小编给大家分享一下mysql中代理是什么意思,希望大家阅读完这篇文章后大所收获、下面让我们一起去探讨吧!
mysql代理是mysql官方提供的mysql中间件服务,上游可接入若干个【mysql客户机】,后端可连接若干个【mysql服务器】,【mysql-proxy】最基本的用法,就是作为一个请求拦截,请求中转的中间层。
引用><强> mysql代理的意思是:强>
<强> #背景强>
今天同事分享的主题就是mysql-proxy,于是下来自己了解下,不求精通,只求知道这个玩意
<强> #简介强>
mysql-proxy是mysql官方提供的mysql中间件服务,上游可接入若干个mysql客户机,后端可连接若干个mysql服务器。
它使用mysql协议,任何使用mysql客户机的上游无需修改任何代码,即可迁移至mysql-proxy上。
mysql-proxy最基本的用法,就是作为一个请求拦截,请求中转的中间层:
进一步的,mysql-proxy可以分析与修改请求。拦截查询和修改结果,需要通过编写Lua脚本来完成。
mysql-proxy允许用户指定Lua脚本对请求进行拦截,对请求进行分析与修改,它还允许用户指定Lua脚本对服务器的返回结果
进行修改,加入一些结果集或者去除一些结果集均可。
所以说,根本上,mysql-proxy是一个官方提供的框架,具备良好的扩展性,可以用来完成:
<李>
sql拦截与修改
李> <李>性能分析与监控
李> <李>读写分离
李> <李>请求路由
李><强> #用途强>
1。分享的同事使用代理的目的是,因为测试环境碰到了测试/开发同学不小心全表更新/删除操作,导致测试数据异常,从而影响项目进度,于是他接入mysql-proxy对sql语句进行了拦截检查,并可以将sql语句发送到DBA提供的一个sql检查服务中去判断sql语句是否有问题
2。之前还有这么一段经历,之前订单经过拆库操作,订单表分为了128个库,是根据订单号去拆库的,然而不是所有的表都有订单号(历史架构的锅),如有个需求是根据手机号码去查询订单号,导致要遍历查询128去判断是否存在,那么就需要代理介入,当时使用的是阿里的字符集中间件
<强> #不足强>
由于加入了一层代理会导致网络请求的增加消耗,所以性能造成一定的影响,
看完了这篇文章,相信你对mysql中代理是什么意思有了一定的了解,想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!
mysql中代理是什么意思