linux服务启动脚本

linux服务启动脚本:

支持启动、关闭、重启、查看是否正在运行的功能。

#!/bin/sh
#该脚本为Linux下启动java程序的通用脚本。即可以作为开机自启动service脚本被调用,
#也可以作为启动java程序的独立脚本来使用。

#警告!!!:该脚本stop部分使用系统kill命令来强制终止指定的java程序进程。
#在杀死进程前,未作任何条件检查。在某些情况下,如程序正在进行文件或数据库写操作,
#可能会造成数据丢失或数据不完整。如果必须要考虑到这类情况,则需要改写此脚本,
#增加在执行kill命令前的一系列检查。

###################################
#环境变量及程序执行参数
#需要根据实际环境以及Java程序名称来修改这些参数
###################################
#JDK所在路径
JAVA_HOME=“/usr/java/jdk”

#执行程序启动所使用的系统用户,考虑到安全,推荐不使用root帐号
RUNNING_USER=root

#Java程序所在的目录(classes的上一级目录)
APP_HOME=/opt/tudaxia/test/WEB-INF

#需要启动的Java主程序(main方法类)
APP_MAINCLASS=com.tudaxia.test.TestMain

#拼凑完整的classpath参数,包括指定lib目录下所有的jar
CLASSPATH= A P P H O M E / c l a s s e s f o r i i n " APP_HOME/classes for i in " APPHOME/classesforiin"APP_HOME"/lib/*.jar; do
CLASSPATH=“ C L A S S P A T H " : " CLASSPATH":" CLASSPATH":"i”
done

#java虚拟机启动参数
JAVA_OPTS=“-ms512m -mx512m -Xmn256m -Djava.awt.headless=true -XX:MaxPermSize=128m”

###################################
#(函数)判断程序是否已启动

#说明:
#使用JDK自带的JPS命令及grep命令组合,准确查找pid
#jps 加 l 参数,表示显示java的完整包路径
#使用awk,分割出pid ($1部分),及Java程序名称($2部分)
###################################
#初始化psid变量(全局)
psid=0

checkpid() {
javaps=$JAVA_HOME/bin/jps -l | grep $APP_MAINCLASS

if [ -n “$javaps” ]; then
psid=echo $javaps | awk '{print $1}'
else
psid=0
fi
}

###################################
#(函数)启动程序

#说明:
#1. 首先调用checkpid函数,刷新KaTeX parse error: Expected 'EOF', got '#' at position 10: psid全局变量 #̲2. 如果程序已经启动(psid不等于0),则提示程序已启动
#3. 如果程序没有被启动,则执行启动命令行
#4. 启动命令执行后,再次调用checkpid函数
#5. 如果步骤4的结果能够确认程序的pid,则打印[OK],否则打印[Failed]
#注意:echo -n 表示打印字符后,不换行
#注意: “nohup 某命令 >/dev/null 2>&1 &” 的用法
###################################
start() {
checkpid

if [ $psid -ne 0 ]; then
echo “"
echo “warn: A P P M A I N C L A S S a l r e a d y s t a r t e d ! ( p i d = APP_MAINCLASS already started! (pid= APPMAINCLASSalreadystarted!(pid=psid)”
echo "

else
echo -n “Starting $APP_MAINCLASS …”
JAVA_CMD=“nohup $JAVA_HOME/bin/java $JAVA_OPTS -classpath $CLASSPATH $APP_MAINCLASS >/dev/null 2>&1 &”
su - R U N N I N G U S E R − c " RUNNING_USER -c " RUNNINGUSERc"JAVA_CMD"
checkpid
if [ p s i d − n e 0 ] ; t h e n e c h o " ( p i d = psid -ne 0 ]; then echo "(pid= psidne0];thenecho"(pid=psid) [OK]"
else
echo “[Failed]”
fi
fi
}

###################################
#(函数)停止程序

#说明:
#1. 首先调用checkpid函数,刷新KaTeX parse error: Expected 'EOF', got '#' at position 10: psid全局变量 #̲2. 如果程序已经启动(psid不等于0),则开始执行停止,否则,提示程序未运行
#3. 使用kill -9 pid命令进行强制杀死进程
#4. 执行kill命令行紧接其后,马上查看上一句命令的返回值: KaTeX parse error: Expected 'EOF', got '#' at position 3: ? #̲5. 如果步骤4的结果?等于0,则打印[OK],否则打印[Failed]
#6. 为了防止java程序被启动多次,这里增加反复检查进程,反复杀死的处理(递归调用stop)。
#注意:echo -n 表示打印字符后,不换行
#注意: 在shell编程中,“$?” 表示上一句命令或者一个函数的返回值
###################################
stop() {
checkpid

if [ $psid -ne 0 ]; then
echo -n "Stopping A P P M A I N C L A S S . . . ( p i d = APP_MAINCLASS ...(pid= APPMAINCLASS...(pid=psid) "
su - $RUNNING_USER -c “kill -9 $psid”
if [ $? -eq 0 ]; then
echo “[OK]”
else
echo “[Failed]”
fi

  checkpid
  if [ $psid -ne 0 ]; then
     stop
  fi

else
echo “"
echo “warn: $APP_MAINCLASS is not running”
echo "

fi
}

###################################
#(函数)检查程序运行状态

#说明:
#1. 首先调用checkpid函数,刷新KaTeX parse error: Expected 'EOF', got '#' at position 10: psid全局变量 #̲2. 如果程序已经启动(psid不等于0),则提示正在运行并表示出pid
#3. 否则,提示程序未运行
###################################
status() {
checkpid

if [ p s i d − n e 0 ] ; t h e n e c h o " psid -ne 0 ]; then echo " psidne0];thenecho"APP_MAINCLASS is running! (pid= p s i d ) " e l s e e c h o " psid)" else echo " psid)"elseecho"APP_MAINCLASS is not running"
fi
}

###################################
#(函数)打印系统环境参数
###################################
info() {
echo “System Information:”
echo “"
echo head -n 1 /etc/issue
echo uname -a
echo
echo "JAVA_HOME= J A V A H O M E " e c h o ‘ JAVA_HOME" echo ` JAVAHOME"echoJAVA_HOME/bin/java -version`
echo
echo “APP_HOME= A P P H O M E " e c h o " A P P M A I N C L A S S = APP_HOME" echo "APP_MAINCLASS= APPHOME"echo"APPMAINCLASS=APP_MAINCLASS”
echo "

}

###################################
#读取脚本的第一个参数($1),进行判断
#参数取值范围:{start|stop|restart|status|info}
#如参数不在指定范围之内,则打印帮助信息
###################################
case “$1” in
‘start’)
start
;;
‘stop’)
stop
;;
‘restart’)
stop
start
;;
‘status’)
status
;;
‘info’)
info
;;
*)
echo “Usage: $0 {start|stop|restart|status|info}”
exit 1
esac
exit 0


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux系统中,systemctl是一个与服务相关的命令行工具。它可以管理系统级别的服务,包括启动、停止、重启、查看状态等操作。而服务启动脚本则是一个用来定义服务启动流程的脚本文件。 systemctl使用服务启动脚本来初始化、启动服务,并实现常规的任务管理和控制。这些任务包括定义服务的名称、描述、监听端口、指定运行进程等。 服务启动脚本一般位于系统特定的目录中,如/etc/systemd/system/目录下。当管理员使用systemctl命令开始管理服务时,它会在这个目录下搜索同名的服务启动脚本。如果找到匹配的脚本,systemctl将调用它来启动和管理服务服务启动脚本具有一定的规范结构,其中包含了服务的所有信息。它包括以下几个关键信息: 1.服务名称:用来标识服务的名称,通常与服务启动脚本的文件名一致。 2.描述:对服务进行简单介绍。 3.依赖性:定义服务启动的依赖关系,确保相关服务在需要时按正确的顺序启动。 4.运行参数:定义服务运行的参数,如监听端口、运行用户等。 5.启动脚本:定义启动服务时需要执行的命令。 总的来说,服务启动脚本是一种定义服务初始化、启动和管理流程的脚本。它是systemctl命令能够有效管理服务的重要组成部分。通过对服务启动脚本的定义和管理,Linux系统可以更方便地管理各种系统级别的服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值