• nohup命令详解


      

    基础命令学习目录首页

    原文链接:https://blog.csdn.net/hfismyangel/article/details/80258126

    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:

    1
    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 

    1
    ps -aux|grep chat.js
     a:显示所有程序 
     u:以用户为主的格式来显示 
     x:显示所有程序,不以终端机来区分

    注:

      用ps -def | grep查找进程很方便,最后一行总是会grep自己

      用grep -v参数可以将grep命令排除掉

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

      再用awk提取一下进程ID 

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

    
    

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

    查看使用某端口的进程

    1
    lsof -i:8090

    1
    netstat -ap|grep 8090

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

    1
    netstat -nap|grep 7779

    使用kill杀掉进城后再启动

    4.终止后台运行的进程

    1
    kill -9  进程号

    今天在linux上部署wdt程序,在SSH客户端执行./start-dishi.sh,启动成功,在关闭SSH客户端后,运行的程序也同时终止了,怎样才能保证在推出SSH客户端后程序能一直执行呢?通过网上查找资料,发现需要使用nohup命令。
    完美解决方案:nohup ./start-dishi.sh >output 2>&1 &

    现对上面的命令进行下解释

    用途:不挂断地运行命令。
    语法:nohup Command [ Arg ... ] [ & ]
    描述:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。

    操作系统中有三个常用的流:
      0:标准输入流 stdin
      1:标准输出流 stdout
      2:标准错误流 stderr
      一般当我们用 > console.txt,实际是 1>console.txt的省略用法;< console.txt ,实际是 0 < console.txt的省略用法。
     
     
    下面步入正题:
    >nohup ./start-dishi.sh >output 2>&1 &
    解释:
     1. 带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上); 
     2. 2>&1的意思 
      这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的. 
      这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了 
    ==================================================================================
    最后谈一下/dev/null文件的作用,这是一个无底洞,任何东西都可以定向到这里,但是却无法打开。 所以一般很大的stdou和stderr当你不关心的时候可以利用stdout和stderr定向到这里>./command.sh >/dev/null 2>&1 
    It’s not too late to change.
    原文链接:https://www.cnblogs.com/zq-inlook/p/3577003.html
  • 相关阅读:
    熟悉常用的HBase操作,编写MapReduce作业
    爬虫大作业
    熟悉常用的HDFS操作
    数据结构化与保存
    获取全部校园新闻
    爬取校园新闻首页的新闻
    网络爬虫基础练习
    leetcode
    归并排序
    选择排序法
  • 原文地址:https://www.cnblogs.com/machangwei-8/p/10392063.html
Copyright © 2020-2023  润新知