zoukankan      html  css  js  c++  java
  • CentOS 7下MySQL5.7.23的服务配置参数测试

    CentOS 7默认安装MySQL5.7.23,服务管理发生了变化,从sysvinit(service mysql start)变化为systemd(systemctl start mysqld.service)

    最近测试了下MySQL5.7.23的服务管理参数,测试主要涉及Restart ,RestartPreventExitStatus,RestartSec,StartLimitInterval四个服务启动参数。

    【服务启动方式比较】

    1、CentOS7下MySQL5.7.23默认参数下的服务启动方式

    MySQL crash、OOM、kill -9 pid三种情况下mysqld进程被终止,都会马上重新启动,间隔100ms

    systemctl stop mysqld@service不会自动重启

    2、CentOS6下MySQL5.6.21的服务启动情况

    MySQL crash、OOM crash和oom kill的是mysqld进程,由于存在mysqld_safe的守护进程,会自动重启mysqld

    对于kill -9的命令,如果只kill -9 mysqld进程,mysqld_safe守护进程会重启mysqld,如果mysqld_safe也被kill掉,那么mysqld就不会被拉起来

    service mysql stop 不会自动重启

    【在CentOS 7下如何实现kill -9 mysqld后不自动重启】

    RestartPreventExitStatus= 中列出的退出码或信号永远不会导致该服务被重启

    修改RestartPreventExitStatus=1 SIGKILL,增加kill -9对应的信号SIGKILL

     测试kill -9,mysqld进程不会自动重启

    测试OOM,mysqld进程也不会自动重启

    原因是由于OOM在kill进程时传的也是SIGKILL的信号

    【需要关注的服务配置的两个参数】

    1、RestartSec设置在重启服务(Restart)前暂停多长时间,默认值是100ms,就是mysqld进程OOM或kill后等待100ms就会马上重启

    我们MHA中配置的ping_interval=10,意思是MHA Manager每10秒 ping一次master,尝试3次失败后,进行failover

    这个参数需要评估下,是否做设定,比如如果希望发生上面异常,能被MHA检测到,那么最保险的是间隔30秒再重启mysql进程,需要指定RestartSec=30

    2、StartLimitInterval

    设置单元的启动频率限制。 默认一个单元在10秒内最多允许启动5次。建议修改为StartLimitInterval=0,无限制重启。

  • 相关阅读:
    WScript.Shell对象的run和exec(脚本调用其他程序)
    Hard link 和 Symbolic link 软链接 硬链接
    SGI STL 红黑树(RedBlack Tree)源代码分析
    宏likely和unlikely
    PCLint输出格式选项
    32位与64位原子操作的问题
    王石与成功的定义
    关于FckEditor基于Asp.net MVC中出现未结束的字符窜常量——解决方案
    崩溃中!Nhibernate的数据分页.
    创建Silverlight技术联盟QQ群 希望大家踊跃加入
  • 原文地址:https://www.cnblogs.com/wangdong/p/9828648.html
Copyright © 2011-2022 走看看