• 1
  • 2
  • 3
  • 4
  • 5
mysql数据库问题 首 页  »  帮助中心  »  数据库  »  mysql数据库问题
分析MySQL服务器的连接过程
发布日期:2016-4-16 17:4:17

  分析MySQL服务器的连接过程

  mysqld是MySQL服务器端主进程,mysqld是MySQL的真正核心也不为过,一切工作都是围绕mysqld进程进行的。因此要分析mysql这个庞然大物,mysqld的代码则是最好的突破口。

  一切都是从熟悉的main()函数开始的,实际上是从mysqld_main()函数开始的。这些代码都在mysqld.cc。mysqld_main()随后调用了win_main)()。win_main()函数,目的是为了做了一些初始化的工作。

  初始化工作完成了之后,MySQL已经做好准备来接受连接了。然后开始用Handle_connections_methods()函数了。这个函数的主要工作为:

  • 新建3个子进程
  • 这3个子进程分别接受TCP/IP、命名管道和共享内存这三种方式的连接。

一般情况下客户都是用TCP/IP(socket)来连接MySQL服务器的,这种通信方式是最有弹性的。但在嵌入式软件的应用环境中,需要采用后面这两种通信方式。

  简化后的handle_connections_methods()函数,代码如图1所示:


 图1

  新建了3个线程之后,handle_connectins_methods()函数将进入一个长时间循环,直到3个连接线程全部退出后,它才退出。在这里主要看socket的连接线程,这个handle_connections_sockets_thread就是我们的研究对象。这个线程把自己初始化之后,就直接调用了handle_connections_sockets()函数;

  handle_connections_sockets()函数使用select()调用监听mysqld的端口,接着等待客户端的连接。等到一个客户端连接后,这个函数中会新建一个THD类型的变量,这个变量从连接建立开始,到SQL语法分析、查询执行、结果返回等等。这个变量一直都在,总之这是一个非常重要的变量。

  还有struct st_vio这个结构体,这个结构体是一个命令的中转站。在THD中也定义了一个vio类型的结构体。这个结构体的功能为从储存从套接字中读取通信内容,接着又把自己的值赋给THD的vio变量。VIO类型中详细的描述了一次请求,包括:

  • 请求的内容
  • 时间
  • 请求的套接字地址

之后发生的事情就是把这个THD类型的变量传递到服务线程,create_thread_to_handle_connection()实现这个功能。

  删减后的代码如图2所示


 图2

  这个函数会查看有没有闲置的缓存线程(MySQL没有把断开连接后的服务线程立即销毁掉,而是缓存了起来),若有就是用缓存线程,如果没有就新建一个线程来服务连接。到这里,一个连接就进入了服务线程,连接线程返回继续等待连接。

  后边的内容就都是在服务线程中实现的,《深入理解MySQL》中有很详细的代码跟踪,感兴趣的同学可以看看。我把函数调用顺序附上,供参考。

程序如图3所示

 图3