startJar.sh 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. APP_NAME=
  2. APP_DEBUG=
  3. APP_DUMPlOG=/mnt/fdkk_bim/logs/heapdump/heapdump.log
  4. date=`date`
  5. path=$(pwd)
  6. source /etc/profile
  7. usage() {
  8. echo "case: sh run.sh [start|stop|restart|status|checkServer]"
  9. echo "请类似这样执行 ./*.sh start prod or ./*sh restart prod"
  10. exit 1
  11. }
  12. checkEnv(){
  13. echo "prod config"
  14. if [ -z "${APP_NAME}" ] || [ -z "${APP_DEBUG}" ]; then #判断pid是否为空
  15. if [[ $1 = 'prod' ]]; then
  16. echo "prod config"
  17. APP_NAME=fdkk-bim-prod.jar
  18. APP_DEBUG=5527
  19. elif [[ $1 = 'uat' ]] ; then
  20. echo "uat config"
  21. APP_NAME=fdkk-bim-uat.jar
  22. APP_DEBUG=5522
  23. else
  24. echo "没有设置环境"
  25. fi
  26. # else
  27. # echo "已经设置-${APP_NAME}-${APP_DEBUG}"
  28. fi
  29. }
  30. # 判断当前服务是否已经启动的函数
  31. is_exist(){
  32. checkEnv $1
  33. pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' ` #根据ps 命令查询当前服务的进程号 赋值给pid"
  34. if [ -z "${pid}" ]; then #判断pid是否为空
  35. echo "pid 不存在"
  36. return 1
  37. else
  38. echo "pid 存在"
  39. return 0
  40. fi
  41. }
  42. start(){
  43. checkEnv $1
  44. is_exist
  45. if [ $? -eq "0" ]; then # [$? -eq "0"] 说明pid不等于空 说明服务正在运行中,将进程号打印出来
  46. echo "${APP_NAME} running. pid=${pid}"
  47. else
  48. nohup java -jar -Xmx4072M -Xms1024M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${APP_DUMPlOG} -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=${APP_DEBUG} ${path}/${APP_NAME} --spring.profiles.active=$1 > logs.log 2>error.log & # 说明pid为空 执行java -jar 命令启动服务
  49. # 执行java -jar 命令启动服务
  50. echo "${APP_NAME} started启动"
  51. fi
  52. }
  53. stop(){
  54. echo "执行 stop 方法"
  55. checkEnv $1
  56. is_exist
  57. if [ $? -eq "0" ]; then # [$? -eq "0"] 说明pid不等于空 说明服务正在运行中,将进程号杀死
  58. kill -15 $pid
  59. echo "${pid} stopped-停止"
  60. else
  61. echo "${APP_NAME} 没有运行"
  62. fi
  63. }
  64. status(){
  65. echo "执行 status 方法"
  66. checkEnv $1
  67. is_exist
  68. if [ $? -eq "0" ]; then
  69. echo "${APP_NAME} running-启动. Pid is ${pid}"
  70. else
  71. echo "${APP_NAME} 没有运行"
  72. fi
  73. }
  74. checkServer(){
  75. echo "执行 status 方法"
  76. checkEnv $1
  77. is_exist
  78. if [ $? -eq "0" ]; then
  79. echo "${APP_NAME} running-正在运行. Pid is ${pid}"
  80. echo `date +%Y-%m-%d` `date +%H:%M:%S` ${APP_NAME} "running-正在运行. Pid is ${pid}" >> check.log
  81. exit 0
  82. else
  83. echo "${APP_NAME} 没有运行,即将重启"
  84. echo `date +%Y-%m-%d` `date +%H:%M:%S` ${APP_NAME} "没有运行,即将重启" >> check.log
  85. restart $1
  86. fi
  87. }
  88. # 重启命令其实就是先执行关闭命令 再执行重启命令
  89. restart(){
  90. echo "执行 restart 方法"
  91. checkEnv $1
  92. is_exist
  93. if [ $? -eq "0" ]; then # [$? -eq "0"] 说明pid不等于空 说明服务正在运行中,将进程号杀死
  94. kill -9 $pid
  95. echo "${pid} stopped-停止"
  96. else
  97. echo "${APP_NAME} 没有运行"
  98. fi
  99. sleep 5
  100. is_exist
  101. if [ $? -eq "0" ]; then # [$? -eq "0"] 说明pid不等于空 说明服务正在运行中,将进程号打印出来
  102. echo "${APP_NAME} running. pid=${pid}"
  103. else
  104. nohup java -jar -Xmx4072M -Xms1024M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${APP_DUMPlOG} -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=${APP_DEBUG} ${path}/${APP_NAME} --spring.profiles.active=$1 > logs.log 2>error.log & # 说明pid为空 执行java -jar 命令启动服务
  105. echo "${APP_NAME} started启动"
  106. fi
  107. }
  108. # 这里的$1 取的是当前输入命令 的第二个参数 ./start.sh start
  109. case "$1" in
  110. "start")
  111. start $2
  112. ;;
  113. "stop")
  114. stop $2
  115. ;;
  116. "status")
  117. status $2
  118. ;;
  119. "restart")
  120. restart $2
  121. ;;
  122. "checkServer")
  123. checkServer $2
  124. ;;
  125. *)
  126. usage
  127. ;;
  128. esac