mysql-proxy原理与使用浅析(一)

为什么要使用 MySQL-Proxy 呢? MySQL-Proxy 能带来什么样的好处?我们先来看一下正常的 MySQL 通信流程:

很显然,我们可以在这些流程中间加入一个中间人,由它来将这些请求转发,接下来我们看一下如果加入一个中间人( MySQL-Proxy )的情况下,流程会变成什么样子,以及这种变化会带给我们什么样的好处。

上图中红线部分都表示 MySQL-Proxy 可能篡改的地方。而 proxy_xxx 方法表示 MySQL-Proxy 可以拦截并提供给使用者进行篡改的途径。事实上 MySQL-Proxy 使用了 LUA 来作为它的胶水语言,同时提供了 connect_server, read_handshake, read_auth, read_authresult, read_query, read_query_result, disconnect_client 几种方法,分别对应上图中 proxy_xxx 的方法,如果 lua 的脚本里没有提供这些方法的话,那么就会采用 proxy_xxx 里定义默认实现。

那么为什么 MySQL-Proxy 采用 LUA 来作为胶水语言呢?因为 LUA 语言本身从设计上就是一个支持扩展性,并且使用简单,效率极高同时支持多种平台的语言。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值