其实,这应该放在docker之前写,因为docker不需要写service脚本且目录很明了。现在写,是因为之前的程序用的systemctl注册的服务,如果,有同学是想实现服务自启的我还是推荐docker(有兴趣看下docker部署+容器制作)。不管怎么说也不能忘了怎么做,参考网上的文章,我再整理一下。
要实现注册服务,开机自启,首先,需要给执行文件写一个sh脚本,之后写一个service脚本,最后,将service脚本放到指定目录。
1、执行文件的sh脚本
例子:新建一个test.sh文件,修改权限777(可执行)
#!/bin/bash
SERVERNAME="xxxx.out" #执行文件名(你要注册服务的执行文件)
start() #运行程序
{
echo "start $SERVERNAME"
/home/devs/$SERVERNAME & #绝对路径拉起程序
# 上面的 & 一定要保留 他的作用类似脱机执行,不然程序会阻塞
echo "start $SERVERNAME ok!"
exit 0;
}
stop() #停止程序
{
echo "stop $SERVERNAME"
killall $SERVERNAME
echo "stop $SERVERNAME ok!"
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo "usage: $0 start|stop|restart"
exit 0;
esac
exit
2、服务的service脚本
例子 新建一个xxxx.service文件
# xxxx.service服务文件
[Unit]
Description=xxxxProxy # 服务描述
[Service] # 通过上面写的test.sh脚本执行启动、停止、重启
Type=forking
ExecStart=/bin/bash -c "/home/devs/xxxxProxy.out &"
#/home/devs/test.sh start
ExecStop=/home/devs/test.sh stop
ExecReload=/home/devs/test.sh restart
[Install]
WantedBy=multi-user.target
我把具体的service脚本解释信息放到文章最后,有兴趣可以看看
3、service脚本放置目录(很重要)
systemctl脚本存放在:/usr/lib/systemd/,有系统(system)和用户(user)之分
1、/usr/lib/systemd/system #系统服务,开机不需要登陆就能运行的程序(相当于开启自启)
2、/usr/lib/systemd/user #用户服务,需要登录后才能运行的程序
service脚本以754的权限保存在/usr/lib/systemd/system目录下,需要重新加载配置文件方可生效 systemctl daemon-reload
4、执行命令
好了,上面的步骤都做好后,开始使用命令操作自己的服务吧。
命令行 | 解析 |
---|---|
systemctl status xxx | 查看服务状态 |
systemctl start xxx | 启动服务 |
systemctl stop xxx | 停止服务 |
systemctl restart xxx | 重启服务 |
systemctl enable xxx | 启用开机自启 |
systemctl disable xxx | 停用用开机自启 |
systemctl list-units --type=service | 查看所有已启动的服务 |
systemctl daemon-reload | 修改xxx.service文件后,需要执行 重新加载文件 |
5、service脚本解析
service脚本一般分为3部分:【unit】、【service】、【install】
[Unit] # 主要是服务说明
Description=test # 简单描述服务
After=network.target # 描述服务类别,表示本服务需要在network服务启动后在启动
Before=xxx.service #表示需要在某些服务启动之前启动
#After和Before字段只涉及启动顺序,不涉及依赖关系。
[Service] # 核心区域
Type=forking # 表示后台运行模式。
User=user # 设置服务运行的用户
Group=user # 设置服务运行的用户组
KillMode=control-group # 定义systemd如何停止服务
PIDFile=/usr/local/test/test.pid # 存放PID的绝对路径
Restart=no # 定义服务进程退出后,systemd的重启方式,默认是不重启
ExecStart=/usr/local/test/bin/startup.sh # 服务启动命令,命令需要绝对路径
PrivateTmp=true # 表示给服务分配独立的临时空间
[Install]
WantedBy=multi-user.target # 多用户
5.1 字段详细说明
1、Type类型有:
simple(默认):#以Execstart字段启动的进程为主进程
forking:#Execstart 字段以fox()方式启动,,此时父进程将退出,子进程将成为主进程(后台运行),一般都设置为forking
oneshot : #类似于simple,但只执行一次,systemd会等他执行完,才执行其他服务
dbus: #类似于simple,但会等待D—Bus信号后启动
notify: #类似与simple ,但结束后会发出通知信号,然后systemd才启动其他服务
idle: #类似与simple,但要等到其他任务都执行完,才启动该服务
2、EnvironmentFile:指定配置文件,和连词号组合使用,可以避免配置文件不存在的异常。
Environment:
后面接多个不同的shell变量。
例如:
Environment=DATA_DIR=/data/elk
Environment=LOG_DIR=/var/log/elasticsearch
Environment=PID_DIR=/var/run/elasticsearch
EnvironmentFile=-/etc/sysconfig/elasticsearch
连词号(-):在所有启动设置之前,添加的变量字段,都可以加上连词号
表示抑制错误,即发生错误时,不影响其他命令的执行。
比如EnviromentFile=-/etc/sysconfig/xxx表示即使文件不存在,也不会抛异常
3、Killmode的类型
contorl-group (默认) # 当前控制组里所有的子进程都会被杀掉
process : #只杀主进程
mixed: #主进程将收到SIGTERM(终止进程)信号,子进程将收到SIGKILL(无条件终止)信号
none: # 没有进程会被杀掉,只是执行服务的stop命令
4、Restart类型
no (默认):#退出后无操作
on-success :#只有正常退出时(退出状态码为0),才会重启
on-failure: #非正常退出时,重启,包括信号终止,和超时
on-abnaomal: #只有信号终止或超时,才会重启
on-abort : #只有在收到没有捕捉到信号终止时,才会重启
on-watchdog: #超市退出时,才会重启
always: #不管什么退出原因,都会重启
#对于守护进程,推荐使用on-failure
5、RestartSec
表示systemd重启服务之前,需要等待的秒数:RestartSec:30
6、各种Exec*字段
Exec*后面的命令,仅接受‘指令 参数 参数..’格式,不能接受<> |&等特殊字符,很多bash语法也不支持,如果想要支持bash语法,需要设置Tyep=oneshot
# ExecStart: # 启动服务时执行的命令
# ExecReload: # 重启服务时执行的命令
# ExecStop: # 停止服务时执行的命令
# ExecStartPre: # 启动服务前执行的命令
# ExecStartPost:# 启动服务后执行的命令
# ExecStopPost: # 停止服务后执行的命令
# PrivateTmp=True #表示给服务分配独立的临时空间,
# 注意:[Service]部分的启动、重启、停止命令全部要求使用绝对路径,使用相对路径则会报错!
7、[Install]部分是服务安装的相关设置,可设置为多用户的
[Install]
WantedBy=multi-user.target
# WantedBy字段:
# multi-user.target: # 表示多用户命令行状态,这个设置很重要
# graphical.target: # 表示图形用户状体,它依赖于multi-user.target
参考文档:
systemctl管理脚本