Linu部署服务启停脚本

Linux项目部署启停

WEB应用(WAR包)部署

  实际开发中,难免遇见新业务项目构建、项目重构(重新优化整个项目的架构,相当于重写),也可能是项目拆分多个模块,也可能部分拆分,但项目的模块化分离,就存在新建项目,新开服务端的可能,在Linux部署中,我们通常遇见需要搭建一个新的服务:

  WEB应用(war包):

  1. 在Linux服务目录中,安装适配的Tomcat应用。
  2. 修改Tomcat相关配置,如下:
    • Tomcat应用本身所占用的端口更新,为什么改?因为服务中可能存在多个部署应用,就可能存在多个Tomcat服务,多服务应用端口相同会冲突(如果你没有此需求,可不用改)
      • 修改tomcat安装目录下conf/server.xml,打开文件,修改文件中<Server>标签的属性port值,约22行  
      • <Server port="8005" shutdown="SHUTDOWN">
    • 本次部署WEB应用,所使用的端口更新,为什么改?因为Tomcat部署加载的服务端口是由Tomcat应用指定配置的,默认此服务启动后访问的端口是8080(如果你不担心冲突或被恶意使用,可不用改)
      • 修改tomcat安装目录下conf/server.xml,打开文件,修改文件中<Server>标签中<Service>标签中的<Connector>标签的属性port值,,约71行
      • <Connector port="8080" protocol="HTTP/1.1"
    • 本次部署WEB应用,可支持的远程跟踪端口,为什么改?因为应用有后端服务代码,在日志信息不全面的情况下,可暂时弃用远程Debug方式排查业务问题(如果你的日志信息非常全面,不需要远程查问题,可不用改)  
      • 方式一:Tomcat本身就考虑到这一层,相关配置也是有的,可以使用默认的,只是启动服务的使用要添加参数。Tomcat启动(startup.sh/startup.bat)实际调用的是(catalina.sh/catalina.bat),打开catalina.sh/catalina.bat会看到如下(以catalina.sh为例):也就是启动的时候,添加一个参数“jpda”,如:./startup.sh   jpda 执行startup.sh jpda命令,这样设置的参数就会被catalina.sh脚本使用,端口嘛,可自行更改。此介绍作为,参考,我一般就是自定义。
      • 复制代码
        ........ 脑补省略一万个字 ........ 
        
        if [ "$1" = "jpda" ] ; then
          if [ -z "$JPDA_TRANSPORT" ]; then
            JPDA_TRANSPORT="dt_socket"
          fi
          if [ -z "$JPDA_ADDRESS" ]; then
            JPDA_ADDRESS="localhost:8000"
          fi
          if [ -z "$JPDA_SUSPEND" ]; then
            JPDA_SUSPEND="n"
          fi
          if [ -z "$JPDA_OPTS" ]; then
            JPDA_OPTS="-agentlib:jdwp=transport=$JPDA_TRANSPORT,address=$JPDA_ADDRESS,server=y,suspend=$JPDA_SUSPEND"
          fi
          CATALINA_OPTS="$JPDA_OPTS $CATALINA_OPTS"
          shift
        fi
        
        ........ 脑补省略一万个字 ........ 
        复制代码
      • 方式二:如果您希望在不直接传递jpda参数给startup.sh的情况下,仍然能自动应用特定的JVM参数(包括远程调试端口配置),可以考虑直接修改Tomcat的启动脚本catalina.sh,将这些配置永久加入到默认的启动选项中。找到Tomcat安装目录下的bin/catalina.sh文件(对于Windows则是catalina.bat),在catalina.sh文件的某个适当位置,添加您想要的JVM参数,比如设置远程调试端口、调整堆内存大小和选择垃圾回收器。在Tomcat中,CATALINA_OPTS、JPDA_ADDRESS、JPDA_TRANSPORT、JPDA_SUSPEND等环境变量名称是约定俗成的,并且被Tomcat脚本直接引用以配置JVM和调试相关设置。
      • 复制代码
        ........ 脑补省略一万个字 ........ 
        
           # 设置远程调试端口(如果默认需要开启)
           JPDA_ADDRESS="localhost:8000"
           JPDA_OPTS="-agentlib:jdwp=transport=dt_socket,address=$JPDA_ADDRESS,server=y,suspend=n"
           CATALINA_OPTS="$CATALINA_OPTS $JPDA_OPTS"
        
           # 调整堆内存大小
           CATALINA_OPTS="$CATALINA_OPTS -Xms512m -Xmx2g"
        
           # 配置垃圾回收机制
           CATALINA_OPTS="$CATALINA_OPTS -XX:+UseG1GC"
        
        ........ 脑补省略一万个字 ........ 
        复制代码
  3. Tomcat目录下bin包中,给启停服务脚本授权允许执行,若有其他授权可自行根据需求添加
  4. 将war包放入到Tomcat安装目录下(webapps/...)部署,启动服务

  Tomcat的暂时先不写了,后面有时间再说,此处临时记录。上面的基本够用了

