最近项目有需要的关系,就抽出点时间研究了一下 Linux 下使用脚本启动Java应用的方式。很简单,大家作为参考。
这个脚本是在网上找到一个挺好的通用 shell 脚本。只需要修改一些配置变量,就可以用来做起动脚本了。并且除了能起动、还支持关闭、重启、查看是否正在运行的功能。
start 函数中,nohup 部分其实也可以提出来放入一个配置变量中。
示例项目源码地址:https://gitee.com/liupeifeng3514/Linux_Java_Shell
这是一个Web项目,在其中提供了一个包含main方法的Java类作为启动类。项目的功能就是每隔两秒钟打印日志到 /tmp/Alog.log 文件中。
log4j.properties 文件
### 输出信息到控制抬 ### log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n ### 输出DEBUG 级别以上的日志到=E://logs/Alog.log ### log4j.logger.com.lpf.ClassA= DEBUG, A, stdout log4j.appender.A=org.apache.log4j.FileAppender log4j.appender.A.File=/tmp/Alog.log log4j.appender.A.layout=org.apache.log4j.PatternLayout log4j.appender.A.layout.ConversionPattern=%d %p [%c] - %m%n代码很简单,就不做过多的解释了。
选中项目—>右键—>Export—>WAR file
将打包好的项目上传到 Linux 服务器上,使用如下命令解压:
[root@peipei3514 src]# unzip -oq Linux_Java_Shell.war -d /usr/local/Linux_Java_Shell命令解释:
-o 不必先询问用户,unzip执行后覆盖原有文件;-q 执行时不显示任何信息;-d <目录> 指定文件解压缩后所要存储的目录。赋予脚本可执行权限:
chmod 555 scriptname 允许任何人都具有可读权和执行权限;chmod +rx scriptname 允许任何人都具有可读权和执行权限;chmod u+rx scriptname 只给脚本的所有者可读和执行权限。查看环境信息:
[root@peipei3514 Linux_Java_Shell]# ./Linux_Java_Shell.sh info System Information: **************************** \S Linux peipei3514 3.10.0-693.21.1.el7.x86_64 #1 SMP Wed Mar 7 19:03:37 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux JAVA_HOME=/usr/local/jdk1.8.0_161/ java version "1.8.0_161" Java(TM) SE Runtime Environment (build 1.8.0_161-b12) Java HotSpot(TM) 64-Bit Server VM (build 25.161-b12, mixed mode) APP_HOME=/usr/local/Linux_Java_Shell/WEB-INF/ APP_MAINCLASS=com.lpf.Test **************************** Usage: ./Linux_Java_Shell.sh {start|stop|restart|status|info}启动应用:
[root@peipei3514 Linux_Java_Shell]# ./Linux_Java_Shell.sh start Starting com.lpf.Test ...(pid=1408) [OK] Usage: ./Linux_Java_Shell.sh {start|stop|restart|status|info}停止应用:
[root@peipei3514 Linux_Java_Shell]# ./Linux_Java_Shell.sh stop Stopping com.lpf.Test ...(pid=1408) [OK] Usage: ./Linux_Java_Shell.sh {start|stop|restart|status|info}启动应用后,可以看到日志的输出:
[root@peipei3514 Linux_Java_Shell]# tail -f /tmp/Alog.log 2018-05-06 18:58:53,128 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:58:54,723 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:58:56,805 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:58:58,803 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:00,795 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:02,783 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:04,806 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:06,809 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:08,812 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:10,794 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:12,796 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:14,792 DEBUG [com.lpf.ClassA] - 这是 debug 消息。 2018-05-06 18:59:16,795 DEBUG [com.lpf.ClassA] - 这是 debug 消息。执行脚本的时候可能会报这样的错误:
-bash: ./Linux_Java_Shell.sh: /bin/sh^M: 坏的解释器: 没有那个文件或目录这是因为 .sh文件是从windows拷贝过来的,所以多了\r,执行:
sed -i 's/\r$//' Linux_Java_Shell.sh会把 Linux_Java_Shell.sh 中的\r 替换成空白,再次执行则成功!
在windows下编辑的时候,换行结尾是 \n\r , 而在linux下是 \n,所以才会有多出来的 \r
参考文章:java.awt.headless 模式