一.系统服务

如果组件已经安装为系统服务,默认服务文件为 xxx.service,存储在 /usr/lib/systemd/system
可以使用以下2种方式设置开机启动
systemctl方式
systemctlenable/disable xxx 指令设置/取消开机启动--查看是否开机启动[root@localhostsystem]# systemctl status chronyd.servicechronyd.service - NTP client/serverLoaded: loaded (/usr/lib/systemd/system/chronyd.service; enabled; vendor preset: enabled)Active: active (running) since Thu 2022-07-28 18:33:39 CST; 4 months 4 days agoDocs: man:chronyd(8)man:chrony.conf(5)MainPID: 790 (chronyd)Memory: 1.0MCGroup: /system.slice/chronyd.service└─790/usr/sbin/chronydsystemctllist-unit-files# 查看服务的自启动状态以list-unit-files为准# 但是系统服务太多,我想分类查看该如何做?# 查看系统中已经enable的服务systemctllist-unit-files --state=enabledsystemctl is-enabled# 查看系统中已经disable的服务systemctllist-unit-files --state=disabledsystemctl is-enabled# --state还可以与list-units结合使用,具体可使用以下命令查询用法systemctl--state=help
chkconfig方式(较复杂)
chkconfig --add xxx && chkconfig --level 3 xxx on/off,本方式要求服务脚本文件必须在 /etc/init.d/ 目录下,且结合 /etc/rc.d/rc0.d~rc6.d目录实现,同时服务脚本文件必须包含必要的头部脚本代码,较复杂--查看是否开机启动chkconfig --list network注:该输出结果只显示 SysV 服务,并不包含原生 systemd 服务。SysV 配置数据可能被原生 systemd 配置覆盖。要列出 systemd 服务,请执行 'systemctl list-unit-files'查看在具体 target 启用的服务请执行 'systemctl list-dependencies [target]'network 0:关 1:关 2:开 3:开 4:开 5:开 6:关
特别关注:systemctl方式实际效果
该方式实际是在 /etc/systemd/system/xxx/ 或 /etc/systemd/user/下创建 .service文件 的软连接,分别代表系统服务与用户服务。
其中,xxx为该服务的适用模式,如网络服务network-online.target.wants、多用户服务multi-user.target.wants。
[root@localhost ~]# systemctl enable mysqldCreated symlink from /etc/systemd/system/multi-user.target.wants/mysqld.service to /usr/lib/systemd/system/mysqld.service.
该方式下,取消卡机启动,可以执行以下操作之一
  • systemctl disable xxx
  • 移除 /etc/systemd/system/xxx/ 或 /etc/systemd/user/ 下相应软连接或服务文件

二.通用方案

不管组件是否已经安装为系统服务,可以通过开机启动脚本实现
注意,以下操作,均需要设置相关脚本的可执行权限,即 chmod +x 启动脚本
  • 方法一:追加启动命令到默认启动脚本 /etc/rc.local,或/etc/rc.d/rc.local,前者是后者的软连接
  • 方法二:编写启动脚本.sh,放到目录 /etc/profile.d下
  • 方法三:编写启动脚本.sh,将脚本的执行指令追加到 /etc/rc.local,或/etc/rc.d/rc.local

三.crontab方案

crontab支持特殊关键字实现特定任务调度,代替 5个时间设置标识符(分 时 日 月 周),特殊语法以 @ 符号作为前缀
具体请参考:官方文档
语法:@xxx command
@reboot : Run once after reboot. 重启时执行一次,实测比 /etc/rc.d/rc.local 更早执行(提前1-2s),比默认1分钟定时提前30s左右@yearly : Run once a year, ie. "0 0 1 1 *". 一年执行一次,1100分执行@annually : Run once a year, ie. "0 0 1 1 *". 一年执行一次,1100分执行@monthly : Run once a month, ie. "0 0 1 * *". 一月执行一次,每月100分执行@weekly : Run once a week, ie. "0 0 * * 0". 一周执行一次@daily : Run once a day, ie. "0 0 * * *". 一天执行一次@hourly : Run once an hour, ie. "0 * * * *". 一小时执行一次
即,可以使用 @reboot 关键字实现开机启动功能,示例如下
[root@localhost daemonProcess]# crontab -e# Example of job definition:# .---------------- minute (0 - 59)# | .------------- hour (0 - 23)# | | .---------- day of month (1 - 31)# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat# | | | | |# * * * * * command to be executed#开机启动@reboot /usr/local/daemonProcess/somescript.sh#守护* * * * * /usr/local/daemonProcess/somescript.sh
特别关注:
是否同时使用 @reboot 和 定时,需要根据实际业务需要来决定。
如果守护定时设置为1分钟,即 * * * * *,则建议不再设置 @reboot,因为两者在开机启动后的1分钟内,都会执行,可能会造成重复执行,如果所守护的应用服务兼容重复启动,没有问题,如果不兼容,建议使用一种方案。
如果守护定时间隔比较大,还是建议同时使用 @reboot,保证应用服务及时启动。

四.生产环境开机启动方案建议

以上3种方案,建议在生产环境只采用一种,所有组件、服务统一,便于服务较多时快速运维。
比如,有些服务默认安装时不会自动生成 系统服务,所以方案一的方式不能适用生产环境中所有组件、服务,如果此时按照各组件、服务分别制定开机启动方案,则在后续如果服务启动异常 或 服务发版时,就需要明确识别各服务的开机启动方案,然后做相应的操作,提高运维成本,增加出错概率。

附录:开机启动脚本示例

1.追加启动命令到 /etc/rc.local,或/etc/rc.d/rc.local,前者是后者的软连接2.编写启动脚本.sh,放到目录 /etc/profile.d下---chmod +x /etc/rc.d/rc.local #开机启动脚本/usr/local/AutoStartOnBoot.shchmod +x /usr/local/AutoStartOnBoot.sh#本脚本需要依赖 /etc/rc.d/rc.local#rc.local在加载环境变量之前执行,所以此处需要人工加载source /etc/profile#redis/usr/local/redis/redis-5.0.13/bin/redis-server /usr/local/redis/redis-5.0.13/conf/redis.conf #zk#zk pid文件必须先删除后重启rm -f /data/zookeeper/data/zookeeper_server.pid;/usr/local/apache-zookeeper-3.6.3-bin/bin/zkServer.sh start#kafkaJMX_PORT=9999 /usr/local/kafka_2.13-2.7.1/bin/kafka-server-start.sh -daemon /usr/local/kafka_2.13-2.7.1/config/server.properties#kafka-manager#kafka-manager pid文件必须先删除后重启rm -f /usr/local/kafka-manager-2.0.0.2/RUNNING_PIDnohup /usr/local/kafka-manager-2.0.0.2/bin/kafka-manager -Dconfig.file=/usr/local/kafka-manager-2.0.0.2/conf/application.conf -Dhttp.port=9002 >/dev/null2>&1 &#mysqlservice mysqld start
链接:https://www.cnblogs.com/xiaoyaozhe/p/17671260.html
(版权归原作者所有,侵删)
继续阅读
阅读原文