zoukankan      html  css  js  c++  java
  • nohup sh start.sh >/dev/null 2>&1 &

    nohup sh start.sh >/dev/null 2>&1 &


    背景说明

    start.sh 脚本里,写了Java应用程序启动的相关命令,并且在 log4j.properties 中配置了日志的输出路径。

    此时,启动服务的时候,如果使用如下命令,则会在start.sh脚本所在的目录下,产生一个名为 nohup.out 的输出文件。

    nohup sh start.sh &

    这个多余的 nohup.out 文件是不需要的,可以使用如下命令解决:

    nohup sh start.sh >/dev/null 2>&1 &

    命令解析

    1、nohup &

    nohup 表示永久运行& 表示后台运行

    2、>/dev/null 2>&1

    /dev/null 代表空设备文件,也就是不输出任何信息到终端。

    操作系统中有三个常用的流:
      0:标准输入流 stdin
      1:标准输出流 stdout
      2:标准错误流 stderr

    ">/dev/null" 等价于 "1>/dev/null",表示标准输出(1)输出到 /dev/null 中,即终端不输出标准输出信息

    "2>&1" 中的 “&” 是等价于的意思,表示 标准错误(2)输出的位置 等价于 标准输出(1)的位置,即等价于 “2>/dev/null”, 即终端不输出标准错误信息

    因此,">/dev/null 2>&1" 表示 标准错误信息和标准输出信息,在终端上均不输出。


    3、指定输出文件

    如果想要将服务启动和运行过程中的日志信息输出到指定位置(比如:/var/log/start.log),可以参考如下命令:

    nohup sh start.sh >/var/log/start.log 2>&1 &
  • 相关阅读:
    Java之ServiceLoader
    docker学习(3)--Dockfile详解
    docker学习(2)--基础命令
    docker学习(1)--基础概念
    dubbo学习(1)--简单的入门搭建实例
    Flume搭建及学习(基础篇)
    VM下--Linux根分区磁盘扩容
    Windows10下简单搭建zookeeper
    Windows10下搭建TensorFlow环境
    cmath库函数
  • 原文地址:https://www.cnblogs.com/miracle-luna/p/11802630.html
Copyright © 2011-2022 走看看