Linux进程:假死的恐怖(linux进程假死)
Linux进程:假死的恐怖
Linux进程可以提高工作效率,但是如果它出现“假死”状态,则会给用户带来巨大的麻烦和恐惧。所谓假死,就是进程独占系统资源,出现不更新状态的问题,以至于用户无法得到期望的结果,这在Linux系统中非常常见。
Linux的假死一般是由进程死锁引起的。死锁就是多个进程因争夺相同的资源而牵连在一起,从而导致某一个进程一直占有系统资源的状态。例如,当两个进程分别调用函数:pthread_mutex_lock (p1) 和 pthread_mutex_lock (p2),同时尝试访问这两个互斥量,此时就可能发生死锁。因为 p1和 p2 互相等待对方释放资源,没有一个能够得到资源,从而发生“假死”状态。
此外,其他系统调用也有可能导致假死,比如磁盘IO操作、系统中断和上下文切换失败。
解决Linux假死问题的一个基本办法是重置或重启进程。另一种更安全的做法是分析假死的代码,尝试找到引发死锁的原因并进行优化调整。例如,在上述示例中,使用pthread_mutex_trylock函数可以有效避免进程死锁:
/* 之前分析可能存在死锁的地方 */
if ( -1 == pthread_mutex_lock (p1))
{
/*得到p1之前要尝试用pthread_mutex_trylock获取锁,若失败再尝试其他方法 */
/* Get p1, try to get lock with pthread_mutex_trylock first, if it fails, try other methods. */
if ( 0 == pthread_mutex_trylock (p1))
{
/* 获取p1成功 */
/* Got p1 successfully. */
}
else
{
/* 获取p1失败,则尝试其他方法,以避免死锁 */
/* Failed to get p1, try other methods to avoid deadlock. */
}
}
此外,在实际开发中,可以不使用多线程,而是使用fork()函数来创建子进程,从而消除进程死锁引起假死的风险。
总而言之,Linux进程出现假死状态会带来很大的困扰和恐惧,针对此