在linux中运行服务,当服务启动后,这个终端,可能就被此服务占用了,如果强制使用Ctrl+C来退出,很有可能就会把这个服务给停掉。
因此,需要一个类似于守护进程的方式,来运行服务,并且,不会影响shell终端的使用,虽然可以再重新打开一个shell终端,例如Redis服务启动之后,就会使终端处于阻塞状态,如果强制退出,这个服务就被停掉了。
Linux下运行与控制后台进程的各种方法
1、nohup 
顾名思义,nohup的用途就是让提交的命令忽略所有的hangup信号。 
使用方法:nohup COMMAND [ARG]...
2、setsid 
在一个新的会话中运行命令,从而可以避开当前终端发出的HUP信号。 
使用方法:setsid COMMAND [ARG]...
3、& 
可以结合()产生一个新的子shell并在这个子shell中将任务放置到后台运行,从而不受当前shell终端的HUP信号影响。 
使用方法:(COMMAND [ARG]... &)
通常使用方式为: 
 
三点理由: 
1)nohup保障进程不会被hangup信号异常中断; 
2)将任务放置到后台运行,不占用当前的终端; 
3)将错误输出也打印到log中,默认>只有标准输出,错误输出没有。
这几个命令的使用: 
fg、bg、jobs、&、nohup、ctrl + z命令 
一、&  
加在一个命令的最后,可以把这个命令放到后台执行,如gftp &, 
二、ctrl + z  
可以将一个正在前台执行的命令放到后台,并且处于暂停状态,不可执行 
三、jobs  
查看当前有多少在后台运行的命令  
jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated,但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识;也就是说,jobs命令显示的是当前shell环境中所起的后台正在运行或者被挂起的任务信息; 
四、fg  
将后台中的命令调至前台继续运行  
如果后台中有多个命令,可以用fg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执行的命令的序号(不是pid) 
五、bg  
将一个在后台暂停的命令,变成继续执行 (在后台执行)  
如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执行的命令的序号(不是pid)  
将任务转移到后台运行:  
先ctrl + z;再bg,这样进程就被移到后台运行,终端还能继续接受命令。  
概念:当前任务  
如果后台的任务号有2个,[1],[2];如果当第一个后台任务顺利执行完毕,第二个后台任务还在执行中时,当前任务便会自动变成后台任务号码“[2]” 的后台任务。所以可以得出一点,即当前任务是会变动的。当用户输入“fg”、“bg”和“stop”等命令时,如果不加任何引号,则所变动的均是当前任务 
六:nohup  
如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。 
1、进程的终止
后台进程的终止:
方法一:  
通过jobs命令查看job号(假设为num),然后执行kill %num 
方法二:  
通过ps命令查看job的进程号(PID,假设为pid),然后执行kill pid 
2、前台进程的终止:  
ctrl+c  
kill的其他作用  
kill除了可以终止进程,还能给进程发送其它信号,使用kill -l 可以察看kill支持的信号。  
SIGTERM是不带参数时kill发送的信号,意思是要进程终止运行,但执行与否还得看进程是否支持。如果进程还没有终止,可以使用kill -SIGKILL pid,这是由内核来终止进程,进程不能监听这个信号。 
3、进程的挂起  
后台进程的挂起:  
在solaris中通过stop命令执行,通过jobs命令查看job号(假设为num),然后执行stop %num;  
在redhat中,不存在stop命令,可通过执行命令kill -stop PID,将进程挂起;  
当要重新执行当前被挂起的任务时,通过bg %num 即可将挂起的job的状态由stopped改为running,仍在后台执行;当需要改为在前台执行时,执行命令fg %num即可; 
前台进程的挂起:  
ctrl+Z;  
使用jobs 查看任务。  
  
使用jobs -l来查看每个后台任务的具体进程号  
使用fg %n 关闭。 
使用nohup,相当于把输出流给重定向到一个log文件中,这里为nouhp.out文件。