你是否曾经遇到过在系统休眠时出现的各种问题?比如文件系统被破坏、创建hibernation image失败、设备suspend异常等等。这些问题都可以通过linux进程冻结技术得到解决。
- 进程冻结技术(freezing of tasks)是指在系统hibernate或者suspend的时候,将用户进程和部分内核线程置于“可控”的暂停状态。
- 如果没有冻结技术,进程可以在任意可调度的点暂停,而且直到cpu_down才会暂停并迁移。这会给系统带来很多问题:
- 有可能破坏文件系统。在系统创建hibernate image到cpu down之间,如果有进程还在修改文件系统的内容,这将会导致系统恢复之后无法完全恢复文件系统;
- 有可能导致创建hibernation image失败。创建hibernation image需要足够的内存空间,但是在这期间如果还有进程在申请内存,就可能导致创建失败;
- 有可能干扰设备的suspend和resume。在cpu down之前,device suspend期间,如果进程还在访问设备,尤其是访问竞争资源,就有可能引起设备suspend异常;
- 有可能导致进程感知系统休眠。系统休眠的理想状态是所有任务对休眠过程无感知,睡醒之后全部自动恢复工作,但是有些进程,比如某个进程需要所有cpu online才能正常工作,如果进程不冻结,那么在休眠过程中将会工作异常。
- 冻结的对象是内核中可以被调度执行的实体,包括用户进程、内核线程和work_queue。用户进程默认是可以被冻结的,借用信号处理机制实现;内核线程和work_queue默认是不能被冻结的,少数内核线程和work_queue在创建时指定了freezable标志,这些任务需要对freeze状态进行判断,当系统进入freezing时,主动暂停运行。kernel threads可以通过调用kthread_freezable_should_stop来判断freezing状态,并主动调用__refrigerator进入冻结;work_queue通过判断max_active属性,如果max_active=0,则不能入队新的work,所有work延后执行。
标记系统freeze状态的有三个重要的全局变量:pm_freezing、system_freezing_cnt和pm_nosig_freezing,如果全为0,表示系统未进入冻结;system_freezing_cnt>0表示系统进入冻结,pm_freezing=true表示冻结用户进程,pm_nosig_freezing=true表示冻结内核线程和workqueue。它们会在freeze_processes和freeze_kernel_threads中置位,在thaw_processes和thaw_kernel_threads中清零。
fake_signal_wake_up函数巧妙的利用了信号处理机制,只设置任务的TIF_SIGPENDING位,但不传递任何信号,然后唤醒任务;这样任务在返回用户态时会进入信号处理流程,检查系统的freeze状态,并做相应处理。
任务主动调用try_to_freeze的代码如下:
``` ``` 1. static inline bool try_to_freeze_unsafe(void) 2. { 3. if (likely(!freezing(current))) //检查系统是否处于freezing状态 4. return false; 5. return __refrigerator(false); //主动进入冻结 6. } 7. 8. static inline bool freezing(struct task_struct *p) 9. { 10. if (likely(!atomic_read(&system_freezing_cnt))) //系统总体进入freezing 11. return false; 12. return freezing_slow_path(p); 13. } 14. 15. bool freezing_slow_path(struct task_struct *p) 16. { 17. if (p->flags & PF_NOFREEZE) //当前进程是否允许冻结 18. return false; 19. 20. if (pm_nosig_freezing || cgroup_freezing(p)) //系统冻结kernel threads 21. return true; 22. 23. if (pm_freezing && !(p->flags & PF_KTHREAD)) //系统冻结用户进程 24. return true; 25. 26. return false; 27. }登录后复制
进入冻结状态直到恢复的主要函数:bool __refrigerator(bool check_kthr_stop)
1. { 2. ... 3. for (;;) { 4. set_current_state(TASK_UNINTERRUPTIBLE); //设置进程为UNINTERRUPTIBLE状态 5. 6. spin_lock_irq(&freezer_lock); 7. current->flags |= PF_FROZEN; //设置已冻结状态 8. if (!freezing(current) || 9. (check_kthr_stop && kthread_should_stop())) //判断系统是否还处于冻结 10. current->flags &= ~PF_FROZEN; //如果系统已解冻,则取消冻结状态 11. spin_unlock_irq(&freezer_lock); 12. 13. if (!(current->flags & PF_FROZEN)) //如果已取消冻结,跳出循环,恢复执行 14. break; 15. was_frozen = true; 16. schedule(); 17. } 18. ...... 19. }登录后复制
总之,Linux进程冻结技术是一个非常有用的技术,可以帮助你避免一些潜在的问题,让你的系统更加稳定。如果你想了解更多关于这个技术的信息,可以查看本文提供的参考资料。
以上就是:Linux进程冻结技术:让你的系统更加稳定的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » :Linux进程冻结技术:让你的系统更加稳定
发表评论 取消回复