mysql数据读写分离

数据读写分离:客户端访问数据的查询请求和写请求分别给不同的数据库服务器处理
查询 select A数据库slave
写 insert update delete B数据库master

为什么要数据读写分离
减轻单台数据库服务器的并发访问压力
提高机器硬件的利用率

如何实现数据读写分离
通过程序实现(让程序员写代码实现)
通过安装软件提供的服务实现(中间件)
mycat mysql-proxy maxscale

配置数据读写分离(maxscale+mysql–主从同步)
client50 maxscale57 mysql-server51 mysql-server52

1、部署mysql一主一从同步结构
(1)配置主服务器51
启用binlog日志,用户授权,查看binlog日志信息
(2)配置从服务器52
指定server_id,指定主服务器 启动进程

2、配置数据读写分离服务器57
1、下载并安装软件包maxscale-2.1.2-1.rhel.7.x86_64.rpm
rpm -ivh maxscale-2.1.2-1.rhel.7.x86_64.rpm

3、修改配置文件
vim /etc/maxscale.cnf
[maxscale]
threads=auto 定义线程数量

[server1]
type=server
address=192.168.4.51
port=3306
protocol=MySQLBackend

[server2]
type=server
address=192.168.4.52
port=3306
protocol=MySQLBackend

[MySQL Monitor] //配置监控模块
type=monitor
module=mysqlmon
servers=server1,server2 //后端服务器
user=scalemon //监控用户
passwd=123qqq…A 监控密码
monitor_interval=10000 //间隔时间
#[Read-Only Service] //不配置定义只处理查询请求的服务器
#type=service
#router=readconnroute
#servers=server1
#user=myuser
#passwd=mypwd
#router_options=slave

[Read-Write Service]
type=service
router=readwritesplit
servers=server1,server2
user=scaleroute //路由用户
passwd=123qqq…A
max_slave_connections=100%

[MaxAdmin Listener]
type=listener
service=MaxAdmin Service
protocol=maxscaled
socket=default
port=4016

4、用户授权(根据配置文件的设置在2台数据库服务器上添加对应的用户)
grant replication slave,replication client on . to scalemon@"%" identified by “123qqq…A”;
grant select on mysql.* to scaleroute@"%" identified by “123qqq…A”;
select user,host from mysql.user where user in (“scalemon”,“scaleroute”);

5、启动服务
(1)验证授权用户
[root@pc57 ~]# mysql -h192.168.4.51 -uscaleroute -p123qqq…A;
[root@pc57 ~]# mysql -h192.168.4.52 -uscaleroute -p123qqq…A;
[root@pc57 ~]# mysql -h192.168.4.52 -uscalemon -p123qqq…A;
[root@pc57 ~]# mysql -h192.168.4.51 -uscalemon -p123qqq…A;
(2)启动服务
maxscale -f /etc/maxscale.cnf //启动服务
killall -9 maxscale //停止服务

6、测试配置
(1)查看管理信息(在主机57本机自己访问自己)
maxadmin -uadmin -pmariadb -P4016
list servers
(2)测试数据读写分离(客户端连接192.168.4.57访问数据)
在主数据库服务器上添加访问数据的用户
mysql> create database db8;
mysql> create table t1(id int);
grant select,insert on db8.* to yaya8@"%" identified by “123qqq…A”;
客户端连接57主机访问数据

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值