Linux内功修炼
-
进程崩溃后,Linux 内核是如何清理 Robust Mutex 的?深度解析其底层清理机制
在多线程或多进程共享内存的并发编程中,死锁是一个经典的幽灵。而在所有死锁场景中,最让人头疼的一种是: 一个持有共享锁(Mutex)的进程突然崩溃(如收到 SIGSEGV 信号),导致该锁永远处于被持有状态,其他等待该锁的进程/线程将被永久...
-
进程崩溃后,Linux内核是如何自动释放 flock 文件锁的?
在 Linux 系统中,如果一个进程在持有 flock 锁的情况下意外崩溃(例如收到 SIGSEGV 段错误信号而终止),内核并不会让这个文件锁一直悬空。内核拥有一套极其严密的资源回收机制,能够确保在进程退出时,自动释放其持有的所...
-
Linux 共享内存的深水区:shm_open 与 shmget 会被 Swap 交换吗?
在 Linux 系统底层开发和高性能服务优化中,共享内存(Shared Memory)是实现进程间零拷贝通信的王牌。但许多开发者在设计高并发、低延迟系统时,常常会忽略一个致命的隐患: 当宿主机物理内存不足时,通过 shm_open 或...