java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > java -jar启动项目及日志输出问题

java -jar启动项目以及日志输出的相关问题

作者:零下三度撸代码

这篇文章主要介绍了java -jar启动项目以及日志输出的相关问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

windows下启动、停止、重启jar项目

后台启动

@echo off
START "app" javaw -jar app-0.0.1-SNAPSHOT.jar

停止jar项目

@echo off
set port=3061
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do (
    echo kill the process %%m who use the port 
    taskkill /pid %%m -t -f
    goto q
)
:q

上述的方式是直接使用taskkill命令来关闭项目和linux中的kill一样

重启项目

@echo off
set port=3061
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do (
    echo kill the process %%m who use the port 
    taskkill /pid %%m -t -f
    goto start
)
:start

START "app" javaw -jar app-0.0.1-SNAPSHOT.jar

重启的方式就是将程序先关闭,然后重新启动。

Linux下关于启动服务器日志相关操作

java -jar xxx.jar

这种方式是在linux下的窗口启动,关闭窗口就相当于关闭了服务器。

服务器后台启动

nohup java -jar xxx.jar &

这样就会将程序运行到了后台,但是没有特指定日志输出的位置和日志名字,因此日志默认在当前目录的nohup.out下。

后台启动且指定日志位置

日志输出的方式需要知道如下:

因此有如下两种方式

nohup java -jar xxx.jar > /dev/null &

日志重定向到/dev/null中,这这个目录是linux的空设备文件,写入这里的内容会全部丢失掉。

因此没有日志输出

nohup java -jar xxx.jar > /dev/null 2>&1 &

标准日志无输出,错误日志重定向到/dev/null,因此错误日志也没有输出

nohup java -jar xxx.jar > /dev/null 2>log.error &

错误日志输出到当前目录的log.error文件中

nohup java -jar xxx.jar > log.out 2>&1 &

标准日志和错误日志都输出到当前的目录的log.out文件中

每天都输出一个文件

nohup java -jar xxx.jar | /usr/local/cronlog/sbin/cronlog logs/console-%Y-%m-%d.out &

上述的方式是使用cron每天定时的方式来产生一个日志文件。

总结

以上就是对windows启动项目相关的逻辑、以及对启动项目指定生成日志的方式。大家在后续可以使用这种方式来启动自己的打包后的项目。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文