Exploring the mysterious world of background operations in Linux
Let us explore a mysterious world in the Linux operating system - background running. In daily use, we often need to use background running to let tasks execute silently in the background without affecting our current work. So, how to implement background operation in Linux?
think
First of all, we need to consider a question. Why does the background program exit when you close the terminal directly? That is because when you close the terminal directly, the terminal will send a SIGHUP signal to the background task started in the current environment, causing the running program to hang. Then just ignore SIGHUP. La.
nohup
The most commonly used command is [nohup]. From the name, it can be seen that whether to suspend the running command, close the terminal or log out of an account, the process will continue to run. It must also be used with the [&] symbol.
Usage: nohup Command [ Arg … ] [ & ]
$ nohup sh test.sh & # 直接关闭当前终端,再打开一个查看 $ ps -few|grep test.sh
As can be seen from the above, the parent process of test.sh we are running has become [PID 1]., and is taken over by the Linux main process.
setsid
nohup means ignoring the SIGHUP signal. Are there any other ideas?
The setip command can reopen the session, inherit the ID of the parent process group, and escape the control of the parent process. As you can see from the picture below, the parent process of the test.sh script is already init 1. At this time, regardless of closing or exiting the terminal, it has nothing to do with the background program.
$ setsid sh test.sh

Another difference between setsid and nohup is that there is no need to use the & background symbol.
exit
Use the exit command to exit the terminal, but our program will continue to run. Why is this?
This is because when exiting the terminal using the exit command, the SIGHUP signal will not be sent to the task to which the terminal belongs. It is controlled by the huponexit configuration item. The default is off. You can use the shopt command to view it.

[root@api ~]# shopt |grep huponexit huponexit off
Configure huponexit to on, use the exit command again to exit, and the corresponding tasks will exit accordingly.
[root@api ~]# shopt -s huponexit [root@api ~]# shopt |grep huponexit huponexit on
trap
The trap command is a built-in command in Linux. The action to be taken when receiving the specified signal, followed by the name of the signal to be processed. Common signals are as follows:

When a script goes into the background and we don’t want the terminal to exit and close the program, we can add the trap command to the script to ignore the SIGHUP signal (hang the process).
#!/bin/sh trap "" HUP while true;do date >> /root/test.txt sleep 1 done
Linux screen command is used for multiple window management programs. It can create a terminal and let the program run in it

screen sh test.sh &
As can be seen from the example, the parent process of the test script is the screen terminal process, and the parent process of the screen terminal, PID1, has also completed the running of the background process.
In short, running in the background is a very common and practical technique in Linux. Whether it is performing some background services on the server side or completing some long-running tasks on a personal computer, background operations can help us improve efficiency and facilitate our daily work.
The above is the detailed content of Exploring the mysterious world of background operations in Linux. For more information, please follow other related articles on the PHP Chinese website!

The Internet does not rely on a single operating system, but Linux plays an important role in it. Linux is widely used in servers and network devices and is popular for its stability, security and scalability.

The core of the Linux operating system is its command line interface, which can perform various operations through the command line. 1. File and directory operations use ls, cd, mkdir, rm and other commands to manage files and directories. 2. User and permission management ensures system security and resource allocation through useradd, passwd, chmod and other commands. 3. Process management uses ps, kill and other commands to monitor and control system processes. 4. Network operations include ping, ifconfig, ssh and other commands to configure and manage network connections. 5. System monitoring and maintenance use commands such as top, df, du to understand the system's operating status and resource usage.

Introduction Linux is a powerful operating system favored by developers, system administrators, and power users due to its flexibility and efficiency. However, frequently using long and complex commands can be tedious and er

Linux is suitable for servers, development environments, and embedded systems. 1. As a server operating system, Linux is stable and efficient, and is often used to deploy high-concurrency applications. 2. As a development environment, Linux provides efficient command line tools and package management systems to improve development efficiency. 3. In embedded systems, Linux is lightweight and customizable, suitable for environments with limited resources.

Introduction: Securing the Digital Frontier with Linux-Based Ethical Hacking In our increasingly interconnected world, cybersecurity is paramount. Ethical hacking and penetration testing are vital for proactively identifying and mitigating vulnerabi

The methods for basic Linux learning from scratch include: 1. Understand the file system and command line interface, 2. Master basic commands such as ls, cd, mkdir, 3. Learn file operations, such as creating and editing files, 4. Explore advanced usage such as pipelines and grep commands, 5. Master debugging skills and performance optimization, 6. Continuously improve skills through practice and exploration.

Linux is widely used in servers, embedded systems and desktop environments. 1) In the server field, Linux has become an ideal choice for hosting websites, databases and applications due to its stability and security. 2) In embedded systems, Linux is popular for its high customization and efficiency. 3) In the desktop environment, Linux provides a variety of desktop environments to meet the needs of different users.

The disadvantages of Linux include user experience, software compatibility, hardware support, and learning curve. 1. The user experience is not as friendly as Windows or macOS, and it relies on the command line interface. 2. The software compatibility is not as good as other systems and lacks native versions of many commercial software. 3. Hardware support is not as comprehensive as Windows, and drivers may be compiled manually. 4. The learning curve is steep, and mastering command line operations requires time and patience.


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

Zend Studio 13.0.1
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.