后台--nohup &

这篇博客主要介绍了如何在Linux系统中使用`nohup`命令不挂断地运行程序,并将其放在后台。`nohup`命令的输出会被附加到`nohup.out`文件,同时讨论了与`&`符号结合使用的方法,以及如何查看和管理后台进程。此外,还提到了检查和结束占用特定端口进程的技巧。
摘要由CSDN通过智能技术生成

1.nohup
用途:不挂断地运行命令。
语法:nohup Command [ Arg … ] [ & ]
  无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。
  如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。
  如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。
退出状态:该命令返回下列出口值:   
  126 可以查找但不能调用 Command 参数指定的命令。   
  127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。   
  否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。
2.&
用途:在后台运行
一般两个一起用
nohup command &
eg:

nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &

结果
进程号7585
查看运行的后台进程
(1)jobs -l
结果
jobs命令只看当前终端生效的,关闭终端后,在另一个终端jobs已经无法看到后台跑得程序了,此时利用ps(进程查看命令)
(2)ps -ef

ps -aux|grep chat.js

a:显示所有程序
u:以用户为主的格式来显示
x:显示所有程序,不以终端机来区分
结果
注:
  用ps -def | grep查找进程很方便,最后一行总是会grep自己
  用grep -v参数可以将grep命令排除掉

ps -aux|grep chat.js| grep -v grep

结果

再用awk提取一下进程ID

ps -aux|grep chat.js| grep -v grep | awk '{print $2}'

结果

3.如果某个进程起不来,可能是某个端口被占用
查看使用某端口的进程

lsof -i:8090

结果

netstat -ap|grep 8090

结果

查看到进程id之后,使用netstat命令查看其占用的端口

netstat -nap|grep 7779

结果

使用kill杀掉进城后再启动
4.终止后台运行的进程

kill -9  进程号

结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值