阿里云mysql读写分离实现_MySQL-Proxy实现MySQL读写分离

阿里云mysql读写分离实现_MySQL-Proxy实现MySQL读写分离要实现读写分离,需要先有搭建MySQL的主从环境介绍master192.168.133.128slave192.168.133.132proxy192.168.133.130首先在mysql-proxy上安装依赖包yum-yinstallgccgcc-c++autoconflibevent-develpkgconfiglibtoolmysql-devellibterm…

大家好,又见面了,我是你们的朋友全栈君。

要实现读写分离,需要先有搭建MySQL的主从

环境介绍

master 192.168.133.128

slave 192.168.133.132

proxy 192.168.133.130

首先在 mysql-proxy 上安装依赖包

yum -y install gcc gcc-c++ autoconf libevent-devel pkgconfig libtool mysql-devel libtermcap-devel ncurses-devel readline-devel

安装 glib-2.22.5.tar.gz

tar zxf glib-2.22.5.tar.gz

cd glib-2.22.5

./configure –prefix=/usr/local/glib-2.22.5

make && make install

安装 lua-5.1.4.tar.gz

tar zxf lua-5.1.4.tar.gz

cd lua-5.1.4

vim Makefile

87eef372e8cb17cde9132d7afd17542a.png

vim src/Makefile

92ee902785d8883cee50f7217172ef1e.png       # 64位系统需要更改,要不然会报错

make linux install

echo $?#检查一下是否正确安装了

创建 pkgconfig 目录,并将 lua.pc 拷贝过去

mkdir /usr/local/lua-5.1.4/lib/pkgconfig

cp /root/lua-5.1.4/etc/lua.pc /usr/local/lua-5.1.4/lib/pkgconfig/

修改刚才的 lua-5.1.4 中的安装路径

vim /usr/local/lua-5.1.4/lib/pkgconfig/lua.pc

b334ffdfe20a92615ac34b1d874d7112.png

添加环境变量

export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/glib-2.22.5/lib/pkgconfig/:/usr/local/lua-5.1.4/lib/pkgconfig/

# 这个 PKG_CONFIG_PATH 不懂,还希望各位大牛给讲讲啊

开始安装 mysql-proxy

mkdir /application         #先创建一个安装目录

tar zxf mysql-proxy-0.8.2.tar.gz

cd mysql-proxy-0.8.2

./configure –prefix=/application/mysql-proxy-0.8.2

make && make install

创建一个软连接,并拷贝 rw-splitting.lua 脚本,它是真正负责真正的读写分离

ln -s /application/mysql-proxy-0.8.2/ /application/mysql-proxy

cp /root/mysql-proxy-0.8.2/lib/rw-splitting.lua /application/mysql-proxy/lib/mysql-proxy/lua/

并在刚才创建的软连接中新建 conf 和 logs 的目录

mkdir /application/mysql-proxy/conf

mkdir /application/mysql-proxy/logs

在 /application/mysql-proxy/conf 目录中新建 mysql-proxy.conf 文件,内容如下

vim /application/mysql-proxy/conf/mysql-proxy.cnf

[mysql-proxy]

plugins=admin,proxy#这个参数很重要,如果开启就没有4041端口啊

admin-username=admin

admin-password=admin

admin-lua-script=/application/mysql-proxy/lib/mysql-proxy/lua/admin.lua

proxy-backend-addresses=192.168.133.128:3306#读写库

proxy-read-only-backend-addresses=192.168.133.132:3306#只读库

proxy-lua-script=/application/mysql-proxy/lib/mysql-proxy/lua/rw-splitting.lua#读写分离的脚本

log-file=/application/mysql-proxy/logs/proxy.log

log-level=debug

daemon=true

keepalive=true

修改 mysql-proxy.conf 的文件权限

chmod 0600 /application/mysql-proxy/conf/mysql-proxy.cnf

启动 mysql-proxy 并放入后台启动

/application/mysql-proxy/bin/mysql-proxy –defaults-file=/application/mysql-proxy/conf/mysql-proxy.cnf &

通过 netstat 检查 proxy 的端口是否开启

netstat -tlunp

141ab56c2d833ba8283d587fdba4bf79.png

到此为止,mysql-proxy 实现读写分离已经完成,现在进行读写分离测试

读写分离测试

编辑 rw-splitting.lua 文件,真实环境当然就不需要修改了,测试环境还是该一下吧,硬件不给力啊。哈哈

vim /application/mysql-proxy/lib/mysql-proxy/lua/rw-splitting.lua

6d501cac02c3d57e848ef0a6e7d07d25.png

重启 mysql-proxy 服务,也可以通过脚本放入 /etc/init.d 下,这里先简单一下吧

killall mysql-proxy   # 多杀几遍

