linux后台启动,不输出日志文件

nohup命令用于在Linux系统后台持续运行程序,即使关闭终端也不会受到影响。它会创建一个nohup.out日志文件,默认在当前目录或$HOME/nohup.out中记录输出。nohup不直接将程序放入后台,但配合&符号,程序可以在后台继续运行。通过重定向标准输入、输出和错误,可以实现日志记录。例如:nohup java-jar lncms.war > xx.log 2>&1 &,这样既能在关闭终端后保持运行,又能将日志写入xx.log文件。

nohup命令
nohup 英文全称 no hang up(不挂起),用于在系统后台不挂断地运行命令,退出终端不会影响程序的运行。

nohup 命令,在默认情况下(非重定向时),会输出一个名叫 nohup.out 的文件到当前目录下,如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。

nohup的本质是通过忽略SIGHUP信号,从而不会在终端关闭会退出时由于SIGHUP信号导致程序退出,nohup本身不会将程序放入后台运行,但是通过nohup方式启动的程序,由于其忽略了SIGHUP信号,其接收到SIGHUP信号也不会退出。

语法格式

nohup Command [ Arg … ] [&]
参数说明
Command:要执行的命令。

Arg:一些参数,可以指定输出文件。

&:让命令在后台执行,终端退出后命令仍旧执行。

大多数人都会见到如下方式使用, 执行命令并重定向输入到xx.log文件中

nohup Command > xx.log 2>&1 &

2>&1 解释

将标准错误 2 重定向到标准输出 &1 ,标准输出 &1 再被重定向输入到文件中。

0 – stdin (standard input,标准输入)
1 – stdout (standard output,标准输出)
2 – stderr (standard error,标准错误输出)

&命令
就是将程序放在后台运行。对于shell来说,通过& 可以把一个程序放在后台运行。其就是作为一个job来运行的。此时如果终端断开,程序还是会被SIGHUP信号导致退出的

语法格式

command   [Arg ...]   &

参数说明

Command:要执行的命令。

Arg:一些参数,可以指定输出文件。

总结

nohup执行后默认会将输出保存在nohup.out文件,但执行后无法接受标准输入,关闭窗口后仍然会运行
&无法将标准输出保存到文件中,可以接受标准输入,关闭窗口后程序就会停止
nohup &一起使用综合了两者的优点,既能标准输入也能将标准输出的日志输入到文件,关闭窗口后仍然会运行

示例

1. nohup java -jar lncms.war >/dev/null nohup.out &dev/null
输出到到黑洞,意思是不输出日志文件

2.nohup java -jar lncms.war-> 8081.log &
这种就是吧日志写到8081.log

3.nohup java -jar lncms .war&
这种就是默认的nohup.out

### 启动 Java 应用并记录日志Linux 系统中,可以通过 `nohup` 命令将 Java 应用程序以后台方式启动,并将日志输出到指定文件。以下是一些常见的做法: #### 1. 启动 Java 应用并将日志输出到指定文件 ```bash nohup java -jar /home/pro/application/monitor/zop-monitor-web.jar > /logs/zop-monitor-web.log 2>&1 & ``` - `nohup`:确保程序在终端关闭后继续运行。 - `>`:将标准输出重定向到指定的文件。 - `2>&1`:将标准错误输出重定向到标准输出。 - `&`:将程序放入后台运行。 #### 2. 按天生成日志文件 如果希望每天生成一个新的日志文件,可以使用 `date` 命令动态生成日志文件名: ```bash nohup java -jar app_name.jar >> /home/log/app_name-$(date +%Y-%m-%d).log 2>&1 & ``` - `$(date +%Y-%m-%d)`:动态生成当前日期,格式为 `YYYY-MM-DD`,确保每天生成一个独立的日志文件。 #### 3. 查看日志文件 可以使用 `tail` 命令实时查看日志文件的内容: ```bash tail -f /logs/zop-monitor-web.log ``` - `-f`:实时跟踪日志文件的更新内容。 #### 4. 检查 Java 进程 可以使用 `jps` 命令查看当前所有 Java 进程: ```bash jps ``` - `jps`:显示所有 Java 进程的 PID 和主类名,便于管理和调试。 #### 5. 使用脚本管理 Java 应用 可以编写一个启动脚本(例如 `run.sh`),用于管理 Java 应用的启动、停止和重启操作。以下是一个简单的脚本示例: ```bash #!/bin/bash APP_NAME="zop-monitor-web" JAR_PATH="/home/pro/application/monitor/${APP_NAME}.jar" LOG_PATH="/logs/${APP_NAME}.log" start() { nohup java -jar $JAR_PATH > $LOG_PATH 2>&1 & echo "$APP_NAME started." } stop() { PID=$(ps -ef | grep $APP_NAME | grep -v grep | awk '{print $2}') if [ -n "$PID" ]; then kill -9 $PID echo "$APP_NAME stopped." else echo "$APP_NAME is not running." fi } case "$1" in start) start ;; stop) stop ;; restart) stop start ;; *) echo "Usage: $0 {start|stop|restart}" exit 1 esac exit 0 ``` - `start`:启动 Java 应用。 - `stop`:停止 Java 应用。 - `restart`:重启 Java 应用。 #### 6. 目录结构管理 为了更好地管理 Java 应用,建议按照以下目录结构组织文件: ``` /home/pro/application/monitor/ ├── config/ ├── lib/ ├── logs/ │ └── zop-monitor-web.log ├── run.sh └── zop-monitor-web.jar ``` - `config/`:存放配置文件。 - `lib/`:存放依赖的 JAR 包。 - `logs/`:存放日志文件。 - `run.sh`:启动脚本。 - `zop-monitor-web.jar`:Java 应用的 JAR 包。 通过上述方法,可以在 Linux 系统中轻松实现 Java 应用的后台运行,并有效管理日志输出[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值