对于刚刚接触MySQL的同学来说对MySQL安装和启动是入门级也是最简单的,但是我想没有很多认清楚MySQL的启动方式对MySQL的影响,比如mysqld_safe和mysqld的启动方式的区别,我们为什么通常都在/etc/my.cnf下设置mysql的参数,而my.cnf下又有[mysqld]和[mysqld_safe]等模块,这些又有什么作用,这篇博文希望能让大家大致了解下mysql的启动过程。

一、MySQL读取配置文件的顺序

[root@mysql01 ~]# mysql --verbose --help | grep my.cnf
order of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

在上面的命令结果中,我们知道mysql在启动过程中默认会按照顺序去找mysql的启动参数,所以这也是我们都通常建议大家把参数放到/etc/my.cnf的原因。

二、MySQL启动方式

MySQL的启动方式通常分成三种:mysqld、mysqld_safe、mysqld_multi(主要用于多实例启动)

而这三种方式又有什么关联关系呢?

首先当我们使用service mysqld start或者/etc/init.d/mysqld start这样的方式启动的时候,其实是使用了mysql.server这个脚本,这个脚本默认会调用mysqld_safe来启动mysqld,所以通常我们启动mysql之后查看进程的时候会发现有mysqld和mysqld_safe这两个进程存在。这两种通常都是单实例的启动方式,当然也可以使用mysqld来启动多实例的。而mysqld_multi用来启动多实例,也是通过先调用mysqld_safe和mysqld来启动mysql的。

三、MySQL启动原理

默认的mysql的服务启动程序是mysql.server,mysql.server程序主要是会用到两个程序和一个函数,分别是my_print_defaults、myslqd_safe和parse_server_arguments

1、my_print_defaults:读取my.cnf配置文件,输出参数传递给parse_server_arguments,该程序只读my.cnf中[mysqld]中的参数。

2、parse_server_arguments:该函数处理my_print_defaults传递过来的参数赋值给--basedir、--datadir、--pid-file、--server-startup-timeout

3、myslqd_safe:mysqld_safe程序调用mysqld程序来启动mysql服务,[mysqld_safe]会覆盖mysqld部分中的参数

4、mysqld_multi会读取配置文件中的[mysqld_muti],[mysqldN]下面的参数,N需要时一个整数,建议用端口号表示,该部分的配置会覆盖[mysqld]部分中的配置

5、在mysqld进程挂掉的时候,mysqld_safe进程会监测到并重新将mysqld启动起来。

四、生产环境下的启动建议

建议在生产环境下使用mysqld --defaults-file=.../my.cnf &来启动 ,当mysqld挂掉的时候,不要让mysqld_safe来将其启动,最好本着出错了就停下来的原则,发现错误然后解决错误。

转载于:https://blog.51cto.com/2255753/1907293

MySQL启动过程详解相关推荐

  1. Mysql加锁过程详解(3)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  2. Linux开启动过程详解

    Linux开启动过程详解 Linux启动过程 前言: Linux是一种自由和开放源代码的类UNIX操作系统.该操作系统的内核由林纳斯·托瓦兹在1991年10月5日首次发布.在加上用户空间的应用程序之后 ...

  3. centos7 启动流程图_Linux启动过程详解

    Linux启动过程详解 作者:江远航 一.启动流程图如下 图1 Linux启动流程图 BIOS ---> MBR ---> Kernel---> Init 二.Linux启动顺序 一 ...

  4. Mysql加锁过程详解(2)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  5. Delta3d框架学习--程序启动过程详解

    一个Delta3d程序启动过程详解 一.初始化一个dtGame::GameApplication的实例,dtGame::GameApplication* app = new dtGame::GameA ...

  6. 朱老师ARM裸机学习笔记(四):S5PV210启动过程详解

    常用器件特性 内存: SRAM 静态内存 特点就是容量小.价格高,优点是不需要软件初始化直接上电就能用 DRAM 动态内存 特点就是容量大.价格低,缺点就是上电后不能直接使用,需要软件初始化后才可以使 ...

  7. Spring启动过程详解

    Spring启动过程详解 前言 spring容器启动过程 AnnotationConfigApplicationContext 有参数构造方法 无参数构造 AnnotatedBeanDefinitio ...

  8. linux efi 启动原理,Linux(RHEL6)启动过程详解

    Linux(RHEL6)启动过程详解 Linux(红帽RHEL6)启动过程详解: RHEL的一个重要和强大的方面是它是开源的,并且系统的启动过程是用户可配置的.用户可以自由的配置启动过程的许多方面,包 ...

  9. 嵌入式linux的u-boot系统启动过程,【站友投递】U-boot启动过程详解

    [站友投递]U-boot启动过程详解 来源:互联网 作者:denny 时间:2009-03-18 Tag:点击: 一.U-BOOT的目录结构 u-boot目录下有18个子目录,分别存放管理不通的源程序 ...

最新文章

  1. 巨大冲击!AlphaFold2再登Nature,从业者都懵了:人类98.5%的蛋白质,全都被预测了一遍...
  2. golang获取md5
  3. NYOJ 179 LK's problem
  4. python3安装venv虚拟环境
  5. 学会这10大高性能开发技术,轻松躲过裁员名单!
  6. SELinux入门:了解和配置SELinux
  7. 发布虚拟机WEB服务 备忘
  8. python输入名字配对情侣网名_输入姓名配对qq网名,QQ情侣昵称
  9. AD20更改PCB 2D视图的背景环境颜色
  10. Python的二进制位运算
  11. 初读《Linux运维之道》浅见
  12. JSONObject.fromObject(obj) 报错
  13. 【第56期】游戏策划:给@LK的简历分析
  14. 如何自己开发漏洞扫描工具
  15. Casper与V神的博弈论(过节了,文末送大礼)
  16. 怎么用计算机表达爱意,简单表达爱意的句子
  17. iOS开发之模仿qq通讯录
  18. 简单模拟图卷积(numpy实现)
  19. Tableau图表 • 堆积发散条形图(李克特量表)
  20. 真正免费的PDF合并软件,不用下载,在线一键合并

热门文章

  1. 十二、用Axis操作 Header头部信息
  2. 利用XML实现通用WEB报表打印(参考)
  3. NGINX api网关(mark 有空填坑)
  4. Bzoj1007 [HNOI2008]水平可见直线
  5. 【计算几何】【极角序】【二分】bzoj1914 [Usaco2010 OPen]Triangle Counting 数三角形
  6. VM中的Linux安装jdk和tomcat
  7. 使用 ADSync 集成 IBM Lotus Domino Directory 和 Microsoft Active Directory
  8. ubuntu 配置桥接网卡_KVM之配置桥接网卡
  9. dpt原来英文是什么_今天才发现!原来微信还可以翻译文字,还不知道就可惜了...
  10. 如何用Git向GitHub上传送文件(从注册GitHub到用Git上传的每一步)