CentOS 7下systemd是如何stop mysql服务的

【背景】

有同事在研究mongo的服务启动方式,讨论到mysql5.7的服务管理时一起做了下面测试。

MySQL5.7是用systemd来管理service的,它的配置文件/usr/lib/systemd/system/mysqld@.service中,只定义了ExecStart启动服务器的命令,

但没有定义ExecStop参数,就是停止mysqld服务时执行的命令。systemd究竟是如何stop mysql服务的。

 

【测试步骤】

1、执行关闭服务的命令

systemctl stop mysqld@replica02.service

2、使用systemtap脚本来抓取kill进程时的信号量

global target;
global signal;

probe begin
{
        printf("%-6s %-12s %-5s %-6s %6s\n", "FROM", "COMMAND", "SIG", "TO",
            "RESULT");
}
probe nd_syscall.kill
{
        target[tid()] = uint_arg(1);
        signal[tid()] = uint_arg(2);
}
probe nd_syscall.kill.return
{
        if (target[tid()] != 0) {
                printf("%-6d %-12s %-5d %-6d %6d\n", pid(), execname(),
                    signal[tid()], target[tid()], int_arg(1));
                delete target[tid()];
                delete signal[tid()];
        }
}

  

3、可以看到上面的mysqld进程127531被systemd进程kill掉了,先传15,再传18两个信号量

相当于执行了kill -15 127531,kill -18 127531两个命令

 

4、从文档中也找到了说明,

KillSignal参数可以指定停止进程时使用的信号,默认值为15 SIGTERM ,另外systemd会紧跟此信号再发送一个18 SIGCONT信号,以确保杀死已挂起的进程。

KillSignal=Specifies which signal to use when killing a service. This controls the signal that is sent as first step of shutting down a unit (see above), and is usually followed by SIGKILL (see above and below). For a list of valid signals, see signal(7). Defaults to SIGTERM.

Note that, right after sending the signal specified in this setting, systemd will always send SIGCONT, to ensure that even suspended tasks can be terminated cleanly.

 

转载于:https://www.cnblogs.com/wangdong/p/10132777.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值