博客
关于我
Linux shell脚本启动springboot项目
阅读量:372 次
发布时间:2019-03-04

本文共 3973 字,大约阅读时间需要 13 分钟。

前提:jar与lib依赖分离,且处于同级目录,如果不是,可以自己修改配置文件(nohup java -jar xxx.jar)

运行实例:

执行命令:# sh start.sh [start|stop|restart|status|debug] [version] || [ADD_PORT]# ADD_PORT为debug调试模式时用,默认监听端口为51135启动程序:        sh start.sh start test-1.x.xdebug启动:      sh start.sh debug test-1.x.x | sh start.sh debug test-1.x.x 51235重启程序:        sh start.sh restart test-1.x.x查看运行状态:     sh start.sh status test-1.x.x关闭程序:        sh start.sh stop test-1.x.x获取使用教程:     sh start.sh -h[root@demo demos]# lsstart.sh lib test-1.0.jar[root@demo demos]# sh start.sh start test-1.0Service test-1.0.jar is starting!pid=17827.................Start success.................[root@demo demos]# sh start.sh status test-1.0Service test-1.0.jar is running. It's pid=17827[root@demo demos]# sh start.sh restart test-1.0.................Restarting.................Service test-1.0.jar is starting!pid=19134.................Start success..................................Restart success.................[root@demo demos]# sh start.sh stop test-1.0Service stop success!pid:19134 which has been killed forcibly!

start.sh脚本

#!/bin/sh# 定义变量JAR_NAME="$2.jar"# 监听端口ADD_PORT="$3"# help获取使用方法help() {     echo ""  echo "please use command: sh start.sh [start|stop|restart|status|debug] [version] || [ADD_PORT]"  echo "For example: sh start.sh start 1.0.1"  echo "debug For example: sh start.sh debug demo1.0 | sh start.sh debug demo1.0 6156"  echo ""  exit 1}# 该方法会重新启动程序debug() {     # 查看pid,先杀掉,再运行jar  pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')  # 设置默认监听端口  if [ -z $ADD_PORT ]; then    ADD_PORT="51135"    echo "......default Listen on port for DEBUG:${ADD_PORT}"  fi  # -z 表示为空  if [ ! -z $pid ]; then    kill -9 $pid    echo ""    echo "......kill -9 ${pid}....."    nohup java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=$ADD_PORT -Dloader.path=lib/ -jar $JAR_NAME >debugOut.log 2>&1 &    pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')    echo ""    echo "debug Service ${JAR_NAME} is starting!newPid:${pid}, Listen on port:${ADD_PORT}"    echo "......debug restart: success......"    echo ""  else     nohup java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=$ADD_PORT -Dloader.path=lib/ -jar $JAR_NAME >debugOut.log 2>&1 &    pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')    echo ""    echo "debug Service ${JAR_NAME} is starting!pid:${pid}, address:${ADD_PORT}"    echo "......debug Start: success......"    echo ""  fi}# 启动方法start() {     # 重新获取一下pid  pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')  # -z 表示为空  if [ -z $pid ]; then    nohup java -Dloader.path=lib/ -jar $JAR_NAME >out.log 2>&1 &    pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')    echo ""    echo "Service ${JAR_NAME} is starting!pid:${pid}"    echo ".........Start success........"  else    echo ""    echo "Service ${JAR_NAME} is already running,it's pid:${pid}. If necessary."    echo "please use command:[sh start.sh stop [version] | sh start.sh restart [version]]."    echo ""  fi}# 停止方法stop() {     # 重新获取一下pid  pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')  # -z 表示为空  if [ -z $pid ]; then    echo ""    echo "Service ${JAR_NAME} is not running!"    echo ""  else    kill -9 $pid    echo ""    echo "Service stop success!pid:${pid}"    echo ""  fi}# 输出运行状态方法status() {     # 重新获取一下pid  pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')  # -z 表示为空  if [ -z $pid ]; then    echo ""    echo "Service ${JAR_NAME} is not running!"    echo ""  else    echo ""    echo "Service ${JAR_NAME} is running. It's pid=${pid}"    echo ""  fi}# 重启方法restart() {     echo ".................Restarting................."  pid=$(ps -ef | grep $JAR_NAME | grep -v grep | awk '{print $2}')  # -z 表示为空  if [ ! -z $pid ]; then    kill -9 $pid  fi  start  echo ""}# 根据输入参数执行对应方法case "$1" in"start")  start  ;;"stop")  stop  ;;"status")  status  ;;"restart")  restart  ;;"-h")  help  ;;"debug")  debug  ;;esac

转载地址:http://aakg.baihongyu.com/

你可能感兴趣的文章
Netty 调用,效率这么低还用啥?
查看>>
Netty+Protostuff实现单机压测秒级接收35万个对象实践经验分享
查看>>
Netty+SpringBoot+FastDFS+Html5实现聊天App详解(一)
查看>>
netty--helloword程序
查看>>
Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
查看>>
netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
查看>>
netty——Channl的常用方法、ChannelFuture、CloseFuture
查看>>
netty——Future和Promise的使用 线程间的通信
查看>>
netty——Handler和pipeline
查看>>
Vue输出HTML
查看>>
netty——黏包半包的解决方案、滑动窗口的概念
查看>>
Netty中Http客户端、服务端的编解码器
查看>>
Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
查看>>
Netty中实现多客户端连接与通信-以实现聊天室群聊功能为例(附代码下载)
查看>>
Netty中的组件是怎么交互的?
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
netty之 定长数据流处理数据粘包问题
查看>>
Netty事件注册机制深入解析
查看>>
netty代理
查看>>
Netty入门使用
查看>>