透过systemctl管理mysqld服务

透过systemctl管理mysqld服务,第1张

概述1. 背景 CentOS 7.x 之前的版本,系统启动时,第一支呼叫的程序是 init ,然后 init 去唤起所有的系统所需要的服务,无论是本地服务还是网络服务。所有的服务启动脚本都放置于 /etc 1. 背景

CentOS 7.x 之前的版本,系统启动时,第一支呼叫的程序是 init ,然后 init 去唤起所有的系统所需要的服务,无论是本地服务还是网络服务。所有的服务启动脚本都放置于 /etc/init.d 下面,基本上都是使用 bash shell script 所写成的脚本程序。

从CentOS 7.x 以后,Red Hat 放弃了 init 启动脚本的方法,改用systemd 这个启动服务管理机制。

2.systemctl管理服务的好处

平行处理所有服务,加速开机流程

旧的init 启动脚本是【一项一项任务依序启动】的模式,因此不相依的服务也是一个一个的等待。但目前我们的硬件主机系统与 *** 作系统几乎都支持多核心结构了,systemd可以让所有的服务同时启动,系统启动的速度变快了。

一经要求就相应的 on-demand 启动方式

System 全部就是仅有一直systemd 服务 搭配systemctl 指令来处理,无需其它的指令来支持。不想之前的启动方式还要init,chkconfig,service…等指令。此外,systemd 由于常驻内存,因此任何要求(on-demand)都可以立即处理后续的daemon启动的任务。

服务相依性的自我检查

由于systemd可以自定义服务相依性的检查,因此如果 B 服务是架构在 A服务上面的,那当你在没有启动 A 服务的情况下仅手动启动 B 服务时,systemd 会自动帮你启动A服务。这样可以免去管理员一项一项去分析的麻烦。

3.Systemd启动脚配置文件所在目录
目录说明
/lib/system/system/

使用CentOS官方提供的软件安装后,默认的启动脚本配置文件都放在这里,这里的数据尽量不要修改。要修改时,请到 /etc/system/system低下修改较佳。

/etc/system/system/管理员依据主机系统的需求所建立的执行脚本,其实这个目录有点像之前的/etc/rc.d/rc5.d/Sxx 之类的功能。执行优先顺序要比/run/system/system/ 高。

/run/system/system/

系统执行过程中所产生的服务脚本。
4.MysqL服务

在之前的安装中,我们一般都是 通过 support-files/MysqL.server (单实例)、support-files/MysqLd_multi.server (多实例)来配置服务。

例如 :https://www.cnblogs.com/xuliuzai/p/10078351.html

再如:https://www.cnblogs.com/xuliuzai/p/10732833.html

其实现管理MysqL服务的脚本就是 在MysqL.server、 MysqLd_multi.server文件中。

脚本复杂并且修改比较困难。例如,我需要配置多实例,但不想修改既有的my.cnf 配置文件,如果新实例的文件名字命名为my3307.cnf,此时再用老的方法,去修改 MysqL.server 就比较麻烦。

而如果用 system就比较简单。

例如 ,定义一个测试服务为:MysqL3307.service

 

[Unit]Description=MysqL ServerAfter=network.target[Install]WantedBy=multi-user.target[Service]Type=forkingTimeoutSec=0PermissionsstartOnly=trueExecStart=/data/MysqL57/bin/MysqLd --defaults-file=/etc/my3307.cnf --daemonizelimitNOfile = 65535Restart=on-failureRestartSec=3RestartPreventExitStatus=1PrivateTmp=false

 

此服务的其它的一些 *** 作命令;

systemctl enable MysqL3307.service  ---设置开启自启动

systemctl start MysqL3307.service     ----开启此服务

systemctl stop MysqL3307.service    -----关闭此服务

systemctl status MysqL3307.service -----查看服务状态

 

注意 ; (1)/data/MysqL57/bin/MysqLd 路径为 可执行文档所在路径;/etc/my3307.cnf 配置未见;

(2)Restart=on-failure 是决定 服务Failure 时,是否自动拉起;RestartSec=3 尝试拉起间隔。

 

 

---------部分知识参考《鸟哥的linux私房菜-基础学习篇(第四版)》,谢谢!

总结

以上是内存溢出为你收集整理的透过systemctl管理mysqld服务全部内容,希望文章能够帮你解决透过systemctl管理mysqld服务所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1152268.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存