我的编程空间,编程开发者的网络收藏夹
学习永远不晚

1. select语句执行过程-网络通信

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

1. select语句执行过程-网络通信

1. select语句执行过程-网络通信

执行过程图

执行过程

网络通信

MySQL 是支持多种通信协议的,可以使用同步/异步的方式,支持长连接/短连接。

1.同步/异步

异步的问题

  • 异步可以避免应用阻塞等待,但是不能节省 SQL 执行的时间。
  • 如果异步存在并发,每一个 SQL 的执行都要单独建立一个连接,避免数据混乱。线程的上下文切换,会增加服务器压力
  • 增加编程复杂度

默认是同步,即客户端需要等mysql服务器的响应,也是符合大多数情况的。

2. 长连接/短连接

短连接就是操作完毕以后,马上 close 掉。长连接可以保持打开,减少服务端创建和释放连接的消耗,后面的程序访问的时候还可以使用这个连接。一般我们会在连接池中使用长连接。

相关命令

2.1.查询连接超时时间

show global variables like "wait_timeout"; -- 非交互式超时时间, 如 JDBC 程序
show global variables like "interactive_timeout"; -- 交互式超时时间, 如数据库工具

默认都是 28800 秒,8 小时。

2.2.查询和设置连接状态

2.2.1 查询连接状态
show global status like "Thread%";
+-------------------+-------+
| Variable_name     | Value |
+-------------------+-------+
| Threads_cached    | 649   |  <—当前被缓存的空闲线程的数量
| Threads_connected | 93    | <—正在使用(处于连接状态)的线程
| Threads_created   | 742   |  <—服务启动以来,创建了多少个线程
| Threads_running   | 5     | <—正在忙的线程(正在查询数据,传输数据等等操作)
+-------------------+-------+
2.2.2 查看开机起来数据库被连接了多少次
show status like "%connections%";
show global status like "%connections%";
+-----------------------------------+---------------------+
| Variable_name                     | Value               |
+-----------------------------------+---------------------+
| Connection_errors_max_connections | 0                   |
| Connections                       | 101395055           |   <–服务启动以来,历史连接数
| Max_used_connections              | 742                 |
| Max_used_connections_time         | 2018-08-21 15:42:38 |
+-----------------------------------+---------------------+
2.2.3 设置thread_cache_size

通过连接线程池的命中率来判断设置值thread_cache_size是否合适, 命中率超过90%以上,设定合理。 (Connections - Threads_created) / Connections * 100 %>=90%

2.3 查询执行状态

 SHOW PROCESSLIST;

2.4查询和设置最大连接数

查看配置

show variables like "max_connections";

在 5.7 版本中默认是 151 个,最大可以设置成 16384(2^14)。

设置配置

set global max_connections = 1000;

3.通信协议

1.Unix Socket。

2. TCP/IP

mysql -h192.168.8.211 -uroot -p123456

我 们 的 编 程 语 言 的 连 接 模 块 都 是 用 TCP 协 议 连 接 到 MySQL 服 务 器 的 , 比 如 mysql-connector-java-x.x.xx.jar。

3. 命名管道(Named Pipes)

4. 内存共享(Share Memory)

这两种通信方式只能在 Windows 上面使用,一般用得比较少。

4.通信方式

  • 单工: 在两台计算机通信的时候,数据的传输是单向的。生活中的类比:遥控器。
  • 半双工: 在两台计算机之间,数据传输是双向的,你可以给我发送,我也可以给你发送, 但是在这个通讯连接里面,同一时间只能有一台服务器在发送数据,也就是你要给我发 的话,也必须等我发给你完了之后才能给我发。生活中的类比:对讲机。
  • 全双工: 数据的传输是双向的,并且可以同时传输。生活中的类比:打电话。 MySQL采用半双工方式

SQL命令一次性发送

客户端发送 SQL 语句给服务端的时候,(在一次连接里面)数据是不能分成小块发送的,不管你的 SQL 语句有多大,都是一次性发送 比如我们用 MyBatis 动态 SQL 生成了一个批量插入的语句,插入 10 万条数据,values后面跟了一长串的内容,或者 where 条件 in 里面的值太多,会出现问题。 相关配置max_allowed_packet,默认4M

执行结果一次性发送

服务端来说,也是一次性发送所有的数据,不能因为你已经取到了想要的数据就中断操作,这个时候会对网络和内存产生大量消耗

#参考资料 1.https://mp.weixin.qq.com/s/PEk97JyIlUexuAjFr2pmiw

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

1. select语句执行过程-网络通信

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

1. select语句执行过程-网络通信

执行过程图网络通信MySQL 是支持多种通信协议的,可以使用同步/异步的方式,支持长连接/短连接。1.同步/异步异步的问题异步可以避免应用阻塞等待,但是不能节省 SQL 执行的时间。如果异步存在并发,每一个 SQL 的执行都要单独建立一个连接,避免数据混乱。线
1. select语句执行过程-网络通信
2015-06-19

3. select语句执行过程-优化器

1.有哪些2.开启追踪优化器追踪默认是关闭的2.1 开启SHOW VARIABLES LIKE "optimizer_trace";set optimizer_trace="enabled=on";2.2 执行一个sql后查询计划select * from i
3. select语句执行过程-优化器
2019-02-28

2 select语句执行过程-缓存& 语法解析和预处理(Parser & Preprocessor)

1.缓存MySQL 的缓存默认是关闭的,8.0直接去掉了缓存模块show variables like "query_cache%"2.语法解析从这个最简单的sql语句说起select name from user_info where id = 1; and
2 select语句执行过程-缓存& 语法解析和预处理(Parser & Preprocessor)
2015-12-23

编程热搜

目录