/application/mysql-proxy/bin/mysql-proxy –defaults-file=/application/mysql-proxy/conf/mysql-proxy.cnf &

在 Master 上创建 testyuci 数据库,并在 slave 上查看是否已经同步

create database testyuci;

816fff09b1f53258967091e0bd2468a8.png

在 slave 上查看

show databases;

4c2bc91435f23408baca0004c5cd8bb9.png

并在 Master 上创建一个 mysql-proxy 的同步账号

grant all on *.* to ‘proxy1’@’192.168.133.130’ identified by ‘123456’;

flush privileges;

并分别在 Master,Slave 上检查刚才的操作

select user,host from mysql.user;

现在在 slave 上将主从同步停止

stop slave;

72d858325718e3db8cf20cfecda8b023.png

在 Master 上连接 mysql-proxy 的管理员端口,密码和用户名是 mysql-proxy.cnf 文件中的

mysql -uadmin -padmin -h192.168.133.130 -P4041

82e757325eb5036c6b68e6acf893ca71.png

查看刚才配置的两台服务器状态

select * from backends;

fa04f5cb98211ca476097e6395e9a49c.png

在 Master 上通过刚才创建的 proxy1 用户登陆 proxy 的 4040 端口

并测试读写,创建一个数据库

mysql -uproxy1 -p123456 -h192.168.133.130 –P4040

create database proxy;

a4a2d023c5b7cdfe72c6da1b77684af6.png

在 Slave 上通过 proxy1 上连接 proxy 的 4040 端口,执行查询操作

mysql -uproxy1 -p123456 -h192.168.133.130 –P4040

select user,host from mysql.user;

e2c3ecb8a0b9d8b29827b9cb7d87aebd.png

最后在连接 proxy 的 4041 端口,再次查看,服务搭建成功

mysql –uadmin –padmin –h192.168.133.130 –P4041

select * from backends;

4d4a434256f591e05b3b928416c3afd5.png

最后别忘了把 slave 的服务在开启

mysql -uroot –p123456

start slave;

44bcd722822095d5c195d4c1290d0557.png

本文转自   mlwzby   51CTO博客,原文链接:http://blog.51cto.com/aby028/1893820

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145077.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月18日 上午8:20
下一篇 2022年5月18日 上午8:20


相关推荐

  • 超分辨率重建之SRCNN整理总结

    白驹微过隙,指上细流沙。时间飞逝啊!转眼之间,四五个月过去了,伴随着中国迈进2020的新时代的元旦的步伐声,我的考研生活暂时告了一个小段落。距今的这些天,忙完了各种小事情,也是时候整理整理之前一些由于时间紧张而没有细细梳理的知识体系和小知识点了。又恰巧应CSDN上朋友的需求,今天就将之前的一些笔记和补充大致梳理一下,一来以供自己今后学习笔记,二来可以与大家共同学习参考。目录…

    2022年4月8日
    49
  • mac navicat15 激活码[最新免费获取]

    (mac navicat15 激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月30日
    60
  • 局域网arp断网攻击怎么解决_arp断网攻击连不上网

    局域网arp断网攻击怎么解决_arp断网攻击连不上网   关于局域网断网攻击,顾名思义,就是对局域网内某个IP或全部IP进行攻击,让局域网内某个IP或全部IP断网,这是不是很有趣。   原理:关于arp断网攻击是基于arp协议的缺陷,这其实是arp欺骗的时候配置错误引起的现象。就是以…

    2022年10月7日
    5
  • 小米浏览器接入豆包大模型

    小米浏览器接入豆包大模型

    2026年3月12日
    5
  • java war包是什么_jar包和war包区别是什么?

    java war包是什么_jar包和war包区别是什么?1.jar包的介绍JAR(JavaArchive,Java归档文件)是与平台无关的文件格式,它允许将许多文件组合成一个压缩文件。JavaSE程序可以打包成Jar包(J其实可以理解为Java了)。JAR文件格式以流行的ZIP文件格式为基础。与ZIP文件不同的是,JAR文件不仅用于压缩和发布,而且还用于部署和封装库、组件和插件程序,并可被像编译器和JVM这样的工具直接使用。在JA…

    2022年5月23日
    39
  • 使用IntelliJ IDEA 配置JDK(入门)

    使用IntelliJ IDEA 配置JDK(入门)一 JDK 下载 nbsp 首先要下载 java 开发工具包 JDK 下载地址 http www oracle com technetwork java javase downloads index html 点击如下下载按钮 nbsp 在下载页面点击接受许可 并根据自己的系统选择对应的版本 本文以 Window64 位系统为例 下载后成功后 双击图标即可安装 安装过程中直接下一步即可 也可修

    2026年3月19日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号