当前位置: 首页 > 图文教程 > 数据库 > MYSQL > mysql proxy问题的解决方法

MYSQL
MySQL 一次执行多条语句的实现及常见问题
mysql 常见命令和学习心得
mysql 发生系统错误1067的解决方法
MySQL 建表的优化策略 小结
批量替换 MySQL 指定字段中的字符串
mysql4.0升级到mysql5(4.1),解决字符集问题
MySQL 随机密码生成代码
Linux系统下配置功能完善的Web服务器
PHP+MYSQL实例:网站在线人数的代码
Perl直接入门详尽指南
PHP实例程序:直接读取数据库信息的三种方法
Apache、PHP和mySQL的配置的过程
新手学PHP和MySQL动态网站开发教程
优化mysql性能的十个参数
用相关数据库命令对MySQL进行优化
MYSQL执行SQL语句需要注意的两个问题
保护MySQL数据库中重要数据全攻略
Linux下配置 Tomcat+JDK+MySQL应用平台
数据从MySQL迁移到 Oracle的注意事项
快速掌握 MySQL数据库中触发器的应用

MYSQL 中的 mysql proxy问题的解决方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 81 ::
收藏到网摘: n/a

最近试用mysql proxy,遇到若干问题,好在一一找到了解决方案,列出来备忘。这次使用的版本是0.6.x,也许新版本就没有这些问题了。 无法通过mysql proxy连接mysql
在host,password正确的情况下,也会遇到无法连接mysql的情况,可以查查mysql server是不是使用了old_password,检查my.cnf里面是不是有
PLAIN TEXT
CODE:
复制代码 代码如下:

old_password = 1

有的数据库是从老版本升级上来的,所以会开启这个选项,mysql proxy不支持old_password。另外也可以通过查看密码长度的方式来判断:
PLAIN TEXT
CODE:
复制代码 代码如下:

select length(password) from mysql.user

如果长度为16位则是old_password无疑。
字符乱码
通过proxy连上数据库之后,查到的字符串始终是乱码,即便手工执行了set names 'utf8'也没有效果。
解决办法,mysql server必须设置
PLAIN TEXT
CODE:
复制代码 代码如下:

[mysqld]
skip-character-set-client-handshake
init-connect='SET NAMES utf8'
default-character-set=utf8

一台mysql slave当掉之后,mysql proxy会报错导致全部的mysql无法连接
安装了mysql proxy实现读写分离,有master x 1, slave x 2。为了测试failover,停掉了一个slave,然后mysql proxy会一直报错,提示无法连接。这个情况比单点的mysql还糟糕,挂掉一个就全挂掉!mysql的工程师给提供了一段代码,替换掉src/network-mysqld-proxy.c的NETWORK_MYSQLD_PLUGIN_PROTO函数可以解决这个问题。
代码比较长,直接附上下载地址: network-mysqld-proxy-function.c
定期crash
这个问题也很糟糕,mysql proxy经常会自己悄悄的停止工作,所幸时间间隔很长。猜想是有内存泄漏的问题存在,希望以后的版本能解决。
我采用的解决办法就是晚上定期重启它。