Mysql中怎么读写分离,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在Mysql中读写分离实际上就是让主数据库处理主动写操作,让从数据库处理主动读操作。我们可以使用mysql-proxy中间件实现Mysql的读写分离,mysql-proxy在这里是作为什么角色呢?实际上我们可以将mysql-proxy理解为一个主从数据库之间的代理,它负责接受客户端的请求,然后判断请求SQL是属于写操作还是读操作,如果属于读操作则转发给从数据库处理请求,如果处于写操作则转发给主数据库处理请求。
实现Mysql读写分离
其实实现Mysql读写分离最简单的方案就是开启主从同步,在后端配置主数据库的连接和从数据库的连接,如果需要处理更新数据操作,就是用主数据库连接完成更新操作,如果只是select查询数据,则使用从数据库连接从从数据库获取数据。但是通过代码来管理连接不同的主从数据库太过于繁琐了,所以Mysql提供了官方的中间件mysql-proxy实现代理,客户端只需要请求mysql-proxy的连接池取到一个连接,至于根据读写操作来选择不同的主从数据库这些工作就只需要交给mysql-proxy来处理就可以了。所以本篇文章重点介绍如何使用mysql-proxy来实现Mysql的读写分离。
lua安装
–proxy-read-only-backend-addresses:配置只读从数据库–proxy-backend-addresses:配置主服务器–proxy-lua-script:rw-splitting.lua脚本路径&:表示后台执行mysql-proxy。–log-file:日志文件存放路径可以看到查出来的数据是从数据 香港云主机库的数据,因为结果只有一条,如果来自于主数据库应该有我们刚才新插入的三条数据,所以可以证明我们的读操作分离也成功了,到这里我们主从同步和读写分离全部配置成功,我们在项目中就可以使用这个4040端口的root用户来代理数据库操作,如果是写操作则代理到主数据库去执行,如果属于读操作则代理到从数据库去执行,实现Mysql读写分离。mysql-proxy执行流程简析我们这里测试是为了方便采取一主一从的架构去测试,但是很多时候后端Mysql服务不止一个,我们最后来大致了解下mysql-proxy的工作流程:实际上客户端向mysql-proxy发起连接时会调用connect_server()函数,如果没有实现这个函数,则mysql-proxy默认使用轮询方式找到合适的客户端代理请求给客户端。用户进行账号权限验证时传递账号密码等信息,mysql-proxy会调用read_auth()函数,当后端mysql服务向mysql-proxy认证结果时,mysql-proxy则会调用read_auth_result()然后给客户端返回认证结果。认证成功。客户端每次发起请求mysql-proxy都会调用read_query()来处理中间具体转发的业务逻辑,然后在后端mysql服务向mysql-proxy传递查询结果时,调用read_query_result()对结果集进行一系列处理,最后将结果集返回给客户端。关于Mysql中怎么读写分离问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注开发云行业资讯频道了解更多相关知识。
这篇文章主要介绍了JASP0.12版本增加了哪些功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JASP0.12版本增加了哪些功能文章都会有所收获,下面我们一起来看看吧。关于“JASP0.12版本增加了哪些功能” 香港云主机这篇…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。