linux下的脚本
#!/bin/sh
# 该脚本为Linux下启动java程序的脚本
# 特别注意:
# 该脚本使用系统kill命令来强制终止指定的java程序进程。
# 所以在杀死进程前,可能会造成数据丢失或数据不完整。如果必须要考虑到这类情况,则需要改写此脚本,
# 根据实际情况来修改以下配置信息 ##################################
# JAVA应用程序的名称
APP_NAME="app_name"
# JAVA应用程序端口号
SERVER_PORT=8200
# jar包存放路径
JAR_PATH='/var/www/appPack'
# jar包名称
JAR_NAME="$APP_NAME.jar"
# PID 代表是PID文件
JAR_PID=$JAR_NAME\.pid
# 日志输出文件
LOG_FILE=logs
# java虚拟机启动参数
#-Xms:初始Heap(堆)大小,使用的最小内存,cpu性能高时此值应设的大一些
XMS="-Xms200m"
#-Xmx: java heap(堆)最大值,使用的最大内存
XMX="-Xmx512m"
#-XX:MetaspaceSize:元空间Metaspace扩容时触发FullGC(垃圾回收)的初始化阈值
METASPACE_SIZE="-XX:MetaspaceSize=512m"
#-XX:MaxMetaspaceSize: 元空间Metaspace扩容时触发FullGC(垃圾回收)的最大阈值;建议MetaspaceSize和MaxMetaspaceSize设置一样大
MAX_METASPACE_SIZE="-XX:MaxMetaspaceSize=512m"
#-XX:+PrintGCDateStamps: GC日志打印时间戳信息,你可以通过-XX:+PrintGCDateStamps开启,或者-XX:-PrintGCDateStamps关闭 取值boolean
PRINTGCDATESTAMPS="-XX:+PrintGCDateStamps"
#-XX:+PrintGCDetails:GC日志打印详细信息,你可以通过-XX:+PrintGCDetails开启,或者-XX:-PrintGCDetails关闭 取值boolean
PRINTGCDETAILS="-XX:+PrintGCDetails"
#-XX:ParallelGCThreads: CMS/G1通用线程数设置
PARALLELGCTHREADS="-XX:ParallelGCThreads=10"
#-XX:+HeapDumpOnOutOfMemoryError:当JVM发生OOM时,自动生成DUMP文件,
HEAPDUMPONOUTOFMEMORYERROR="-XX:+HeapDumpOnOutOfMemoryError"
#-XX:HeapDumpPath:当JVM发生OOM时,自动生成DUMP文件的保存路径,缺省情况未指定目录时,JVM会创建一个名称为java_pidPID.hprof的堆dump文件在JVM的工作目录下
HeapDumpPath="-XX:HeapDumpPath=$JAR_PATH/$LOG_FILE/gc/dump/$APP_NAME.hprof"
#-Dfile.encoding: 文件编码
FILE_ENCODING="-Dfile.encoding=utf-8"
#拼接参数
JAVA_OPTS="$XMS $XMX $METASPACE_SIZE $MAX_METASPACE_SIZE $PRINTGCDATESTAMPS $HEAPDUMPONOUTOFMEMORYERROR $HeapDumpPath $FILE_ENCODING -Xloggc:$LOG_FILE/gc/gclog.log"
# 根据实际情况来修改以上配置信息 ##################################
# 检查程序是否处于运行状态
is_exist() {
# 查询出应用服务的进程id,grep -v 是反向查询的意思,查找除了grep操作的run.jar的进程之外的所有进程
pid=`ps -ef|grep $JAR_NAME|grep -v grep|awk '{print $2}' `
# [ ]表示条件测试。注意这里的空格很重要。要注意在'['后面和']'前面都必须要有空格
# [ -z STRING ] 如果STRING的长度为零则返回为真,即空是真
# 如果不存在返回0,存在返回1
if [ -z "${pid}" ]; then
return 0
else
return 1
fi
}
# ######### Shell脚本中$0、$?、$!、$$、$*、$#、$@等的说明 #########
# $$ Shell本身的PID(ProcessID,即脚本运行的当前 进程ID号)
# $! Shell最后运行的后台Process的PID(后台运行的最后一个进程的 进程ID号)
# $? 最后运行的命令的结束代码(返回值)即执行上一个指令的返回值 (显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误)
# $- 显示shell使用的当前选项,与set命令功能相同
# $* 所有参数列表。如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数,此选项参数可超过9个。
# $@ 所有参数列表。如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。
# $# 添加到Shell的参数个数
# $0 Shell本身的文件名
# $1~$n 添加到Shell的各参数值。$1是第1参数、$2是第2参数…。
# 服务启动方法
start() {
is_exist
if [ $? -eq "1" ]; then
echo "$APP_NAME 已经在运行pid是 ${pid}"
else
# jar服务启动脚本
nohup java $JAVA_OPTS -jar $JAR_PATH/$JAR_NAME >$JAR_PATH/$LOG_FILE/$APP_NAME/run.log 2>&1 &
echo $! > $JAR_PID
echo "启动 $APP_NAME 成功 pid是 $! "
sleep 15
# 睡眠一会等启动完成后输出启动日志
cat $JAR_PATH/$LOG_FILE/$APP_NAME/run.log
fi
}
# 服务停止方法
stop() {
# is_exist
pidf=$(cat $JAR_PID)
# echo "$pidf"
echo "pid = $pidf begin kill $pidf"
kill $pidf
rm -rf $JAR_PID
sleep 2
# 判断服务进程是否存在
is_exist
if [ $? -eq "1" ]; then
echo "pid = $pid begin kill -9 $pid"
kill -9 $pid
sleep 2
echo "$APP_NAME 已停止!"
else
echo "$APP_NAME 没有运行!"
fi
}
# 服务运行状态查看方法
status() {
is_exist
if [ $? -eq "1" ]; then
echo "$APP_NAME 正在运行,pid 是 ${pid}"
else
echo "$APP_NAME 没有运行!"
fi
}
# 重启服务方法
restart() {
# 调用服务停止命令
stop
# 调用服务启动命令
start
}
# 帮助说明,用于提示输入参数信息
usage() {
echo "Usage: sh $APP_NAME.sh [ start | stop | restart | status ]"
exit 1
}
###################################
# 读取脚本的第一个参数($1),进行判断
# 参数取值范围:{ start | stop | restart | status }
# 如参数不在指定范围之内,则打印帮助信息
###################################
#根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
'start')
start
;;
'stop')
stop
;;
'restart')
restart
;;
'status')
status
;;
*)
usage
;;
esac
exit 0
windows下的脚本
在windows系统下,如果报错“不是内部运行命令等”可能是因为编码问题引起的,cmd默认编码是gbk。可以尝试转换脚本编码或设置cmd活动页编码。或者检查换行符要为CRLF
@echo off
@rem 设置活动页编码为utf8
chcp 65001
@rem 设置jdk路径,一定要有JAVA_HOME环境变量
if not exist "%JAVA_HOME%\bin\java.exe" echo Please set the JAVA_HOME variable in your environment, We need java(x64)! jdk8 or later is better! & EXIT /B 1
set "JAVA=%JAVA_HOME%\bin\java.exe"
@rem 获取当前脚本路径
set BASE_DIR=%~dp0
@rem 截取到上级路径。ps:注意这里的路径根据自己的目录情况更改
set BASE_DIR=%BASE_DIR:~0,-13%
echo base_dir %BASE_DIR%
@rem 通常就配置这三个参数----------------
@rem JAVA应用程序的名称
set APP_NAME=app_name
@rem JAVA应用程序端口号
set SERVER_PORT=8300
@rem jar包名称
set JAR_NAME=app_name.jar
@rem java虚拟机启动参数
set LOG_FILE=logs
@rem -Xms:初始Heap(堆)大小,使用的最小内存,cpu性能高时此值应设的大一些
set "XMS=-Xms200m"
@rem -Xmx: java heap(堆)最大值,使用的最大内存
set "XMX=-Xmx512m"
@rem -XX:MetaspaceSize:元空间Metaspace扩容时触发FullGC(垃圾回收)的初始化阈值
set "METASPACE_SIZE=-XX:MetaspaceSize=512m"
@rem -XX:MaxMetaspaceSize: 元空间Metaspace扩容时触发FullGC(垃圾回收)的最大阈值;建议MetaspaceSize和MaxMetaspaceSize设置一样大
set "MAX_METASPACE_SIZE=-XX:MaxMetaspaceSize=512m"
@rem -XX:+PrintGCDateStamps: GC日志打印时间戳信息,你可以通过-XX:+PrintGCDateStamps开启,或者-XX:-PrintGCDateStamps关闭 取值boolean
set "PRINTGCDATESTAMPS=-XX:+PrintGCDateStamps"
@rem -XX:+PrintGCDetails:GC日志打印详细信息,你可以通过-XX:+PrintGCDetails开启,或者-XX:-PrintGCDetails关闭 取值boolean
set "PRINTGCDETAILS=-XX:+PrintGCDetails"
@rem -XX:ParallelGCThreads: CMS/G1通用线程数设置
set "PARALLELGCTHREADS=-XX:ParallelGCThreads=10"
@rem -XX:+HeapDumpOnOutOfMemoryError:当JVM发生OOM时,自动生成DUMP文件,
set "HEAPDUMPONOUTOFMEMORYERROR=-XX:+HeapDumpOnOutOfMemoryError"
@rem -XX:HeapDumpPath:当JVM发生OOM时,自动生成DUMP文件的保存路径,缺省情况未指定目录时,JVM会创建一个名称为java_pidPID.hprof的堆dump文件在JVM的工作目录下
set "HeapDumpPath=-XX:HeapDumpPath=%BASE_DIR%\%LOG_FILE%\gc\dump\%APP_NAME%.hprof"
@rem 拼接JAVA_OPTS参数
set "JAVA_OPTS=%XMS% %XMX% %METASPACE_SIZE% %MAX_METASPACE_SIZE% %PRINTGCDATESTAMPS% %HEAPDUMPONOUTOFMEMORYERROR% %HeapDumpPath% %FILE_ENCODING% -Dfile.encoding=utf-8"
@rem 上面是基础参数配置根据自己的需求设置---------------
@rem 获取命令行参数
set command=%1
@rem 判断输入的命令
if "%command%"=="" goto end
if "%command%"=="-start" goto start_jar
if "%command%"=="-stop" goto stop_jar
if "%command%"=="-restart" goto stop_jar
if "%command%"=="-status" goto status_jar
:end
echo "run %APP_NAME%.cmd [ -start|-stop|-restart|-status]" & EXIT /B 1
:stop_jar
echo stop %APP_NAME%
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%SERVER_PORT%"') do (
echo kill the process %%m who use the port
taskkill /pid %%m -t -f
goto q
)
:q
if "%command%"=="-restart" goto start_jar
EXIT /B 1
:start_jar
::执行启动jar命令
echo start %APP_NAME%
::javaw是静默运行,不会出现控制台窗口,也不会输出任何信息,关闭黑窗口程序也不会结束
start javaw %JAVA_OPTS% -jar %BASE_DIR%\%JAR_NAME%> %BASE_DIR%\%LOG_FILE%\%APP_NAME%\run.log 2>&1 &
::利用ping命令等待15秒后输出日志
ping /n 15 127.0.0.1 >nul
::上面使用start命令实际上日志输出不会被重定向到run.log,用start命令是调起另一个批处理窗口,输出只会到黑窗口所以内容时空的,可以通过查看端口状态来确定程序是否启动成功。
::去掉start日志就会输出到run.log,但是如果是在另一批处理脚本中调用此脚本(比如使用Jenkins),执行会停在javaw,不会往下执行,直到java程序结束,所有这里加一个start命令就会往下执行。
::如果是在cmd直接执行此脚本,则不用加start命令
type %BASE_DIR%\%LOG_FILE%\%APP_NAME%\run.log
:status_jar
for /f "tokens=1-5" %%i in ('netstat -ano^|findstr ":%SERVER_PORT%"') do (
if "%%m" NEQ "" (
if "%%m" NEQ "prefix" (
echo %APP_NAME% is run pid %%m
goto qq
)
)
)
echo %APP_NAME% is not run
:qq
exit