mysql "Writing to net"

1.版本

1)操作系统

cat /etc/issue
CentOS release 6.6 (Final)
Kernel \r on an \m

cat /proc/version
Linux version 2.6.32-504.el6.x86_64 (mockbuild@c6b9.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) ) #1 SMP Wed Oct 15 04:27:16 UTC 2014

2)mysql数据库版本

MySQL --version
MySQL  Ver 14.14 Distrib 5.6.26, for linux-glibc2.5 (x86_64) using  EditLine wrapper


2.问题描述

2.1 发现问题

  今天研发的兄弟说,他们有一个sql执行的非常慢(20多秒),让我帮忙优化一下。我就把他们给的sql到生产服务器的备库上跑了一下,发现非常快(0.3秒)。然后我又拿到主库跑了一下也是零点几秒。这是怎么回事?

3.分析问题

   检查slowlog发现确实有这个语句执行了20多秒的记录。然后我在自己的本地通过navicat执行该语句发现也需要20多秒,在执行的过程中show processlist发现该线程状态为"Writing to net"


"Writing to net"   >>It means just what it says--MySQL is writing data to the network socket. 

      出现"Writing to net"的原因有1. 返回结果集太大,并且网络负载较大 2.max_allowed_packet参数设置过小。研发的sql结果集很大有15万,而本地navicat和生产服务器间的通信需要通过多层路由,所以出现该现象。应用服务器和数据库服务器在同一个机房他们之间的通信只需要通过交换机,所以在应用服务器执行sql不会出现长时间处在"Writing to net"状态的现象


4.解决方案

      1.结合应用考虑是否有必要一次返回如此大的结果集,尽可能返回少量数据

      2.应用服务器如果同数据库服务器在同一个机房中,通信只需要通过交换机,也不会出现这种问题。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

渔夫数据库笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值