0. nohup
和&
究竟有啥区别?
首先编写名称为test.c
测试代码如下:
#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <sys/wait.h>
#include <sys/types.h>
#define true 1
void * One(void * no)
{
while (true)
{
printf("NUAACS1\n");
sleep(1);
}
}
void * Two(void * no)
{
while (true)
{
printf("NUAACS2\n");
sleep(1);
}
}
void Stop(int signo)
{
printf("oops! stop!!!\n");
_exit(0);
}
int main()
{
int res;
pthread_t A, B;
signal(SIGINT, Stop);
res = pthread_create(&A, NULL, One, NULL);
res = pthread_create(&B, NULL, Two, NULL);
res = pthread_join(A, NULL);
res = pthread_join(B, NULL);
return 0;
}
代码的内容很简单,就是一个输出NUAACS1,NUAACS2!
与循环轮数的死循环程序,每输出一行就休眠1秒,然后使用gcc
进行编译输出test
文件
gcc test.c -o test -l pthread
- 1
能看到编译结果如如下图所示
下面运行 ./test
前台运行程序,会是什么效果呢?
我们可以看到,程序确实如期望的那样每隔一秒会在终端输出一行字符串。
如果我们此时按下Ctrl + C
组合键 ,理论上程序会收到一个SIGINT
信号,如果不做特殊处理,程序的默认行为是终止,操作结果如下图,程序退出执行。
从上图中我我们可以看到如:
- 首先会在终端显示进程号是
21924
- 键入
Ctrl + C
,发出SIGINT
信号,程序会继续运行
接着使用ps -aux | grep test
,来查看一下test运行的进程号,会发现test
的进程号就是21924
接下来我们关掉这个与主机会话的session
通过另外一个会话session
(就是再打开一个SSH
连接),查看test
的进程号,会发现没有名为test
的进程了,因为关闭这个会话session
的同时,程序会收到一个SIGHUP
信号,程序在接收到SIGHUP
信号后会退出运行。
3. 使用nohup
和&
联合运行程序
nohup ./test &
运行程序
可以发现使用nohup
在t运行test
程序会发现:
- 前台没有出现进程号
- 有一个“忽略输入,输出至
nohup.out
的提示 hello
的输出也没有出现在前台ps
看进程号,这次test.out
的进程号是23297
。
此时如果关掉session
(叉掉左侧窗口),程序会收到一个SIGHUP
信号,程序会不会关闭呢?
结果显示,ID
为23297
的test
进程还在。也就是说test
依然在后台稳定的运行中。
接下来我们用kill
把23297
干掉,再查看进程确定已经关闭。
结论
-
结果会输出到终端
-
使用
Ctrl + C
发送SIGINT
信号,程序免疫 -
关闭
session
发送SIGHUP
信号,程序关闭
-
结果默认会输出到
nohup.out
-
使用
Ctrl + C
发送SIGINT
信号,程序关闭 -
关闭
session
发送SIGHUP
信号,程序免疫
平日线上经常使用nohup
和&
配合来启动程序nohup ./test &
:
- 同时免疫
SIGINT
和SIGHUP
信号