首先去官网或者github下载MySQL5.7的源码。

官网地址:https://dev.mysql.com/downloads/mysql/

github地址:https://github.com/mysql/mysql-server/tree/5.7

但是好像都下在不到《MySQL运维内参》中的5.7.16版本,所以我这里下载了5.7.25版本,和5.7.16版本比较接近。

我这里下载的是mysql-boost-5.7.25.tar.gz

下载好后运行如下命令,解压,并将其移动到~/文档中:

tar -zxvf mysql-boost-5.7.25.tar.gz
mv mysql-5.7.25 ~/文档/

入口函数在sql/main.cc,该文件中又调用了mysqld_mian,从这个函数开始到结束,就完成了mysqld的启动操作。

/*
main() for mysqld.
Calls mysqld_main() entry point exported by sql library.
*/
extern int mysqld_main(int argc, char **argv); int main(int argc, char **argv)
{
return mysqld_main(argc, argv);
}

在sql/mysqld.cc中对mysqld_main函数的定义进行一些精简,如下:

int mysqld_main(int argc, char **argv)
{
my_progname= argv[0];
orig_argc= argc;
orig_argv= argv; /* 处理配置文件及启动参数 */
if (load_defaults(MYSQL_CONFIG_NAME, load_default_groups, &argc, &argv))
{
flush_error_log_messages();
return 1;
}
sys_var_init(); /* 继续处理参数变量 */
ho_error= handle_options(&remaining_argc, &remaining_argv,
&all_early_options[0], mysqld_get_one_option);
mysql_audit_initialize(); /* 日志系统初始化 */
query_logger.init(); // 书上是 logger.init_base(); /* 初始化很多系统内部变量 */
if (init_common_variables())
unireg_abort(MYSQLD_ABORT_EXIT); // Will do exit /* 信号系统初始化 */
my_init_signals(); /* 核心模块启动,包括存储引擎等 */
if (init_server_components())
unireg_abort(MYSQLD_ABORT_EXIT);
if (init_ssl())
unireg_abort(MYSQLD_ABORT_EXIT); /* 终端重定向处理 */
reopen_fstream(); /* 网络系统初始化 */
if (network_init())
unireg_abort(MYSQLD_ABORT_EXIT);
start_signal_handler(); // Creates pidfile
if (!opt_noacl)
{
udf_init(); // 书中是 (void) grant_init();
} /* 状态变量初始化 */
init_status_vars(); /* Binlog相关检查初始化 */
check_binlog_cache_size(NULL);
check_binlog_stmt_cache_size(NULL);
binlog_unsafe_map_init();
if (!opt_bootstrap)
{
set_slave_skip_errors(&opt_slave_skip_errors);
if (server_id != 0)
init_slave(); /* Ignoring errors while configuring replication. */
}
create_shutdown_thread();
start_handle_manager(); /* 服务监听线程创建 */
setup_conn_event_handler_threads(); // 书上是 handle_connections_sockets();
/* Wait until cleanup is done
从这里开始,服务器启动线程一直等待,直到shutdown后,继续向下执行*/
mysql_mutex_lock(&LOCK_socket_listener_active);
socket_listener_active= false;
mysql_cond_broadcast(&COND_socket_listener_active);
mysql_mutex_unlock(&LOCK_socket_listener_active); int ret= 0;
if (shutdown_thr_handle.handle)
ret= my_thread_join(&shutdown_thr_handle, NULL);
shutdown_thr_handle.handle= NULL;
if (0 != ret)
sql_print_warning("Could not join shutdown thread. error:%d", ret); clean_up(1);
mysqld_exit(MYSQLD_SUCCESS_EXIT);
}

所以,从上面的代码看出,mysqld启动时做了以下功能:

  • 处理配置文件及启动参数
  • 日志系统初始化
  • 初始化很多系统内部变量
  • 信号系统初始化
  • 核心模块启动,包括存储引擎等
  • 终端重定向处理
  • 网络系统初始化
  • 状态变量初始化
  • Binlog相关检查初始化
  • 服务监听线程创建

等。

