首页 > 系统相关 >shell批量启动关闭jar

shell批量启动关闭jar

时间:2023-01-02 20:33:53浏览次数:42  
标签:shell 批量 stop jar MODULE sh PATH local

参考:https://blog.csdn.net/qq_35385687/article/details/123518062

#! /bin/sh
#1,启动所有jar包:sh all.sh start all 或者./sh start all
#2,停止所有jar包:sh all.sh stop all 或者./sh stop all
#3,重启所有jar包:sh all.sh restart all 或者./sh restart all
#4,重启或者停止单个jar包,只需要将all替换为相应的模块代码就行
# 端口号
PORTS=(8082 8090 8092)
# 系统模块
MODULES=(boot gateway performance)
# 系统模块名称
MODULE_NAMES=(基础模块 网关 绩效)
# jar包数组
JARS=(boot.jar gateway.jar performance.jar)
# jar包路径
#JAR_PATH='/usr/local/beta'
JAR_PATH='./jars'
# 日志路径
#LOG_PATH='/usr/local/beta'
LOG_PATH='./logs'
mkdir $LOG_PATH
start() {
  local MODULE=
  local MODULE_NAME=
  local JAR_NAME=
  local command="$1"
  local commandOk=0
  local count=0
  local okCount=0
  local port=0
  for((i=0;i<${#MODULES[@]};i++))
  do
    MODULE=${MODULES[$i]}
    MODULE_NAME=${MODULE_NAMES[$i]}
    JAR_NAME=${JARS[$i]}
    PORT=${PORTS[$i]}
    if [ "$command" == "all" ] || [ "$command" == "$MODULE" ];then
      commandOk=1
      count=0
      PID=`ps -ef |grep $(echo $JAR_NAME | awk -F/ '{print $NF}') | grep -v grep | awk '{print $2}'`
      if [ -n "$PID" ];then
        echo "$MODULE---$MODULE_NAME:已经运行,PID=$PID"
      else
        #   exec nohup java -jar $JAR_PATH/$JAR_NAME >> $LOG_PATH/$MODULE.log &
        echo "nohup java -jar $JAR_PATH/$JAR_NAME >> $LOG_PATH/$MODULE.log &"
        nohup java -jar $JAR_PATH/$JAR_NAME >> $LOG_PATH/$MODULE.log &
        PID=`netstat -apn | grep $PORT | awk '{print $7}' | cut -d/ -f 1`
        while [ -z "$PID" ]
        do
          if (($count == 30));then
            echo "$MODULE---$MODULE_NAME:$(expr $count \* 10)秒内未启动,请检查!"
            break
          fi
          count=$(($count+1))
          echo "$MODULE_NAME启动中.................."
          sleep 10s
          PID=`netstat -apn | grep $PORT | awk '{print $7}' | cut -d/ -f 1`
        done
        okCount=$(($okCount+1))
        echo "$MODULE---$MODULE_NAME:已经启动成功,PID=$PID"
      fi
    fi
  done
  if(($commandOk == 0));then
    echo "第二个参数请输入:all|boot|gateway|performance"
  else
    echo "............本次共启动:$okCount个服务..........."
  fi
}

stop() {
  local MODULE=
  local MODULE_NAME=
  local JAR_NAME=
  local command="$1"
  local commandOk=0
  local okCount=0
  for((i=0;i<${#MODULES[@]};i++))
  do
    MODULE=${MODULES[$i]}
    MODULE_NAME=${MODULE_NAMES[$i]}
    JAR_NAME=${JARS[$i]}
    if [ "$command" = "all" ] || [ "$command" = "$MODULE" ];then
      commandOk=1
      PID=`ps -ef |grep $(echo $JAR_NAME | awk -F/ '{print $NF}') | grep -v grep | awk '{print $2}'`
      if [ -n "$PID" ];then
        echo "$MODULE---$MODULE_NAME:准备结束,PID=$PID"
        kill -9 $PID
        PID=`ps -ef |grep $(echo $JAR_NAME | awk -F/ '{print $NF}') | grep -v grep | awk '{print $2}'`
        while [ -n "$PID" ]
        do
          sleep 3s
          PID=`ps -ef |grep $(echo $JAR_NAME | awk -F/ '{print $NF}') | grep -v grep | awk '{print $2}'`
        done
        echo "$MODULE---$MODULE_NAME:成功结束"
        okCount=$(($okCount+1))
      else
        echo "$MODULE---$MODULE_NAME:未运行"
      fi
    fi
  done
  if (($commandOk == 0));then
    echo "第二个参数请输入:all|boot|gateway|performance"
  else
    echo "............本次共停止:$okCount个服务............"
  fi
}
case "$1" in start) start "$2" ;; stop) stop "$2" ;; restart) stop "$2" sleep 3s start "$2" ;; *) echo "第一个参数请输入:start|stop|restart" exit 1 ;; esac

1,启动所有jar包:sh all.sh start all 或者./sh start all
2,停止所有jar包:sh all.sh stop all 或者./sh stop all

3,重启所有jar包:sh all.sh restart all 或者./sh restart all

4,重启或者停止单个jar包,只需要将all替换为相应的模块代码就行,例如sh all.sh stop sms
原文链接:https://blog.csdn.net/zimojiang/article/details/125542890

标签:shell,批量,stop,jar,MODULE,sh,PATH,local
From: https://www.cnblogs.com/yzjBlog123123/p/17020463.html

相关文章

  • MSF反弹shell、与CS_哥斯拉联动
    0x00-引言0x01-思路公网vps启动frp,本地kali启动frp客户端,frp客户端配置将kali端口映射到vps某个端口,msf生成木马接收shell0x02-msf反弹shell01-frp配置frp客户端......
  • 批量分发密钥脚本
    #!/bin/bash#目标主机列表IP="192.168.10.51192.168.10.52192.168.10.53192.168.10.54192.168.10.55192.168.10.56192.168.10.57192.168.10.58192.168.10.59192.168.10.601......
  • PXE高效批量网络装机
    一、PXE基础知识1、PXE使用条件:客户机与PXE服务器必须在同一交换机上,服务器可以分配ip地址给客户机,客户机内存必须大于2G优点规模化:同时装配多台服务器自动化:安装系统,配......
  • ogg格式音乐批量转换为mp3
    今天我发现在qq音乐客户端下载的音乐是ogg格式的,拿到蓝牙音响上面放的时候不识别。于是我需要将ogg音乐文件批量转换为mp3格式。有些网站可以在线转换,但是有个数限制,且上......
  • 一键批量导出微信通讯录
    6-3​微信是我们常用的即时通信APP,除了日常生活使用外,还有一个重要的使用场景,就是日常工作也是用微信。​这样就有了个问题,几乎所有的客服、服务商、供应商等,都是用微信沟通......
  • 用jar命令打包java中class文件
    用jar命令打包java中class文件:1、不指定MANIFEST.MFjar-cvfMyTreeSet.jarcom/wlk/fuxi0101/*.class2、指定MANIFEST.MF2.1、MANIFEST.MF文件内容如下:Manifest-Version:......
  • 史上最全的 pom.xml 文件详解(扩展:Maven的三种项目打包方式——pom,jar,war的区别)
    史上最全的pom.xml文件详解https://blog.csdn.net/jk418756/article/details/87917776?spm=1001.2101.3001.6650.12&utm_medium=distribute.pc_relevant.none-task-blog......
  • MAUI Blazor学习1-移动客户端Shell布局
    MAUI正式版发布半年了,Net7也发布了,再次学习MAUI跨平台开发。UI类型选择Blazor,因为Html的生态圈比Xaml好太多了,能用Html解决的,就不要用Xaml。Blazor既可以开发网页客户端,又......
  • Jenkins 流水线发布JAR包
    1、流水线内容:文件以Jenkinsfile命名pipeline{agentanystages{stage('拉取代码'){steps{checkout([$class:'Gi......
  • 批量抓取导出公众号留言数据,包含留言昵称,留言内容,点赞数,回复和留言时间等,顺便分析留言
    很快就到了2023年,按照惯例抓取整理我2022年发布的公众号文章,同步到我的博客了https://sushengbuhuo.github.io/blog博客上还收录了些其他公众号的历史文章,翻起来方便多了,......