网站首页 > 技术文章 正文
nohup 直译过来就是不挂断,要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部,使用nohup启动的例子:
nohup /usr/bin/java -jar /data/app/SimpleWebServer.jar\
> webserver.log & 2>&1
这样SimpleWebServer.jar在后台启动,所有日志会输出到webserver.log中。
那么接下来使用systemctl管理和启动程序吧:
样例下载地址:
http://www.jibble.org/miniwebserver/
# cat /etc/systemd/system/my-jar-appserver.service
[Unit]
Description=my-jar-appserver
After=network.target
[Service]
User=root
Restart=on-failure
#ExecStart=/bin/systemd-run /usr/bin/java -jar /data/app/SimpleWebServer.jar
ExecStart=/usr/bin/java -jar /data/app/SimpleWebServer.jar
ExecReload=/bin/kill -HUP $MAINPID
[Install]
WantedBy=multi-user.target
## 加入开机自动启动
[root@dev-15-44 /etc/systemd/system]# systemctl enable my-jar-appserver
Created symlink from /etc/systemd/system/multi-user.target.wants\
/my-jar-appserver.service to \
/etc/systemd/system/my-jar-appserver.service.
## 日志:
# ls -l /etc/systemd/system/multi-user.target.wants/my-jar-appserver.service \
lrwxrwxrwx 1 root root 44 Jul 8 11:03 \
/etc/systemd/system/multi-user.target.wants/my-jar-appserver.service -> \
/etc/systemd/system/my-jar-appserver.service
使用了systemctl管理的进程,会对进程进行监控,如果发现进程不存在时会在尝试重启,如Java的OOM(Out Of Memory)情况,进程被误杀等
能够看到无论怎么kill进程,这个jar一直会尝试重新启动,仔细看PID号有变化,除非最后使用 systemctl stop 停止服务之后,进程终于不在了。
## 停止 webserver 程序
[root@dev-15-44 /etc/systemd/system]# systemctl stop my-jar-appserver
[root@dev-15-44 /etc/systemd/system]#
## 日志:
Jul 8 11:01:29 dev-15-44 systemd: Stopping my-jar-appserver...
Jul 8 11:01:29 dev-15-44 systemd: my-jar-appserver.service: main process exited, code=exited, status=143/n/a
Jul 8 11:01:29 dev-15-44 systemd: Stopped my-jar-appserver.
Jul 8 11:01:29 dev-15-44 systemd: Unit my-jar-appserver.service entered failed state.
Jul 8 11:01:29 dev-15-44 systemd: my-jar-appserver.service failed.
## 查看当前java日志
[root@dev-15-44 /etc/systemd/system]#
[root@dev-15-44 /etc/systemd/system]# ps aux|grep java
root 70896 0.0 0.0 112808 976 pts/0 S+ 11:01 0:00 grep --color=auto java
## 删除 my-jar-appserver的自动启动
[root@dev-15-44 /etc/systemd/system]# systemctl disable my-jar-appserver
Removed symlink /etc/systemd/system/multi-user.target.wants/my-jar-appserver.service.
## 日志:
Jul 8 11:02:42 dev-15-44 systemd: Configuration file /etc/systemd/system/node_exporter.service is marked executable. Please remove executable permission bits. Proceeding anyway.
Jul 8 11:02:42 dev-15-44 systemd: Configuration file /etc/systemd/system/node_exporter.service is marked world-writable. Please remove world writability permission bits. Proceeding anyway.
Jul 8 11:02:42 dev-15-44 systemd: [/etc/systemd/system/node_exporter.service:13] Unknown lvalue 'StartLimitIntervalSec' in section 'Service'
# curl localhost -vv
这个jar的webserver默认是开启80端口,允许列目录,而且是根目录“/”哦,有点危险。
# # 查看显示my-jar-appserver是否正在运行
# systemctl is-active my-jar-appserver.service
active
## 显示某个 my-jar-appserver 的底层参数
systemctl show my-jar-appserver.service
## 查看my-jar-appserver的依赖关系
systemctl list-dependencies my-jar-appserver.service
systemctl cat my-jar-appserver.service
猜你喜欢
- 2025-07-28 大模型如何赋能Web渗透测试?(大模型如何赋能web渗透测试工具)
- 2025-07-28 动态切换数据库连接方案(动态切换数据库连接方案是什么)
- 2025-07-28 Apache Tika(apache tika工作流程)
- 2025-07-28 java -jar命令启动SpringBoot应用原理分析
- 2025-07-28 深度探索 Spring Boot3 配置管理:从基础到高级实战
- 2025-07-28 flink sql方式读取kafka实时流数据
- 2025-07-28 小程序源码交付标准详解:必备内容与注意事项
- 2025-07-28 记录程序第一天挖漏洞的过程(漏洞挖掘过程)
- 2025-07-28 springboot从入门到实战开源的全链路追踪系统介绍及实践!
- 2025-07-28 从原理到落地:MCP在Spring AI中的工程实践
- 最近发表
- 标签列表
-
- axure 注册码 (25)
- mutex_lock (30)
- oracleclient (27)
- nfs (25)
- springbatch (28)
- oracle数据库备份 (25)
- dir (26)
- connectionstring属性尚未初始化 (23)
- output (32)
- panel滚动条 (28)
- centos 5 4 (23)
- sql学习 (33)
- c 数组 (33)
- pascal语言教程 (23)
- ppt 教程 (35)
- java7 (24)
- 自适应网站制作 (32)
- server服务自动停止 (25)
- 超链接去掉下划线 (34)
- 什么是堆栈 (22)
- map entry (25)
- ubuntu装qq (25)
- outputstreamwriter (26)
- fill_parent (22)
- mssqlserver jar (30)