MySQL8.0.11源码分析之mysqld关键函数和执行流程

本文详细分析了MySQL8.0.11版本中mysqld的关键函数及其执行流程。从Linux下的入口函数开始,描述了如何通过连接接受器循环接收客户端连接,处理新连接,并在没有空闲线程时创建新线程以处理这些连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysqld是SQL后台程序(即MySQL服务器)。要想使用客户端程序,该程序必须运行,因为客户端通过连接服务器来访问数据库。

//Linux下入口函数

int mysqld_main(int argc, char **argv){

    ...... //初始化操作

    //循环连接

    mysqld_socket_acceptor->connection_event_loop();  

    ......//结束操作

}

 

//连接接受器循环以接受来自客户端的连接

void connection_event_loop() {

    //初始化连接句柄
    Connection_handler_manager *mgr = Connection_handler_manager::get_instance();  

     while (!connection_events_loop_aborted()) {  

         //监听连接事件

         Channel_info *channel_info = m_listener->listen_for_connection_event();        

         //处理一个新的连接

         if (channel_info != NULL) 
            mgr->process_new_connection(channel_info);     

    }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值