linux部署jar包脚本和注册开机启动

简介: 之前开发了windows部署jar包为服务的工具在实际生产环境中使用非常简单方便,公司部分项目是部署在linux系统中的,所以决定整合一个通用的jar包部署脚本,并注册为开机启动服务,为开发实施的同事提供方便,以下操作实际系统环境为centos8

前言

之前开发了windows部署jar包为服务的工具在实际生产环境中使用非常简单方便,公司部分项目是部署在linux系统中的,所以决定整合一个通用的jar包部署脚本,并注册为开机启动服务,为开发实施的同事提供方便,以下操作实际系统环境为centos8

通过脚本启动

  • 安装jdk,可以不配置环境变量

  • 脚本和部署jar包放置在同一个文件夹

  • 修改脚本deploy.sh中的JAVA_HOME指向jdk目录,修改APP_NAME为jar包的名字

#!/bin/bash
export JAVA_HOME=/usr/soft/jdk/jdk1.8.0_241
export JRE_HOME=/$JAVA_HOME/jre
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin

#这里可替换为你自己的执行程序,其他代码无需更改

APP_NAME= manage.jar
#使用说明,用来提示输入参数
usage() {
    echo "Usage: sh robotcenter.sh [start|stop|restart|status]"
    exit 1
}

#检查程序是否在运行
is_exist(){
  pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}'`
  #如果不存在返回1,存在返回0     
  if [ -z "${pid}" ]; then
   return 1
  else
    return 0
  fi
}

#启动方法
start(){
  is_exist
  if [ $? -eq 0 ]; then
    echo "${APP_NAME} is already running. pid=${pid}"
  else
      nohup java -jar ${APP_NAME} > app.log 2>&1 &
  fi
}

#停止方法
stop(){
  is_exist
  if [ $? -eq "0" ]; then
    kill -9 $pid
  else
    echo "${APP_NAME} is not running"
  fi  
}

#输出运行状态
status(){
  is_exist
  if [ $? -eq "0" ]; then
    echo "${APP_NAME} is running. Pid is ${pid}"
  else
    echo "${APP_NAME} is NOT running."
  fi
}

#重启
restart(){
  stop
  sleep 5
  start
}

#根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
  "start")
    start
    ;;
  "stop")
    stop
    ;;
  "status")
    status
    ;;
  "restart")
    restart
    ;;
  *)
    usage
    ;;
esac
  • 命令行进入对应脚本目录
cd /usr/jenkinsworkspace/manage
  • 脚本文件授权
chmod u+x deploy.sh
  • 启动jar包,同目录app.log显示日志,重新启动日志会覆盖
./deploy.sh start
  • 查看jar包运行状态
./deploy.sh status
  • 停止jar包
./deploy.sh stop

注册服务启动

  • 需要执行完毕【通过脚本启动】步骤配置内容

  • 修改deploystart.sh和deploystop.sh脚本内容重的cd路径为【通过脚本启动】步骤拷贝到的项目路径

deploystart.sh

cd /usr/jenkinsworkspace/manage;chmod u+x deploy.sh;./deploy.sh start

deploystop.sh

cd /usr/jenkinsworkspace/manage;chmod u+x deploy.sh;./deploy.sh stop
  • 拷贝deploy.service,deploystart.sh,deploystop.sh到/etc/systemd/system目录

deploy.service

[Unit]
Description=run deploy service
After=network.target

[Service]
Type=forking
ExecStart=/bin/bash /etc/systemd/system/deploystart.sh
ExecStop=/etc/systemd/system/deploystop.sh
PrivateTmp=true

[Install]
WantedBy=multi-user.target
  • 执行命令服务开机启动
systemctl enable deploy.service
  • 执行命令取消服务开机启动
systemctl disable deploy.service
  • 执行命令查看服务状态
systemctl status deploy
  • 执行命令启动服务
systemctl start deploy
  • 执行命令停止服务
systemctl stop deploy
目录
相关文章
|
9天前
|
存储 Shell Linux
Linux Bash 脚本中的 IFS 是什么?
【4月更文挑战第25天】
18 0
Linux Bash 脚本中的 IFS 是什么?
|
1天前
|
前端开发 Java Linux
宝塔Linux:部署His医疗项目通过jar包的方式
宝塔Linux:部署His医疗项目通过jar包的方式
|
3天前
|
Shell Linux 编译器
C语言,Linux,静态库编写方法,makefile与shell脚本的关系。
总结:C语言在Linux上编写静态库时,通常会使用Makefile来管理编译和链接过程,以及Shell脚本来自动化构建任务。Makefile包含了编译规则和链接信息,而Shell脚本可以调用Makefile以及其他构建工具来构建项目。这种组合可以大大简化编译和构建过程,使代码更易于维护和分发。
20 5
|
4天前
|
分布式计算 大数据 Hadoop
【经验分享】用Linux脚本管理虚拟机下的大数据服务
【经验分享】用Linux脚本管理虚拟机下的大数据服务
14 1
|
4天前
|
Shell Linux 编译器
C语言,Linux,静态库编写方法,makefile与shell脚本的关系。
总结:C语言在Linux上编写静态库时,通常会使用Makefile来管理编译和链接过程,以及Shell脚本来自动化构建任务。Makefile包含了编译规则和链接信息,而Shell脚本可以调用Makefile以及其他构建工具来构建项目。这种组合可以大大简化编译和构建过程,使代码更易于维护和分发。
13 3
|
19小时前
|
安全 Linux 测试技术
|
1天前
|
缓存 关系型数据库 Linux
Linux目录结构:深入理解与命令创建指南
Linux目录结构:深入理解与命令创建指南
|
1天前
|
数据挖掘 Linux vr&ar
Linux命令实战:解决日常问题的利器
Linux命令实战:解决日常问题的利器
|
1天前
|
NoSQL Linux Redis
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
12 0
|
1天前
|
安全 Linux Shell
linux基础命令详解
linux基础命令详解
8 0