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/...)部署,启动服务

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以上)

在JDK8,使用远程调试这样:
-agentlib:jdwp=transport=dt_socket,address=8787,server=y,suspend=n
在JDK>8,使用远程调试这样:
-agentlib:jdwp=transport=dt_socket,address=*:8787,server=y,suspend=n

参数意义如下:
transport=dt_socket:使用socket通信。
server=y:作为调试服务器等待客户端连接。
suspend=n:应用启动后立即继续执行,而不是暂停等待调试器连接。
address=*:5005:监听所有IP地址上的5005端口,允许远程调试。

堆内存设置
-Xms16g:设置初始堆内存为16GB,为系统内存的一半,确保系统有足够的内存用于非堆内存和操作系统本身。
-Xmx16g:设置最大堆内存也为16GB,有助于减少堆内存的动态调整。

  以下是重启服务脚本,stop的,自行根据下面的改编吧

#!/bin/bash

# 定义服务名称、日志文件路径、jar文件路径和JDK路径、服务JVM相关参数(启动Boot远程端口服务,端口设置为:9099)、其他命令行
#######把他理解为变量定义,名字这些都是自己定,无特定限制,数据值改为你自己的即可,定义好的变量通过 ${名字} 来使用 #######
SERVICE_NAME="AutoTask"
LOG_FILE="/opt/boot/AutoTask/autoTask.log"
JAR_FILE="/opt/boot/AutoTask/autoTask-0.0.1-SNAPSHOT.jar"
JDK_HOME="/home/java/jdk1.8.0_112/"
JAVA_OPTIONS="-Xms16g  -Xmx16g  -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=9099" # 示例JVM参数 -Xms16g  -Xmx16g 可选配置,设置堆内存的
LOG_VIEWER="tail -f" # 用于查看日志的命令

# 定义一个:启动服务的函数(只有被调用才执行)
start_service() { 
	echo "$(date): 正在启动 $SERVICE_NAME 服务..." 
	nohup ${JDK_HOME}/bin/java "$JAVA_OPTIONS" -jar "$JAR_FILE" --spring.profiles.active=test --server.port=5090 >> "$LOG_FILE" 2>&1 & 
	echo "$(date): $SERVICE_NAME 服务启动成功" 
}

# 定义进程pid 变量
pid=""

# 定义查询服务进程PID的方法 (只有被调用才执行) 
query(){
	# 查询并赋值 (这里指定了管道查询,获取服务进程的)
	pid=`ps uxf | grep ${JAR_FILE} | grep -v grep | awk '{print $2}'`
}

# 停止服务的函数(只有被调用才执行)
stop_service() {
	echo "$(date): 正在停止 $SERVICE_NAME 服务..."
	# 执行一次查询PID,实现赋值
	query
	#检查PID是否为空
	if [ x"${pid}" != x"" ]; then
		# 停止服务,并提示服务正在停止中.... 
		kill -9 ${pid}
		echo "${JAR_FILE} (pid : ${pid}) exiting......"
		# 利用while循环特性(校验pid不为空,执行查询)
		while [ x"${pid}" != x"" ]
			do
				# 间隔5秒再次执行查询,确认是否停止
				sleep 3 
				query
				echo "$Please wait a moment......$(date): 等待 $SERVICE_NAME 服务停止..." 
			done
		# 当程序走到这,说明上面查询已经是空了,可以输出停止完毕了
		echo "$(date) : is OK , $SERVICE_NAME exited.服务停止成功"
	else
		echo "HI , ${JAR_FILE} already stopped."
	fi
} 

# 检查服务是否正在运行的函数
is_service_running() {
	pgrep -f "$JAR_FILE" 56 return $? # 0表示运行,非0表示未运行
}

# 根据服务状态执行相应操作(执行如果服务没有停止,那么执行stop_service停止服务)
if is_service_running; then 
	stop_service
fi 

#执行启动服务
start_service

# 检查日志文件并尝试打开
if [ -f "$LOG_FILE" ]; then 
	echo "服务已启动,正在打开日志文件 $LOG_FILE 查看最新日志..."
	# 如果您想要在后台运行 tail -f 并让脚本继续执行其他任务,取消下面的注释
	# $LOG_VIEWER "$LOG_FILE" & 
	# 如果您想要脚本停留在 tail -f 上,则保持当前状态
	$LOG_VIEWER "$LOG_FILE"
else
	echo "日志文件 $LOG_FILE 不存在,请确保日志文件路径正确且服务已开始写入日志。" 
fi
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux下设置Redis开机自启动,需要进行以下步骤: 1. 编写Redis服务脚本Linux系统中,服务的启动和停止是要通过服务脚本来完成的,因此我们需要编写一个Redis服务脚本,以实现Redis开机自启动。 在终端中输入以下命令,创建Redis服务脚本: ``` sudo nano /etc/systemd/system/redis.service ``` 在打开的文件中,输入以下内容: ``` [Unit] Description=Redis In-Memory Data Store After=network.target [Service] User=redis Group=redis ExecStart=/usr/local/bin/redis-server /etc/redis/redis.conf ExecStop=/usr/local/bin/redis-cli shutdown Restart=always [Install] WantedBy=multi-user.target ``` 上述代码中,需要注意以下几点: - User、Group:Redis服务运行的用户和用户组,需要根据实际情况进行修改。 - ExecStart:Redis服务启动程序的路径和启动参数,需要根据实际情况进行修改。 - ExecStop:Redis服务停止命令。 - Restart:服务启动失败或异常停止时,自动重启服务。 - WantedBy:服务的启动级别。 2. 将Redis服务脚本添加到系统服务中 在终端中输入以下命令,将Redis服务脚本添加到系统服务中: ``` sudo systemctl daemon-reload sudo systemctl enable redis.service ``` 3. 重启系统,验证Redis服务是否已经自启动 在终端中输入以下命令,重启系统: ``` sudo reboot ``` 重启完成后,可以使用以下命令来检查Redis服务是否已经自启动: ``` sudo systemctl status redis.service ``` 如果能看到Redis服务已经处于运行状态,则说明Redis已经成功地自启动了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值