时间:2021-07-01 10:21:17 帮助过:10人阅读
1:资料参考
https://blog.csdn.net/coldljy/article/details/3168906
https://www.cnblogs.com/jwentest/p/8552075.html
https://www.cnblogs.com/ExMan/p/10396298.html
一:原理
Mysql-Proxy是一个处于你的client端和Mysql Server端之间的一个简单程序,它可以监测、分析和改变他们的通信。它使用灵活没有限制,常见的用途包括:负载平衡,故障、查询分析,查询过滤和修改等等。
Mysql -Proxy就是这么一个中间层代理,简单的说,Mysql-Proxy就是一个连接池,负责将前台应用的请求转发给后台数据库,并且通过使用lua脚本,可以实现复杂的连接控制和过滤,从而实现读写分离和负载平衡。对于应用来说,MySQL Proxy是完全透明的,应用则只需要连接到MySQL Proxy的监听端口即可。当然,这样proxy机器可能成为单点失效,但完全可以使用多个proxy机器做为冗余,在应用服务器的连接池配置中配置到多个proxy的连接参数即可。
mysql-proxy最基本的用法,就是作为一个请求拦截,请求中转的中间层:
根本上,mysql-proxy是一个官方提供的框架,具备良好的扩展性,可以用来完成:
sql拦截与修改
性能分析与监控
读写分离
请求路由
三:Mysql-Proxy安装
1、通过yum进行mysql数据库安装的时候,首先我们可以输入 yum list | grep mysql 命令来查看yum上提供的mysql数据库可下载的版本,查看mysql数据库数据库版本的时候,也顺便查看可用的mysql-proxy,图示就是我们想要的结果;
2:yum install mysql-proxy安装:
2.1:使用root用户安装mysql-proxy:执行命令:
yum install mysql-proxy
安装成功后会有提示安装成功
2.2:查看安装是否成功也可以执行命令:mysql-proxy -V;
查看mysql-proxy的相关信息
四:安装成功后进行mysql-proxy配置
5.3:服务启动成功后,用监控的ip和端口登陆mysql,做连接测试
执行命令:mysql -h配置代理地址
-P配置代理端口 -u数据库用户名 -p数据库密码
如图可连接成功
至此我们整个Mysql-Proxy代理的安装部署算是成功。部署过程中遇到很多问题,也列出来做下总结
五:整个安装部署以及使用过程中遇到的问题 按照如上配置,在执行脚本启动服务过程中遇到一些问题,整理出来给大家参考,提供一些解决思路,也作为记录 4.3.1: 问题1:执行脚本报错key file does not start with a group
解决:在vim /etc/mysql-proxy.cnf配置文件添加:[mysql-proxy]#这一行必须有否则报错
4.3.2:
问题2:通过代理的地址和端口登陆成功后会在短时间出现大量的连接错误host is blocked beause of many connections errors:unblock with "mysqladmin flush-hosts ",mysql-proxy连接后端mysql一直报错,达到mysql配置的最大错误次数,导致数据库把代理的ip和端口拉黑
4.3.2.1 :出现的现象
4.3.2.2:
排查过程:
首先查询mysql-proxy日志,日志路径见配置文件/var/log/mysql-proxy.log,打开日志文件
经过抓包分析是阿里云健康扫描导致的,需要将代理外网访问端口访问数据库的端口取消阿里云健康检查即可。mysql的tcp连接数也比较正常
总结:工作中平常就是使用到mysql ,对于一些功能操作了哪些库表测试一般是问开发,如何自己可以知晓呢?mysql的性能监控要怎么实现呢?首先是因为想要简化测试流程,有这个想法,搜索了下 ,有推荐这个工具,通过大概了解下原理觉得这个工作满足需求。然后开干。整个过程中因为阿里云健康检查排查过程用了挺久,也去咨询了运维同事。不过好在问题解决了。
下篇文件讲解mysql-proxy在测试过程中的实战运用。
【干货】Mysql的"事件探查器"-之Mysql-Proxy代理实战一(安装部署与实战sql拦截与性能监控)
标签:编辑 总结 哪些 良好的 代理 log mysq line 遇到的问题