当前位置: 代码网 > 服务器>服务器>Linux > Linux脚本启动jar包方式

Linux脚本启动jar包方式

2024年05月26日 Linux 我要评论
注意:以下脚本笔者是在windows上编辑的,因此默认格式是dos。如果在linux上使用,请使用vi命令编该文件,改为unix格式。笔者使用的springboot + jsp 因此使用的是war包,

注意:

以下脚本笔者是在windows上编辑的,因此默认格式是dos。

如果在linux上使用,请使用vi命令编该文件,改为unix格式。

笔者使用的springboot + jsp 因此使用的是war包,如果你使用的是jar包,在文中用到war的地方改成jar就行。

一:脚本auto_deploy.sh

使用该脚本只需要修改jar_name(改成自己的)、log_path(改成自己的)、脚本格式(改成unix格式)这三点就行了。

#!/bin/bash
# 定义变量
# 要运行的jar包路径,加不加引号都行。 注意:等号两边 不能 有空格,否则会提示command找不到
jar_name="/xxx/xxx/xxx/xxx.war"
# 日志路径,加不加引号都行。 注意:等号两边 不能 有空格,否则会提示command找不到
log_path=/export/logs/main.log
 
 
# 如果输入格式不对,给出提示!
tips() {
	echo ""
	echo "warning!!!......tips, please use command: sh auto_deploy.sh [start|stop|restart|status].   for example: sh auto_deploy.sh start  "
	echo ""
	exit 1
}
 
 
# 启动方法
start() {
        # 重新获取一下pid,因为其它操作如stop会导致pid的状态更新
	pid=`ps -ef | grep $jar_name | grep -v grep | awk '{print $2}'`
        # -z 表示如果$pid为空时执行
	if [ -z $pid ]; then
        nohup java -jar $jar_name > /dev/null 2>&1 &
        pid=`ps -ef | grep $jar_name | grep -v grep | awk '{print $2}'`
		echo ""
        echo "service ${jar_name} is starting!pid=${pid}"
		echo "........................here is the log.............................."
		echo "....................................................................."
        tail -f $log_path
		echo "........................start successfully!........................."
	else
		echo ""
		echo "service ${jar_name} is already running,it's pid = ${pid}. if necessary, please use command: sh auto_deploy.sh restart."
		echo ""
	fi
}
 
# 停止方法
stop() {
		# 重新获取一下pid,因为其它操作如start会导致pid的状态更新
	pid=`ps -ef | grep $jar_name | grep -v grep | awk '{print $2}'`
        # -z 表示如果$pid为空时执行。 注意:每个命令和变量之间一定要前后加空格,否则会提示command找不到
	if [ -z $pid ]; then
		echo ""
        echo "service ${jar_name} is not running! it's not necessary to stop it!"
		echo ""
	else
		kill -9 $pid
		echo ""
		echo "service stop successfully!pid:${pid} which has been killed forcibly!"
		echo ""
	fi
}
 
# 输出运行状态方法
status() {
        # 重新获取一下pid,因为其它操作如stop、restart、start等会导致pid的状态更新
	pid=`ps -ef | grep $jar_name | grep -v grep | awk '{print $2}'`
        # -z 表示如果$pid为空时执行。注意:每个命令和变量之间一定要前后加空格,否则会提示command找不到
	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 ""
	echo ".............................restarting.............................."
	echo "....................................................................."
		# 重新获取一下pid,因为其它操作如start会导致pid的状态更新
	pid=`ps -ef | grep $jar_name | grep -v grep | awk '{print $2}'`
        # -z 表示如果$pid为空时执行。 注意:每个命令和变量之间一定要前后加空格,否则会提示command找不到
	if [ ! -z $pid ]; then
		kill -9 $pid
	fi
	start
	echo "....................restart successfully!..........................."
}
 
# 根据输入参数执行对应方法,不输入则执行tips提示方法
case "$1" in
   "start")
     start
     ;;
   "stop")
     stop
     ;;
   "status")
     status
     ;;
   "restart")
     restart
     ;;
   *)
     tips
     ;;
esac

注意事项:

  • -z 命令表示如果$pid为空时执行。 注意:每个命令和变量之间一定要前后加空格,否则会提示command找不到 
  •  要运行的jar包路径,加不加引号都行。 注意:等号两边 不能 有空格,否则会提示command找不到

二:更改脚本格式

注意:以下脚本笔者是在windows上编辑的,因此默认格式是dos。

如果在linux上使用,请使用vi命令编该文件,改为unix格式。

第一步

上传脚本文件到linux系统后,使用vi命令编辑该脚本文件:

vi auto_deploy.sh

第二步

在esc模式下冒号输入命令set ff回车就能看到,该脚本是windows系统的dos格式

如下图:

第三步

在esc模式下冒号,输入修改格式命令set ff=linux,然后回车(回车后linux系统并没有提示),完事后还是在esc模式下输入写入保存命令:wq。

:set ff=linux
:wq

如下图 

三:脚本运行截图

服务非启动状态下截图

sh auto_deploy.sh

sh auto_deploy.sh stop

 

sh auto_deploy.sh status

服务启动状态下截图

sh auto_deploy.sh start

再次启动一下试试(此时会有提示:服务已经启动,启动状态下请使用重启命了):

查看状态(提示正在运行):

sh auto_deploy.sh status

重启试试:

sh auto_deploy.sh restart

停掉服务试试:

sh auto_deploy.sh stop

再次输入stop命令(给出提示:服务没有运行,没必要停止!):

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com