linux后台启动进程

1、tips进程与终端

父子进程
在linux系统里面,子进程由父进程fork而来,而所有的进程都是由init进程或其子进程fork而来,即init进程是所有进程的祖先。
父子进程的运行是相对独立的,一方的退出不会导致另一方退出。
进程组和会话

  • 进程组:进程组就是多个进程的集合,其中肯定有一个组长,其进程PID等于进程组的PGID
  • 会话:会话(Session)是一个或多个进程组的集合。

Session特点
session可以在任何时候创建,调用setsid函数即可,session中的第一个进程即为session的leader,leader是不能变的。常见的创建session的场景是用户登录,启动bash进程时将会创建新的session,bash进程会作为session的leader,随后bash里面运行的进程(不特殊处理)都将属于这个session。
session的主要特点是当session的leader退出后,session中的所有其它进程将会收到SIGHUP信号,其默认行为是终止进程,即session的leader退出后,session中的其它进程也会退出。
如果session和tty关联的话,它们之间只能一一对应,一个tty只能属于一个session,一个session只能打开一个tty。当然session也可以不和任何tty关联。

2、后台启动进程

进程的启动方式:
1)前台启动:用户输入命令,直接执行程序
2)后台启动:在命令行尾加入“&”符号

2.1、关闭当前的终端,进程随之停止
  • &
    &加到一个命令后,可以让命令在后台运行。
  • CTRL+z
    可以将一个正在前台执行的命令放到后台,并且处于暂停状态。
  • tips
    jobs:
    使用jobs可查看当前有多少在后台运行的命令。
    fg :
    将后台中的命令调至前台继续运行。如果后台中有多个命令,可以用fg %jobnumber(是jobs编号,不是进程号)将选中的命令调出。
    bg:
    将一个在后台暂停的命令,变成在后台继续执行。如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出。
    kill %jobnumber:
    终止后台进程。
2.2、关闭当前的终端,进程继续进行

要使终端关闭时进程不退出,有以下几种情况:
1)用户进程拦截SIGHUP信号。
2)使用户进程和bash进程不在一个session。

  • nohup
    该方法会使进程屏蔽掉SIGHUP信号。
    nohup command,它把标准输出(STDOUT)和标准错误(STDERR)结果输出到nohup.txt文件。这个看似很方便,但是当输出很大的时候,nohup.txt文件会非常大,或者多个后台命令的时候大家都会输出到nohup.txt文件,不利于查找结果和调试程序。
    所以能够重定向输出会非常方便。下面要介绍标准输出,标准输入 和标准错误了。
    /dev/null 表示空设备文件
    0 表示stdin标准输入
    1 表示stdout标准输出
    2 表示stderr标准错误
1 ./command.sh > output 
    标准输出重定向到output文件,其实是 1>output 的缩写 
2 ./command.sh 2>> output 
    将标准错误输出追加到output文件里。
3 nohup ./command.sh > output 2>&1 & 
    主要是中间的 2>&1的意思 
    这个意思是把标准错误(2)重定向到标准输出中(1),而标      
    准输出又定向到文件output里面,所以结果是标准错误和标准输出 
    都导入文件output里面了。 
    如果写成 nohup ./command.sh >output 2>1 &
    就会导致文件output被两次打开,而stdout和stderr将会竞争覆
    盖从而出错,这里中间的&表示合并的意思。
4 /dev/null文件
    这是一个无底洞,任何东西都可以定向到这里,但是却无法打开。 
    所以一般很大的stdou和stderr当你不关心的时候可以利用stdout
    和stderr定向到这里 ./command.sh >/dev/null 2>&1 
  • setsid
    该方法会新建一个新的session,使用户进程和bash不在同一个session,并使自己成为leader。
    只需要在命令使用前加上setsid就可以了。

你可能感兴趣的:(linux后台启动进程)