专业的JAVA编程教程与资源

网站首页 > java教程 正文

还在用nohup启动java jar服务?试试强大的systemctl吧

temp10 2024-12-28 15:46:33 java教程 12 ℃ 0 评论

nohup 直译过来就是不挂断,要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部,使用nohup启动的例子:

nohup /usr/bin/java -jar /data/app/SimpleWebServer.jar\
  > webserver.log & 2>&1

这样SimpleWebServer.jar在后台启动,所有日志会输出到webserver.log中。

还在用nohup启动java jar服务?试试强大的systemctl吧


那么接下来使用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

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表