• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mysql的启动过程详解

mysql的启动过程详解

作者:yzyangwanfu 字体:[增加 减小] 来源:互联网 时间:2017-05-11

yzyangwanfu通过本文主要向大家介绍了mysql存储过程详解,mysql详解,mysql数据类型详解,mysql配置文件详解,mysql explain详解等相关知识,希望本文的分享对您有所帮助

有一天,两个不懂mysql内核的人想去了解mysql内核代码,两个人不是去调试代码、查找资料,而是在那边思考。因为不了解内核,所以边思考边去验证。
 
使用的mysql代码是5.1.7,调试环境是windows平台下的vs2003。
 
Bingxi:“alex,你觉得mysql的启动过程会是什么样的呢?我们以银行为例吧。”
Alex:“嗯,bingxi。早上银行开门了,会先准备好环境,然后开门迎客,mysql也是这样。Mysql里面会有一个handle_connections_sockets函数,这个函数就好比是个叫号机,每个用户来了都会取个号,然后就会进行业务处理。”
{
  ……
  while (!abort_loop)
  {
    select((int) max_used_connection,&readFDs,0,0,0) < 0) //有连接了则往下来执行,否则一直等待
    ……
    accept(sock, my_reinterpret_cast(struct sockaddr *) (&cAddr),&length)  //接受请求
    ……
    create_new_thread(thd);
  }
  //abort_loop=1,则执行到这里进行推出。今天业务不处理了
}
</div>
Bingxi:“啊,这里面存在两种可能的,1)用户来一个就分配一个工作人员处理,2)将排号的人丢进工作队列,根据叫号机到指定窗口获取服务。前者的场景适合于请求量大,并且需要响应速度特别快的情况,但是分配也会有个限制,所谓的最大连接数,这样的情况常见于互联网行业,相应地我们可以看到机器的负载变化范围特别大。同样的,这也是它的一个弊端,假设每个业务都复杂(消耗资源型sql语句),同时处理的话,机器会支撑不住,这时候第二种方法就比较好,这种情况属于事务性场景。”

Alex:“嗯,是的。Mysql选择的是前者,oracle提供两种方法供选择。我们继续往下面的代码看,如果我们配置了线程缓存,且有可用的缓存,则唤醒该线程,否则创建新的线程。”
static void create_new_thread(THD *thd)
{
 
    if (cached_thread_count > wake_thread)
    {
      start_cached_thread(thd);
    }
    else
    {
      if ((error=pthread_create(&thd->real_id,&connection_attrib,
                            handle_one_connection,
                            (void*) thd)))
  }
}
</div>
Bingxi:“嗯,老杨。是不是理解银行为客户分配了一个服务人员,在这段期间一直为该客户服务。里面有个代码段,是一直在等用户下命令。但是有可能网络,或者被kill掉了,就像一个人存了100,不断取1块钱一样,被保安带走了。”
pthread_handler_t handle_one_connection(void *arg)
{
    while (!net->error && net->vio != 0 &&
           !(thd->killed == THD::KILL_CONNECTION))
    {
      net->no_send_error= 0;
      if (do_command(thd))
       break;
    }
}
</div>
Alex:“嗯,获取命令,然后执行命令。在dispatch_command函数中,根据不同的客户请求进行响应的处理,比如开账户、存钱等”
bool do_command(THD *thd)
{
 
  if ((packet_length=my_net_read(net)) == packet_error) //获取命令
 
  DBUG_RETURN(dispatch_command(command,thd, packet+1, (uint) packet_length));
}
</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 深入mysql存储过程中表名使用参数传入的详解
  • 深入mysql创建自定义函数与存储过程的详解
  • 关于MYSQL的优化全面详解
  • mysql的启动过程详解
  • MySQL关闭过程详解和安全关闭MySQL的方法
  • MySQL的表分区详解
  • MySQL存储过程使用实例详解
  • MySql日期查询语句详解

相关文章

  • 2018-12-05关于MySQL数据库 增删改查语句集锦
  • 2018-12-05详解innodb_index_stats导入数据时提示表主键冲突的错误
  • 2018-12-05解析MySQL按常规排序、自定义排序和按中文拼音字母排序的方法
  • 2018-12-05数据库的用户帐号管理基础知识
  • 2018-12-05sqlserver下Kill 所有连接到某一数据库的连接
  • 2017-05-11replace MYSQL字符替换函数sql语句分享(正则判断)
  • 2017-05-11Mysql如何避免全表扫描的方法
  • 2018-12-05MSSQL SERVER中的BETWEEN AND的使用
  • 2018-12-05Mysql优化之MySQL慢查询操作介绍
  • 2017-05-11MySql like模糊查询通配符使用详细介绍

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql 关键词相关度排序方法详细示例分析
    • Window下Mysql忘记root密码怎么重置的图文详细介绍
    • MySQL DBA 常用手册小结
    • 教你设计大型Oracle数据库
    • mysql创建外键时遇到的错误
    • 如何在SQLSERVER中快速有条件删除海量数据
    • mysql 字符串函数收集比较全
    • MySQl在开发和生产不同环境下的索引对比
    • 基于MySQL数据库复制Master-Slave架构的分析
    • 每个分类取最新的几条的SQL实现代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有