MySQL远程访问速度缓慢的解决和分析

在RHEL5.4环境下配置MySQL时遇到国外节点访问延迟的问题,通过检查和调整skip_name_resolve参数,成功优化了网络访问速度。本文详细介绍了排查过程和解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境介绍:
OS:RHEL5.4
MySQL:5.5.10
异常情景:
数据库一直处于机房内网中访问和使用,一天一个国外节点需要访问数据库,开通访问权限后,他们反馈很慢;
随即在防火墙上,开通自己公司IP进行访问,也有类似问题!
开始排错原因:
1.检查网络是否稳定?得到答案,ping ttl值很稳定,ssh也正常;
2.检查MySQL运行状态,无异常发现;
3.突然想起了,MySQL利用DNS做解析的参数有可能在规划时,没有做设置!!!
解决办法:
1.验证参数
mysql> show variables like 'skip_%';
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| skip_external_locking | ON    |
| skip_name_resolve     | OFF   |
| skip_networking       | OFF   |
| skip_show_database    | OFF   |
+-----------------------+-------+
4 rows in set (0.00 sec)
mysql> show variables like 'skip_%';
2.停库,修改my.cnf里面参数
[mysqld]
skip_name_resolve
3.重启数据库后验证:
mysql> show variables like 'skip_%';
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| skip_external_locking | ON    |
| skip_name_resolve     | ON    |
| skip_networking       | OFF   |
| skip_show_database    | OFF   |
+-----------------------+-------+
4 rows in set (0.03 sec)
该选项用于禁用DNS解析,连接速度会快很多。不过,这样就不能在MySQL的授权表中使用主机名而只能用ip地址。


参考知识点整理:
mysqld参数整理http://dev.mysql.com/doc/refman/5.5/en/mysqld-option-tables.html
skip-name-resolve参数介绍1:http://dev.mysql.com/doc/refman/5.5/en/server-options.html#option_mysqld_skip-name-resolve
skip-name-resolve参数介绍2:http://dev.mysql.com/doc/refman/5.5/en/server-system-variables.html#sysvar_skip_name_resolve
host-cache参数介绍:http://dev.mysql.com/doc/refman/5.5/en/host-cache.html
还有一种方法:在源代码中增加HOST_CACHE_SIZE定义(默认值:128)并重新编译MySQLd来提高性能{暂时未测试}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值