MySQL数据库创建线程的相关操作详解

数据库 MySQL
本文我们主要介绍了MySQL数据库创建线程的相关操作,包括线程创建函数以及服务器启动时执行的线程函数的相关知识,希望能够对您有所帮助。

MySQL数据库创建线程的相关操作是本文我们主要要介绍的内容,MySQL数据库中,为了提高系统效率,减少频繁创建线程和中止线程的系统消耗,MySQL使用了线程缓冲区的概念,即如果一个连接断开,则并不销毁承载其的线程,而是将此线程放入线程缓冲区,并处于挂起状态,当下一个新的Connection到来时,首先去线程缓冲区去查找是否有空闲的线程,如果有,则使用之,如果没有则新建线程。

1.线程创建函数

大家知道,Mysql现在是插件式的存储引擎,只要实现规定的接口,就可实现自己的存储引擎。故Mysql的线程创建除了出现在主服务器框架外,存储引擎也可能会进行线程的创建。通过设置断点,在我调试的版本中,发现了两个创建线程的函数。

pthread_create:Mysql自用的创建线程函数

os_thread_create:存储引擎innobase的创建线程的函数

os_thread_create是存储引擎innobase的线程函数,先搁浅不研究了,重点看下pthread_create,首先看下其源码。

  1. int pthread_create(pthread_t *thread_id, pthread_attr_t *attr,  
  2. pthread_handler func, void *param)  
  3. {  
  4. HANDLE hThread;  
  5. struct pthread_map *map;  
  6. DBUG_ENTER("pthread_create");  
  7. if (!(map=malloc(sizeof(*map))))  
  8. DBUG_RETURN(-1);  
  9. map->funcfunc=func; map->paramparam=param;  
  10. pthread_mutex_lock(&THR_LOCK_thread);  
  11. #ifdef __BORLANDC__  
  12. hThread=(HANDLE)_beginthread((void(_USERENTRY *)(void *)) pthread_start,  
  13. attr->dwStackSize ? attr->dwStackSize :  
  14. 65535, (void*) map);  
  15. #else  
  16. hThread=(HANDLE)_beginthread((void( __cdecl *)(void *)) pthread_start, attr->dwStackSize ? attr->dwStackSize : 65535, (void*) map);  
  17. #endif  
  18. DBUG_PRINT("info", ("hThread=%lu",(long) hThread));  
  19. *thread_id=map->pthreadself=hThread;  
  20. pthread_mutex_unlock(&THR_LOCK_thread);  
  21. if (hThread == (HANDLE) -1)  
  22. {  
  23. int error=errno;  
  24. DBUG_PRINT("error",  
  25. ("Can't create thread to handle request (error %d)",error));  
  26. DBUG_RETURN(error ? error : -1);  
  27. }  
  28. VOID(SetThreadPriority(hThread, attr->priority)) ;  
  29. DBUG_RETURN(0);  

上面代码首先构造了一个map结构体,成员分别是函数地址和传入参数。然后调用操作系统的接口,_beginthread,但是执行函数并不是传入的函数——func,而是pthread_start,参数为map。继续跟踪pthread_start。

  1. pthread_handler_t pthread_start(void *param)  
  2. {  
  3. pthread_handler  
  4. func=((struct pthread_map *) param)->func  
  5. void *func_param=((struct pthread_map *) param)->param;  
  6. my_thread_init();         /* Will always succeed in windows */  
  7. pthread_mutex_lock(&THR_LOCK_thread);   /* Wait for beginthread to return */  
  8. win_pthread_self=((struct pthread_map *) param)->pthreadself;  
  9. pthread_mutex_unlock(&THR_LOCK_thread);  
  10. free((char*) param);            /* Free param from create */  
  11. pthread_exit((void*) (*func)(func_param));  
  12. return 0;               /* Safety */  

可以看出,pthread_start中调用了map的func元素,作为真正执行的函数体。OK,创建线程的函数跟踪到此!

2.服务器启动时创建了哪些函数?

通过在两个创建线程的地方设置断点,总结了下,在服务器启动时,创建了如下的线程。

pthread_create创建的线程:

创建线程函数 线程执行函数

create_shutdown_thread

handle_shutdown

start_handle_manager

handle_manager

handle_connections_methods

handle_connections_sockets

innobase的os_thread_create创建的线程:

创建线程函数 线程执行函数

innobase_start_or_create_for_mysql

io_handler_thread(4个)

recv_recovery_from_checkpoint_finish

trx_rollback_or_clean_all_without_sess

innobase_start_or_create_for_mysql

srv_lock_timeout_thread

 

srv_error_monitor_thread

 

srv_monitor_thread

 

srv_master_thread

还可以在调试过程中,通过暂停来看此时服务器中的线程,如下图:

MySQL数据库创建线程的相关操作详解

关于MySQL数据库创建线程的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. 如何检查MySQL数据库的主从延时?
  2. MySQL数据库时间类型的物理存储
  3. Linux cron执行MySQL失败的问题解决方案
  4. PHP与MySQL数据库中排序的对比及使用条件详解
  5. MySQL性能优化之使用Limit关键字来避免全表扫描
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-08-30 14:25:06

QT数据库

2011-09-01 10:56:34

2011-08-30 12:51:19

MySQL线程缓冲池

2011-08-24 17:08:28

Oracle数据库归档模式

2009-09-07 15:25:24

MySQL数据库互操作Silverlight

2011-08-18 17:05:16

Oracle数据库的服

2024-04-03 00:06:03

2010-05-31 17:18:39

Cassandra数据

2021-03-18 08:20:19

SQLServer数据库SQL

2011-04-11 13:19:41

Oracle数据库

2014-11-05 10:37:44

Windows Pho数据库

2011-04-19 11:02:57

数据库分页

2010-05-31 12:10:37

2010-05-28 14:51:47

MySQL数据库

2011-08-02 17:06:29

Oracle远程数据库创建DB Link

2010-05-31 15:12:44

MySQL数据库

2022-03-29 10:52:08

MySQL数据库

2010-03-29 10:19:24

2011-03-30 13:44:45

MySQL数据库锁机制

2010-06-01 12:51:23

MySQL数据库
点赞
收藏

51CTO技术栈公众号