nginx_3_2终端和进程的关系
Posted ~千里之行,始于足下~
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx_3_2终端和进程的关系相关的知识,希望对你有一定的参考价值。
一:终端和进程的关系
(2.1)终端与bash进程
ps -ef | grep bash
pts(虚拟终端),每连接一个虚拟终端到乌班图linux操作系统,就会出现 一个bash进程(shell[壳]),黑窗口,用于解释用户输入的命令
bash = shell = 命令行解释器
whereis bash(查找路径)
(2.2)终端上的开启进程
ps -la
man ps(查找命令的用法)
随着终端的退出,这个终端上运行的进程nginx也退出了;
可执行程序nginx是bash的子进程;
《unix环境高级编程》第九章 进程关系;
(2.3)进程关系进一步分析
每个进程还属于一个进程组:一个或者多个进程的集合,每个进程组有一个唯一 的进程组ID,可以调用系统函数来创建进程组、加入进程组
“会话”(session):是一个或者多个进程组的集合
一般,只要不进行特殊的系统函数调用,一个bash(shell)上边运行的所有程序都 属于一个会话,而这个会话有一个session leader;
那么这个bash(shell)通常就是session leader; 你可以调用系统功函数创建新的session。(setsid)
ps -eo pid,ppid,sid,tty,pgrp,comm | grep -E 'bash|PID|nginx'(测试打印指令)
a)如果我 xshell终端要断开的话,系统就会发送SIGHUP信号(终端断开信号),给session leader,也就是这个bash进程
b)bash进程 收到 SIGHUP信号后,bash会把这个信号发送给session里边的所有进程,收到这个SIGHUP信号的进程的缺省动作就是退出;
(2.4)strace工具的使用
linux下调试分析诊断工具:可以跟踪程序执行时进程的系统调用以及所收到的信号;
a)跟踪nginx进程 : sudo strace -e trace=signal -p 1359
kill(4294965937, SIGHUP) :发送信号SIGHUP给这个 -1359的绝对值所在的进程组;所以nginx进程就收到了SIGHUP信号
综合来讲,这个bash先发送SIGHUP给 同一个session里边的所有进程;
然后再发送SIGHUP给自己;
(2.5)终端关闭时如何让进程不退出
a)nginx进程拦截(忽略)SIGHUP(nginx收到这个信号并告诉操作系统,我不想死,请不要把我杀死)信号,是不是可以;(注册sighub为默认处理动作)
b)nginx进程和bash进程不再同一个seeion里;
孤儿进程
setsid函数不适合进程组组长调用;
setsid命令:启动一个进程,而且能够使启动的进程在一个新的session中,这样的话,终端关闭时该进程就不会退出,试试
setsid ./nginx
nohup(no hang up不要挂断),用该命令启动的进程跟上边忽略掉SIGHUP信号,道理相同
该命令会把屏幕输出重新定位到当前目录的nohup.out
(2.6)后台运行 &
后台执行,执行这个程序的同时,你的终端能够干其他事情;你如果不用 后台执行,那么你执行这个程序后,你的终端就只能等这个程序完成后才能继续执行其他的操作;
fg切换到前台
以上是关于nginx_3_2终端和进程的关系的主要内容,如果未能解决你的问题,请参考以下文章