JAR应用(JAR包)部署

  Java应用(jar包):

  常见jar包为boot应用,无需手动配置Tomcat,当然,如果你没有使用Boot的Tomcat,可以手动配置安装Tomcat(略)

  1.LInux应用目录下,新建服务包

  2.新建文件后缀为 .sh 下,命名个人习惯(如restart.sh、stop.shrestart.sh - 用于重启服务,stop.sh - 用于停止服务

  3.编辑文件,示例代码如下,可根据个人情况修改:

 服务重新启动脚本(restart.sh)

  注意说明:

  JAVA远程调试jdwp配置JDK8到JDK>8(JDK8以上)

复制代码
 1 在JDK8,使用远程调试这样:
 2 -agentlib:jdwp=transport=dt_socket,address=8787,server=y,suspend=n
 3 在JDK>8,使用远程调试这样:
 4 -agentlib:jdwp=transport=dt_socket,address=*:8787,server=y,suspend=n
 5 
 6 参数意义如下:
 7 transport=dt_socket:使用socket通信。
 8 server=y:作为调试服务器等待客户端连接。
 9 suspend=n:应用启动后立即继续执行,而不是暂停等待调试器连接。
10 address=*:5005:监听所有IP地址上的5005端口,允许远程调试。
11 
12 堆内存设置
13 -Xms16g:设置初始堆内存为16GB,为系统内存的一半,确保系统有足够的内存用于非堆内存和操作系统本身。
14 -Xmx16g:设置最大堆内存也为16GB,有助于减少堆内存的动态调整。
复制代码

 

  以下是重启--关闭,关闭--重启服务脚本,独立start、stop的,自行根据下面的改编吧

 

复制代码
  1 #!/bin/bash
  2 
  3 # -----------------------------------------请相信科学的力量!------------------------------------------------------
  4 # |卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍 |
  5 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
  6 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
  7 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
  8 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
  9 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 10 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 11 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 12 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 13 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 14 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 15 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 16 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 17 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 18 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 19 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 20 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 21 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 22 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 23 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 24 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 25 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 26 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 27 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 28 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 29 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 30 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 31 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 32 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 33 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 34 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 35 # |卍!!!!!!!!!!!!!                 卍别动卍                !!!!!!!!!!!!!!!!!!!!卍|
 36 # |卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍卍 |
 37 # ------------------------------------------可以让服务很流程!------------------------------------------------------
 38 
 39 
 40 # 不谢!
 41 
 42 
 43 
 44 # 定义服务名称、日志文件路径、jar文件路径和JDK路径、服务JVM相关参数(启动Boot远程端口服务,端口设置为:9099)、其他命令行
 45 #######把他理解为变量定义,名字这些都是自己定,无特定限制,数据值改为你自己的即可,定义好的变量通过 ${名字} 来使用 #######
 46 SERVICE_NAME="work-order-mgr-0.0.1-SNAPSHOT.jar"
 47 LOG_FILE="/opt/Tomcat/springboot/workordermgr/logs/log-info.log"
 48 JAR_FILE="/opt/Tomcat/springboot/workordermgr/work-order-mgr-0.0.1-SNAPSHOT.jar"
 49 JDK_HOME="/opt/jdk1.8.0_112"
 50 JAVA_OPTIONS="-Xms128m -Xmx256m -agentlib:jdwp=transport=dt_socket,address=16155,server=y,suspend=n" # 示例JVM参数 -Xms16g  -Xmx16g 可选配置,设置堆内存的
 51 LOG_VIEWER="tail -f" # 用于查看日志的命令
 52 # 定义进程pid 变量
 53 pid=""
 54 
 55 # 注意,注意,注意,重要的事情说三遍,上面的定义,为了便于后面多地方引用。但引用取值,也是有区别的。
 56 # 取值方式:${名字} Shell中的变量展开容易受到分词和通配符扩展的影响,因此通常建议总是用双引号包裹变量,除非有特殊需求需要分词。
 57 # 特殊场景1:需要变量值被分割成多个参数。如JVM参数 JAVA_OPTIONS 取值不能使用引号。
 58 # 特殊场景2:值包含通配符。如:file = *.log  取值 echo ${file}
 59 # 是否要让变量值中的空格分割成多个参数? → 是 → 不加引号 ❌
 60 #                                      ↓
 61 #                                      否 → 是否要触发通配符扩展? → 是 → 不加引号 ❌
 62 #                                      ↓
 63 #                                      否 → 必须加引号 ✅
 64 
 65 # 定义一个:启动服务的函数(只有被调用才执行)
 66 start_service() {
 67     echo "$(date): 正在启动 \"${SERVICE_NAME}\" 服务..."
 68     nohup "${JDK_HOME}"/bin/java ${JAVA_OPTIONS} -jar "${JAR_FILE}" --spring.profiles.active=uat --server.port=16166 >> "${LOG_FILE}" 2>&1 &
 69     sleep 5
 70     echo "$(date): ${SERVICE_NAME} 服务启动成功"
 71 }
 72 
 73 
 74 
 75 # 定义查询服务进程PID的方法 (只有被调用才执行)
 76 query(){
 77     # 查询并赋值 (这里指定了管道查询,获取服务进程的)
 78     pid=$(pgrep -f "${JAR_FILE}")
 79 }
 80 
 81 # 停止服务的函数(只有被调用才执行)
 82 stop_service() {
 83     echo "$(date): 正在停止 \"${SERVICE_NAME}\" 服务..."
 84     # 执行一次查询PID,实现赋值
 85     query
 86     #检查PID是否为空
 87     if [ -n "${pid}" ]; then
 88         # 停止服务,并提示服务正在停止中....
 89         kill -9  "${pid}"
 90         echo "\"${JAR_FILE}\" (pid : \"${pid}\") exiting......"
 91         # 利用while循环特性(校验pid不为空,执行查询)
 92         while [ -n "${pid}" ]
 93             do
 94                 # 间隔5秒再次执行查询,确认是否停止
 95                 sleep 3
 96                 query
 97                 echo "Please wait a moment......$(date): 等待 \"${SERVICE_NAME}\" 服务停止..."
 98             done
 99         # 当程序走到这,说明上面查询已经是空了,可以输出停止完毕了
100         echo "$(date) : is OK , \"${SERVICE_NAME}\" exited.服务停止成功"
101     else
102         echo "HI , \"${JAR_FILE}\" already stopped."
103     fi
104 }
105 
106 # 检查服务是否正在运行的函数
107 is_service_running() {
108     query
109     if [ -n "${pid}" ]; then
110         echo "\"${JAR_FILE}\" 当前服务存在,服务正常运行中.... pid = \"${pid}\""
111         return 0  # 服务正常,返回0
112     else
113         echo "\"${JAR_FILE}\" 当前服务未运行,服务未启动.... "
114         return 1  # 服务未启动,返回1 服务正常
115     fi
116 }
117 
118 # 根据服务状态执行相应操作(如果服务正在运行,则停止服务;如果服务未运行,则启动服务)
119 if is_service_running; then
120     echo "stop .........准备停止啦"
121     echo "stop .........准备停止啦"
122     echo "stop .........准备停止啦"
123     stop_service
124 else
125     echo "start........准备启动啦..... "
126     echo "start........ "
127     echo "start........ "
128     start_service
129 fi
130 
131 # 检查日志文件并尝试打开
132 if [ -f "${LOG_FILE}" ]; then
133     echo "服务已启动,正在打开日志文件 \"${LOG_FILE}\" 查看最新日志..."
134     # 如果您想要在后台运行 tail -f 并让脚本继续执行其他任务,取消下面的注释
135     # ${LOG_VIEWER} "\"${LOG_FILE}\"" &
136     # 如果您想要脚本停留在 tail -f 上,则保持当前状态
137     ${LOG_VIEWER}  "${LOG_FILE}"
138 else
139     echo "日志文件 \"${LOG_FILE}\" 不存在,请确保日志文件路径正确且服务已开始写入日志。"
140 fi
复制代码

 

posted @   净重21克  阅读(420)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示