Linux 后台启动java jar 程序 nohup java -jar

nohup java -jar demo-0.0.1-SNAPSHOT.jar > app.log 2>&1 & 解释此指令

这条Linux命令是用于后台运行Spring Boot应用的完整指令,我来分解解释每个部分:

  1. nohup - 忽略挂断信号(HUP),保证终端关闭后程序继续运行

  2. java -jar demo-0.0.1-SNAPSHOT.jar - 使用Java运行指定的Spring Boot可执行JAR包

  3. > app.log - 将标准输出重定向到app.log文件(覆盖模式)

  4. 2>&1 - 将标准错误输出重定向到标准输出(即也写入app.log)

  5. & - 让命令在后台运行

组合效果:

  • 在后台启动Spring Boot应用
  • 所有输出(包括错误)都记录到app.log文件
  • 即使用户退出SSH会话,程序仍会持续运行
  • 适合生产环境部署

补充说明:

  • 如需追加日志而不是覆盖,应使用>> app.log
  • 实际使用时建议添加JVM参数,例如:
    nohup java -Xms512m -Xmx1024m -jar demo.jar >> app.log 2>&1 &
  • 查看日志可用tail -f app.log

若不指定具体的日志文件名(如app.log),常见的后台运行Java程序命令有以下几种写法:

1、默认输出到nohup.out文件(自动生成)

复制代码
nohup java -jar demo.jar & 

这会自动在当前目录生成nohup.out文件记录所有输出1112

2、完全丢弃所有输出(不保存日志)

复制代码
nohup java -jar demo.jar >/dev/null 2>&1 & 

将标准输出和错误都重定向到空设备89

3、按日期动态生成日志文件

复制代码
nohup java -jar demo.jar >>demo-$(date +%Y-%m-%d).log 2>&1 & 

每天会自动创建带日期的日志文件(如demo-2025-07-02.log)5

4、分离标准输出和错误输出

复制代码
nohup java -jar demo.jar >>stdout.log 2>>stderr.log & 

将正常日志和错误日志分别存储16

注意:

  • >表示覆盖写入,>>表示追加写入
  • 生产环境建议采用第3或第4种方式保留日志516
  • 使用tail -f 日志文件名可实时查看日志
相关推荐
新手村-小钻风42 分钟前
【CUDA入门·Lesson 1】Ubuntu实战:CUDA 概念、nvidia-smi 工具与 GPU 参数详解
linux·数据库·ubuntu
编啊编程啊程1 小时前
响应式编程框架Reactor【4】
java·开发语言
Funcy8 小时前
XxlJob源码分析01:环境准备
java
the beard8 小时前
Feign整合Sentinel实现服务降级与Feign拦截器实战指南
java·spring·sentinel
THMAIL8 小时前
攻克 Java 分布式难题:并发模型优化与分布式事务处理实战指南
java·开发语言·分布式
小沈同学呀9 小时前
使用Java操作微软 Azure Blob Storage:上传和下载文件
java·microsoft·azure
czhc11400756639 小时前
Linux 830 shell:expect,ss -ant ,while IFS=read -r line,
linux·运维·r语言
滴滴滴嘟嘟嘟.9 小时前
嵌入式Linux驱动开发:蜂鸣器驱动
linux·运维·驱动开发
梅见十柒10 小时前
UNIX网络编程笔记:共享内存区和远程过程调用
linux·服务器·网络·笔记·tcp/ip·udp·unix
CYRUS_STUDIO10 小时前
一步步带你移植 FART 到 Android 10,实现自动化脱壳
android·java·逆向