MySQL学习笔记——MySQL启动过程(一)的更多相关文章

  1. MySQL学习笔记-MySQL体系结构总览

    MySQL体系结构总览 不管是用哪种数据库,了解数据库的体系结构都是极为重要的.MySQL体系结构主要由数据库和数据库实例构成. 数据库:物理操作系统文件或者其它文件的集合,在mysql中,数据库文件 ...

  2. Oracle学习笔记--Oracle启动过程归纳整理

    Oracle 启动过程分为nomount状态mount状态open状态 每个状态下Oracle都会进行不同的操作:1.nomount状态 在$ORACLE_HOME/dbs目录下寻找参数文件 参数文件 ...

  3. MySQL学习笔记-MySQL数据库优化实践[转]

    最近一段时间,我们整理了一些关于Percona,Linux,Flashcache,硬件设备的优化经验,分享给大家: 硬件 1.开启BBWC RAID卡都有写cache(Battery Backed W ...

  4. MySQL学习笔记-数据库文件

    数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...

  5. MySQL学习笔记-事务相关话题

    事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都 ...

  6. MySQL学习笔记-cache 与 buffer

    Cache和Buffer是两个不同的概念,简单的说,Cache是加速"读",而 buffer是缓冲"写",前者解决读的问题,保存从磁盘上读出的数据,后者是解决写 ...

  7. MySQL学习笔记-锁相关话题

    在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因.   Mysql常用存储引擎的锁 ...

  8. MySQL学习笔记-数据库内存

    数据库内存 InnoDB存储引擎内存由以下几个部分组成:缓冲池(buffer pool).重做日志缓冲池(redo log buffer)以及额外的内存池(additional memory pool ...

  9. MySQL学习笔记-数据库后台线程

    数据库后台线程 默认情况下讲述的InnoDB存储引擎,以后不再重复声明.后台线程有7个--4个IO thread,1个master thread,1个锁监控线程,1个错误监控线程.IO thread的 ...

随机推荐

  1. 对日开发中 PG , PL , SE , PM 是什么

    PG(ProGramer)指程序员. 这类人才在企业中所占数量最多,通常占到整个项目员工数的70%,也是企业中最紧缺的一类职位,一般为具有专业知识的软件工程技术人员. PL(project leade ...

  2. PostgreSQL的 pg_hba.conf 配置参数详解

    pg_hba.conf 配置详解 该文件位于初始化安装的数据库目录下 编辑 pg_hba.conf 配置文件   postgres@clw-db1:/pgdata/9.6/poc/data> v ...

  3. 关于Keil4 转到 Keil5以后的一些错误解决

    一, 看自己选择CPU型号,根据型号再做配置 根据自己型号填写

  4. 洛谷 P2791 幼儿园篮球题

    洛谷 P2791 幼儿园篮球题 https://www.luogu.org/problemnew/show/P2791 我喜欢唱♂跳♂rap♂篮球 要求的是:\(\sum_{i=0}^kC_m^iC_ ...

  5. LibreOJ #6191. 「美团 CodeM 复赛」配对游戏

    二次联通门 : LibreOJ #6191. 「美团 CodeM 复赛」配对游戏 /* LibreOJ #6191. 「美团 CodeM 复赛」配对游戏 概率dp */ #include <cs ...

  6. ICEM——倒角的处理

    原视频下载地址: https://pan.baidu.com/s/1miHMOuk 密码: knc4

  7. fluent当中的梯度宏和VOF梯度的获取【转载】

    1 FLUENT变量梯度宏 C_R_G C_P_G C_U_G C_V_G C_W_G C_T_G C_H_G C_YI_G C_R_RG C_P_RG C_U_RG C_V_RG C_W_RG C_ ...

  8. 第07组 Alpha冲刺(2/6)

    队长:摇光 队长:杨明哲 组长博客:求戳 作业博客:求再戳 队长:杨明哲 过去两天完成了哪些任务 文字/口头描述:重写后端,完成了数据请求部分的后端. 展示GitHub当日代码/文档签入记录:(组内共 ...

  9. 第06组 Alpha冲刺(3/6)

    队名:拾光组 组长博客链接 作业博客链接 团队项目情况 燃尽图(组内共享) 组长:宋奕 过去两天完成了哪些任务 主要完成了用户论坛模块的接口设计 完善后端的信息处理 GitHub签入记录 接下来的计划 ...

  10. Java初级黄金体验 其二

    Java初级黄金体验 其二 引言:让我们看一下你的C盘有多少个文件和文件夹 初级 Java IO : 第一个纪念碑 小程序大致功能 让我们看一下E盘有多少个文件 上代码 最近太多的作业 代码可以无限改 ...