No more fear of process deadlock - solution to Linux process freezing
When using Linux systems for development or operation and maintenance, we often encounter process deadlock problems. When a process deadlocks, the response speed of the entire system will be significantly reduced, or even cause the system to crash. However, as a Linux enthusiast, we no longer have to be afraid of process deadlock. Because the Linux system provides a powerful tool - process freezing, which can effectively solve the process deadlock problem. This article will introduce in detail the principle and application method of Linux process freezing.

1 What is process freezing
Process freezing technology (freezing of tasks) refers to placing user processes and some kernel threads in a "controllable" pause state when the system hibernates or suspends.
2 Why freezing technology is needed
Assuming there is no freezing technology, the process can be suspended at any schedulable point, and will not be suspended and migrated until cpu_down. This can cause a lot of problems for the system:
(1) It is possible to damage the file system. If there are processes still modifying the contents of the file system between the system creating the hibernate image and the CPU down, this will result in the file system being unable to be fully restored after the system is restored;
(2) It may cause the creation of hibernation image to fail. Creating a hibernation image requires sufficient memory space, but if there are still processes applying for memory during this period, the creation may fail;
(3) It may interfere with the device's suspend and resume. Before CPU down, during device suspend, if the process is still accessing the device, especially accessing competing resources, it may cause device suspend exception;
(4) It may cause the process to sense system sleep. The ideal state of system hibernation is that all tasks are unaware of the hibernation process and automatically resume work after waking up. However, some processes, such as a certain process, require all CPUs to be online to work properly. If the process does not freeze, it will Work abnormally.
3 Code implementation framework
The frozen objects are entities in the kernel that can be scheduled for execution, including user processes, kernel threads and work_queue. User processes can be frozen by default, which is implemented by borrowing the signal processing mechanism; kernel threads and work_queue cannot be frozen by default. A few kernel threads and work_queue specify the freezeable flag when they are created. These tasks need to judge the freeze status. When the system When entering freezing, the operation is automatically suspended.
Kernel threads can determine the freezing status by calling kthread_freezable_should_stop, and actively call __refrigerator to enter freezing; work_queue determines the max_active attribute. If max_active=0, new work cannot be queued, and all work is delayed.
There are three important global variables that mark the system freeze status: pm_freezing, system_freezing_cnt and pm_nosig_freezing. If all are 0, it means that the system has not entered freezing; system_freezing_cnt》0 means that the system has entered freezing, pm_freezing=true means freezing user processes, pm_nosig_freezing= true means freezing kernel threads and workqueue. They will be set in freeze_processes and freeze_kernel_threads, and cleared in thaw_processes and thaw_kernel_threads.
The fake_signal_wake_up function cleverly makes use of the signal processing mechanism. It only sets the TIF_SIGPENDING bit of the task, but does not pass any signal, and then wakes up the task; in this way, the task will enter the signal processing process when returning to user mode, check the freeze status of the system, and Deal with it accordingly.
The code for the task to actively call try_to_freeze is as follows:
static inline bool try_to_freeze_unsafe(void) { if (likely(!freezing(current))) //检查系统是否处于freezing状态 return false; return __refrigerator(false); //主动进入冻结 } static inline bool freezing(struct task_struct *p) { if (likely(!atomic_read(&system_freezing_cnt))) //系统总体进入freezing return false; return freezing_slow_path(p); } bool freezing_slow_path(struct task_struct *p) { if (p-》flags & PF_NOFREEZE) //当前进程是否允许冻结 return false; if (pm_nosig_freezing || cgroup_freezing(p)) //系统冻结kernel threads return true; if (pm_freezing && !(p-》flags & PF_KTHREAD)) //系统冻结用户进程 return true; return false; } 进入冻结状态直到恢复的主要函数:bool __refrigerator(bool check_kthr_stop) { 。.. for (;;) { set_current_state(TASK_UNINTERRUPTIBLE); //设置进程为UNINTERRUPTIBLE状态 spin_lock_irq(&freezer_lock); current-》flags |= PF_FROZEN; //设置已冻结状态 if (!freezing(current) || (check_kthr_stop && kthread_should_stop())) //判断系统是否还处于冻结 current-》flags &= ~PF_FROZEN; //如果系统已解冻,则取消冻结状态 spin_unlock_irq(&freezer_lock); if (!(current-》flags & PF_FROZEN)) //如果已取消冻结,跳出循环,恢复执行 break; was_frozen = true; schedule(); } 。..。.. }
Through this article's introduction to the Linux process freezing tool, we learned its principles and usage, and mastered how to effectively solve the process deadlock problem. The process freezing tool solves common operating system problems for us and provides us with a more efficient and stable working environment. When we encounter a process deadlock, there is no need to panic. We can easily solve the problem through process freezing tools.
The above is the detailed content of No more fear of process deadlock - solution to Linux process freezing. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The key differences between CentOS and Ubuntu are: origin (CentOS originates from Red Hat, for enterprises; Ubuntu originates from Debian, for individuals), package management (CentOS uses yum, focusing on stability; Ubuntu uses apt, for high update frequency), support cycle (CentOS provides 10 years of support, Ubuntu provides 5 years of LTS support), community support (CentOS focuses on stability, Ubuntu provides a wide range of tutorials and documents), uses (CentOS is biased towards servers, Ubuntu is suitable for servers and desktops), other differences include installation simplicity (CentOS is thin)

CentOS will be shut down in 2024 because its upstream distribution, RHEL 8, has been shut down. This shutdown will affect the CentOS 8 system, preventing it from continuing to receive updates. Users should plan for migration, and recommended options include CentOS Stream, AlmaLinux, and Rocky Linux to keep the system safe and stable.

Docker uses Linux kernel features to provide an efficient and isolated application running environment. Its working principle is as follows: 1. The mirror is used as a read-only template, which contains everything you need to run the application; 2. The Union File System (UnionFS) stacks multiple file systems, only storing the differences, saving space and speeding up; 3. The daemon manages the mirrors and containers, and the client uses them for interaction; 4. Namespaces and cgroups implement container isolation and resource limitations; 5. Multiple network modes support container interconnection. Only by understanding these core concepts can you better utilize Docker.

How to use Docker Desktop? Docker Desktop is a tool for running Docker containers on local machines. The steps to use include: 1. Install Docker Desktop; 2. Start Docker Desktop; 3. Create Docker image (using Dockerfile); 4. Build Docker image (using docker build); 5. Run Docker container (using docker run).

CentOS installation steps: Download the ISO image and burn bootable media; boot and select the installation source; select the language and keyboard layout; configure the network; partition the hard disk; set the system clock; create the root user; select the software package; start the installation; restart and boot from the hard disk after the installation is completed.

Backup and Recovery Policy of GitLab under CentOS System In order to ensure data security and recoverability, GitLab on CentOS provides a variety of backup methods. This article will introduce several common backup methods, configuration parameters and recovery processes in detail to help you establish a complete GitLab backup and recovery strategy. 1. Manual backup Use the gitlab-rakegitlab:backup:create command to execute manual backup. This command backs up key information such as GitLab repository, database, users, user groups, keys, and permissions. The default backup file is stored in the /var/opt/gitlab/backups directory. You can modify /etc/gitlab

CentOS hard disk mount is divided into the following steps: determine the hard disk device name (/dev/sdX); create a mount point (it is recommended to use /mnt/newdisk); execute the mount command (mount /dev/sdX1 /mnt/newdisk); edit the /etc/fstab file to add a permanent mount configuration; use the umount command to uninstall the device to ensure that no process uses the device.

After CentOS is stopped, users can take the following measures to deal with it: Select a compatible distribution: such as AlmaLinux, Rocky Linux, and CentOS Stream. Migrate to commercial distributions: such as Red Hat Enterprise Linux, Oracle Linux. Upgrade to CentOS 9 Stream: Rolling distribution, providing the latest technology. Select other Linux distributions: such as Ubuntu, Debian. Evaluate other options such as containers, virtual machines, or cloud platforms.
