|
一、概念:
- MySQL数据读写分离是存储数据的一种服务架构
- 执行select命令必须连接 slave角色服务器
- 执行insert命令必须连接 maste角色服务器
- 提供数据读写分离功能的中间件软件有: mysql-proxy maxscale mycat
- 拓扑架构只支持一主一从或者一主多从架构
二、实现读写分离的拓扑图:
三、MaxScale相关配置:
指令/路径/...说明maxscale-2.1.2-1.rhel.7.x86_64.rpm软件包/etc/maxscale.cnf主配置文件maxscale /etc/maxscale.cnf启动服务/var/log/maxscale/maxscale.log日志路径(可查看报错信息)4006读写分离服务使用端口号4016管理服务使用端口号
四、读写分离的配置流程:
- 配置Mysql服务器一主一从
- 配置代理服务器(读写分离服务器)
- 启动读写分离服务
- 客户机50测试配置读写分离服务的配置
五、实操:
第一步:配置Mysql服务器一主一从
- [root@host61 ~]# vim /etc/my.cnf
- [mysqld]
- Server_id = 61
- log_bin=master61
- :wq
- [root@host61 ~]# systemctl restart mysqld
- [root@host61 ~]# mysql -uroot –p123qqq...A
- Mysql> grant replication slave on *.* to repluser@"%" identified by "123qqq...A";
- Mysql> show master status ;
- +-----------------+----------+--------------+------------------+-------------------+
- | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
- +-----------------+----------+--------------+------------------+-------------------+
- | master61.000001 | 441 | | | |
- +-----------------+----------+--------------+------------------+-------------------+
- 1 row in set (0.00 sec)
复制代码- [root@host62 ~]# vim /etc/my.cnf
- [mysqld]
- Server_id = 62
- :wq
- [root@host62 ~]# systemctl restart mysqld
- [root@host62 ~]# mysql -uroot -p密码
- Mysql> change master to master_host="192.168.88.61" ,
- Master_user="repluser" ,
- Master_password="123qqq...A" ,
- Master_log_file="master61.000001" ,
- Master_log_pos=441 ;
- Mysql> start slave;
- Mysql> show slave status \G
- Slave_IO_Running: Yes
- Slave_SQL_Running: Yes
复制代码 第二步:配置代理服务器(读写分离服务器)
- [root@host60 ~]# yum -y install maxscale-2.1.2-1.rhel.7.x86_64.rpm
复制代码- [root@host60 ~]# cp /etc/maxscale.cnf /root/ 备份主配置文件
- [root@host60 ~]# vim /etc/maxscale.cnf
- [maxscale]
- threads=auto # 服务启动后线程的数量,根据CPU 核数创建
- [server1]
- type=server
- address=192.168.88.61 # 指定第1台数据库服务器的ip地址
- port=3306
- protocol=MySQLBackend
- [server2]
- type=server
- address=192.168.88.62 # 指定第2台数据库服务器的ip地址
- port=3306
- protocol=MySQLBackend
- [MySQL Monitor] # 定义监视的数据库服务器
- type=monitor
- module=mysqlmon
- servers=server1,server2 # 监视server1和server2
- user=mysqla # 监控用户账号
- 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 # 读写分离在server1和server2服务器之间进行
- user=mysqlb # 路由用户
- passwd=123qqq...A # 连接密码
- max_slave_connections=100%
- [MaxAdmin Service] # 管理服务(通过访问管理服务可以查看监控信息)
- type=service
- router=cli
- # 因为只读服务没有启用 ,不需要定义服务使用的端口号(注释)
- #[Read-Only Listener]
- #type=listener
- #service=Read-Only Service
- #protocol=MySQLClient
- #port=4008
- [Read-Write Listener] # 定义读写分离服务使用端口号
- type=listener
- service=Read-Write Service
- protocol=MySQLClient
- port=4006 # 端口号
- [MaxAdmin Listener] # 定义管理服务使用端口号
- type=listener
- service=MaxAdmin Service
- protocol=maxscaled
- socket=default
- port=4016 # 端口号
- :wq
复制代码
- 配置数据库服务器(在数据库服务器上添加监控用户和路由用户)
- 注意:因为是主从结构 ,所以只需要在主服务器添加,从服务器会自动同步
- [root@host61 ~]# mysql -uroot -p123qqq...A
- # 添加监控用户 mysqla 用户
- mysql> grant replication slave , replication client on *.* to
- mysqla@"%" identified by "123qqq...A";
- # 权限说明:
- # replication client 监视数据库服务的运行状态
- # replication slave 数据库服务器的主从角色
- # 添加路由用户 mysqlb 用户
- mysql> grant select on mysql.* to mysqlb@"%" identified by "123qqq...A"; # 对授权库下的表有查询权限
- # 在从服务器查看用户是否同步
- [root@host62 ~]# mysql -uroot -p123qqq...A
- select user from mysql.user where user="mysqla";
- select user from mysql.user where user="mysqlb";
复制代码 第三步:启动读写分离服务
- 验证数据库服务器的授权用户 mysqla 和 mysqlb
- # 安装提供mysql命令的软件
- [root@host60 ~]# which mysql || yum -y install mariadb
- [root@host60 ~]# mysql -h192.168.88.61 -umysqla -p123qqq...A
- [root@host60 ~]# mysql -h192.168.88.62 -umysqla -p123qqq...A
- [root@host60 ~]# mysql -h192.168.88.61 -umysqlb -p123qqq...A
- [root@host60 ~]# mysql -h192.168.88.62 -umysqlb -p123qqq...A
- # 说明:能连接成功才是对的,如果连接失败:执行如下操作
- # 在主数据库服务器host61 把添加 mysqla用户 和 mysqlb 用户的命令再执行一遍
- # 启动服务
- [root@host60 ~]# maxscale /etc/maxscale.cnf
- # 查看日志文件
- [root@host60 ~]# ls /var/log/maxscale/
- maxscale.log
- # 查看读写分离服务端口号
- [root@host60 ~]# netstat -utnlp | grep 4006
- tcp6 0 0 :::4006 :::* LISTEN 1580/maxscale
- # 查看读写分离服务端口号
- [root@host60 ~]# netstat -utnlp | grep 4016
- tcp6 0 0 :::4016 :::* LISTEN 1580/maxscale
- #把服务杀死 再启动 相当于重启服务 (修改了配置文件后要重启服务使其配置生效)
- # 通过杀进程的方式停止服务
- [root@host60 ~]# killall -9 maxscale
- # 启动服务
- [root@host60 ~]# maxscale /etc/maxscale.cnf
- # 在host60本机访问管理服务查看数据库服务的监控信息
- [root@host60 ~]# maxadmin -uadmin -pmariadb -P4016
- MaxScale> list servers
- Servers.
- -------------------+-----------------+-------+-------------+--------------------
- Server | Address | Port | Connections | Status
- -------------------+-----------------+-------+-------------+--------------------
- server1 | 192.168.88.61 | 3306 | 0 | Master, Running
- server2 | 192.168.88.62 | 3306 | 0 | Slave, Running
- -------------------+-----------------+-------+-------------+--------------------
- MaxScale> exit
复制代码
- 排错方法 : 查看日志里的报错信息 vim /var/log/maxscale/maxscale.log
第四步:测试配置读写分离服务的配置
- # 首先在主数据库服务器host61 添加客户端连接使用的用户
- [root@host61 ~]# mysql -uroot -p密码
- create database bbsdb;
- create table bbsdb.a(id int);
- grant select,insert on bbsdb.* to yaya@"%" identified by "123qqq...A";
- # 在从服务器host62查看存储数据库表和添加用户
- [root@host62 ~]# mysql -uroot -p密码
- desc bbsdb.a;
- select user from mysql.user where user="yaya";
- # 客户端host50连接读写分离服务器host60访问数据库服务
- mysql -h读写分离服务器的ip -P读写分离服务的端口号 -u数据库授权用户名 -p密码
- [root@host50 ~]# mysql -h192.168.88.60 -P4006 -uyaya -p123qqq...A
复制代码- mysql> select * from bbsdb.a;
- Empty set (0.00 sec)
- mysql> insert into bbsdb.a values(8888);
- Query OK, 1 row affected (0.06 sec)
- mysql> select * from bbsdb.a;
- +------+
- | id |
- +------+
- | 8888 |
- +------+
- 1 row in set (0.00 sec)
复制代码 第五步:验证
- 怎么验证查询select 访问就在host62从服务器获取的数据呢?
- 在从服务本机向表里添加1条记录(在从服务添加的新数据主服务器不会同步)
- # 从服务器插入1条数据
- [root@host62 ~]# mysql -uroot -p123qqq...A -e 'insert into bbsdb.a values(6262)'
- [root@host62 ~]# mysql -uroot -p123qqq...A -e 'select * from bbsdb.a'
- mysql: [Warning] Using a password on the command line interface can be insecure.
- +------+
- | id |
- +------+
- | 8888 |
- | 6262 |
- +------+
- # 主服务器查询
- [root@host11 ~]# mysql -uroot -p123qqq...a -e 'select * from bbsdb.a'
- mysql: [Warning] Using a password on the command line interface can be insecure.
- +------+
- | id |
- +------+
- | 8888 |
- +------+
- # 客户端访问读写分离服务器查询数据(查询结果为从服务器数据源)
- [root@host50 ~]# mysql -h192.168.88.60 -P4006 -uyaya -p123qqq...A -e 'select * from bbsdb.a'
- mysql: [Warning] Using a password on the command line interface can be insecure.
- +------+
- | id |
- +------+
- | 8888 |
- | 6262 |
- +------+
复制代码
- 怎么验证存储数据insert 访问 就是存储在了主机服务器host61上?
- # 客户端机插入数据
- [root@host50 ~]# mysql -h192.168.88.60 -P4006 -uyaya -p123qqq...A -e 'insert into bbsdb.a values(666)'
- # 在主服务器本机查看数据
- [root@host61 ~]# mysql -uroot -p123qqq...a -e 'select * from bbsdb.a'
- mysql: [Warning] Using a password on the command line interface can be insecure.
- +------+
- | id |
- +------+
- | 8888 |
- | 666 |
- +------+
- [root@host50 ~]# mysql -h192.168.88.60 -P4006 -uyaya -p123qqq...A -e 'select * from bbsdb.a'
- mysql: [Warning] Using a password on the command line interface can be insecure.
- +------+
- | id |
- +------+
- | 8888 |
- | 6262 |
- | 666 |
- +------+
复制代码
- 还可以通过查看主服务器的position是否在客户端服务器插入数据后改动来确定是不是在主服务器中进行操作过数据
补充说明
- 如果主从结构中的从服务器宕机了,就实现不了读写分离了,会把读写请求都给主服务器处理。
- 如果主从结构中的主服务器宕机了,读写分离服务无法访问
以上就是MySQL数据读写分离MaxScale相关配置的详细内容,更多关于MySQL数据读写分离MaxScale的资料请关注脚本之家其它相关文章!
来源:https://www.jb51.net/database/291507he8.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
|