Linux

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > Linux > linux后台启动Jar包打印日志

linux后台启动Jar包打印日志方式(windows10)

作者:可乐cc呀

这篇文章主要介绍了linux后台启动Jar包打印日志方式(windows10),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

前言

不多解释命令,一看就懂,如下配置 bat 文件即可

之后会另写一篇bat脚本命令大全,看心情把,就这样

一,windows10 创建start.bat文件

在这里插入图片描述

二,windows10 以文本编辑打开文件

编辑如下命令

@echo off
%1 mshta vbscript:CreateObject("WScript.Shell").Run("%~s0 ::",0,FALSE)(window.close)&&exit
java -jar D:\test\test.jar > D:\test\log\server.log 2>&1 &
exit

三,windows10 指定配置文件,配置Jvm 环境

编辑如下命令

@echo off

set AppName=monitor-admin

echo start %AppName% service

set JAVA_OPTS=-Xms512m -Xmx2048m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m -XX:+HeapDumpOnOutOfMemoryError ^
-XX:+PrintGCDateStamps  -XX:+PrintGCDetails -XX:NewRatio=1 -XX:SurvivorRatio=30 -XX:+UseParallelGC -XX:+UseParallelOldGC


java -jar  %JAVA_OPTS% ./bin/%AppName%.jar --spring.config.location=./conf/application.yml,./conf/application-druid.yml > ./log/server.log 2>&1 &

echo start success close window

pause

四,windows10 创建stop.bat 关闭特定端口的java程序

@echo off

set port=10011

echo start kill app server, by %port%

for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do taskkill /f /pid %%m


echo end

pause

五,windows10 创建restart.bat ,重启jar包

@echo off
%1 mshta vbscript:CreateObject("WScript.Shell").Run("%~s0 ::",0,FALSE)(window.close)&&exit
set port=8080
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%port%"') do taskkill /f /pid %%m &
set JAVA_OPTS=-Xms256m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m
java -jar   D:\test\test.jar  --spring.config.location=./conf/application.yml  >  D:\test\log\server.log 2>&1 &
exit

六,Linux下创建 start.sh 文件

将文件变为可执行文件

chmod 777 start.sh

编辑文件内容

AppName 变量值,改为自己的jar 名称即可

#!/bin/sh

APP_HOME="$(cd "$(dirname "$BASH_SOURCE")" && pwd)"
AppName=test
JAR_PATH=$(find "$APP_HOME"/bin -name "${AppName}*.jar")
JAR_NAME=${JAR_PATH##*/}
APP_PID="app.pid"

# JVM参数
JVM_OPTS="-Dname=$JAR_NAME  -Duser.timezone=Asia/Shanghai -Xms512m -Xmx2048m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m -XX:+HeapDumpOnOutOfMemoryError \
-XX:+PrintGCDateStamps  -XX:+PrintGCDetails -XX:NewRatio=1 -XX:SurvivorRatio=30 -XX:+UseParallelGC -XX:+UseParallelOldGC"

PID=""
query() {
  PID=$(ps -ef | grep java | grep "$APP_HOME"/bin/$AppName | grep -v grep | awk '{print $2}')
}

echo "Start $JAR_NAME ..."

cd "$APP_HOME" || exit

query
if [ x"$PID" != x"" ]; then
  echo "$AppName is running on pid : ${PID}"
  echo "${PID}" >$APP_PID
else
  nohup java "$JVM_OPTS" -jar "$JAR_PATH" --spring.config.location=./conf/application.yml,./conf/application-druid.yml >/dev/null 2>&1 &
  echo "Start running..."

  sleep 3

  query
  echo "${PID}" >$APP_PID
  echo "Start $JAR_NAME success on pid: ${PID}"
fi

执行文件

./start.sh

七,linux下创建 stop.sh 文件

同上命令,不多撰述,打字费键盘,主要是懒

#!/bin/sh

APP_HOME=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
AppName=test

PID=""
query() {
  PID=$(ps -ef | grep java | grep "$APP_HOME"/bin/$AppName | grep -v grep | awk '{print $2}')
}

echo "Stop $AppName"

query
if [ x"$PID" != x"" ]; then
  kill -TERM "$PID"
  echo "$AppName (pid:$PID) exiting..."
  while [ x"$PID" != x"" ]; do
    sleep 1
    query
  done
  echo "$AppName exited."
else
  echo "$AppName already stopped."
fi

八,linux下创建 restart.sh 文件

同上命令,不多撰述,打字费键盘,主要是懒

#!/bin/sh

APP_HOME="$(cd "$(dirname "$BASH_SOURCE")" && pwd)"

cd "$APP_HOME" || exit

sh stop.sh
sleep 2
sh start.sh

九,总结

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

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