MySQL教程之Windows 7/8下连接本地MySQL慢的问题解析_本地MySQL延迟问题排查
扫描二维码随身看资讯
使用手机 二维码应用 扫描右侧二维码,您可以
1. 在手机上细细品读~
2. 分享给您的微信好友或朋友圈~
绿色资源网小编:最近本地调试网站的时候个别程序如phpcms一直出现这个问题,速度异常慢,偶尔发现下面的文章,才提醒了我,原来问题这样的。。。
最近在windows上开发应用的时候发现一个有趣的问题:我的本地程序连接本地mysql库居然要延迟1秒钟左右才能打开。
问题分析
考虑到可能是程序性能问题后,我使用了xdebug的性能日志功能输出程序运行日志后发现连接mysql的函数时间居然用掉了接近95%的执行时间。
确认是mysql性能问题后,考虑是mysql的域名反查功能影响了速度,令我失望的是,在my.ini里面关闭域名反查后问题依旧存在。
百思不得其解时我突发奇想将代码中的服务器的地址从localhost修改为了127.0.0.1,那个神奇的1秒钟延迟居然消失了。
换成ip后居然就好了,难道是localhost存在啥蹊跷?打开cmd,输入ping localhost,ping输出的结果让我十分惊讶:

没错,localhost 出来的是 ipv6 地址 ::1,那么这一秒延迟的原因也很容易理解了,使用localhost连接,程序解析出来的地址是ipv6地址::1,然后去尝试连接监听这个地址的mysql, 而显然的是mysql监听的是ipv4地址127.0.0.1, ipv6连不上超时后会再去连接ipv4地址127.0.0.1, 这就是这个1秒钟延迟出现的原因。
打开windows的hosts文件,你会看到下面的注释
# localhost name resolution is handled within DNS itself.
# 127.0.0.1 localhost
# ::1 localhost
解决方法
方案1. 使用127.0.0.1而不是localhost去连接mysql。
方案2. 编辑hosts文件强制将127.0.0.1绑定在localhost。
- SQL Server服务启动停止_SQL Server 2005故障排除
- SQL Server 2005 版本号查询方法_SQL Server 版本信息获取
- 超详细的SQL Server 2005图解安装全过程_SQL Server 2005安装教程
- MySQL数据库的自动备份与数据库被破坏后的恢复_数据库恢复与安全
- Oracle数据库中去除重复数据解决方案_数据去重方法
- SQL SERVER 2005 数据导入图文教程_Microsoft SQL Server Management Studio 导入数据
- Windows 7 下 SQL Server 2008 Express 安装故障排除指南_SQL Server 2008 Express 安装成功技巧
- SQL Server版本号查看_SQL Server版本查询方法
- Win7安装MySQL 5.5.21图解教程_MySQL乱码解决
- MySQL删除PID文件后无法启动问题解决方案_MySQL PID文件处理指南
- MySQL数据库远程连接实现方法_远程访问MySQL指南
- Oracle 18008 错误 解决方案_ORA-18008 OUTLN Schema 错误排查
- 1 Navicat 8数据库创建与数据导入_Navicat 8用户权限管理
- 2 MS SQL Server 2008数据库同步备份_SQL Server 2008复制
- 3 MySQL数据库的自动备份与数据库被破坏后的恢复_数据库恢复与安全
- 4 SQL Server 2008 安装问题_SQL Server 2005 Express 解决方案
- 5 SQL Server 2008备份恢复技巧_SQL Server 2008数据库恢复最佳实践
- 6 MySQL数据库常用命令学习指南_MySQL数据库实用学习资料之常用命令集合
- 7 MySQL教程之Windows 7/8下连接本地MySQL慢的问题解析_本地MySQL延迟问题排查
- 8 MySQL删除PID文件后无法启动问题解决方案_MySQL PID文件处理指南
- 9 快速让MySQL数据库服务器支持远程连接_MySQL远程连接指南
- 10 安装Sql Server 2000时提示“安装Sql挂起”的解决方案_Sql Server安装故障排除指南
-
Win7安装MySQL 5.5.21图解教程_MySQL乱码解决
大家都知道MySQL是一款中、小型关系型数据库管理系统,很具有实用
-
Navicat 8数据库创建与数据导入_Navicat 8用户权限管理
navicat 8_创建数据库_导入数据_用户权限
-
MS SQL中收缩数据库日志的方法_数据库日志清理指南
在MS SQL 中经常会造成 xxxx_log.ldf 超级大的情况通通是几十个G
-
快速让MySQL数据库服务器支持远程连接_MySQL远程连接指南
在CentOS上安装MySQL数据库服务器后,系统出于安全性考虑,缺省不支


