ProxySQL实现双主双从读写分离部署

1.环境说明

ip 主机 服务
192.168.69.134 读写分离解析主机 proxysql
192.168.69.130 mysql-master mysql
192.168.69.132 mysql-master2 mysql
192.168.69.5 mysql-slave mysql
192.168.69.6 mysql-slave2 mysql

在这里插入图片描述
把所有主机关闭防火墙和setLinux

[root@proxysql ~]# setenforce 0
[root@proxysql ~]# systemctl stop firewalld

2.安装proxysql和安装mysql和配置主从

安装流程图
在这里插入图片描述

2.1给四台mysql安装mariadb

[root@mysql-master ~]# yum -y install mariadb mariadb-server
[root@mysql-master ~]# systemctl start mariadb
[root@mysql-master ~]# systemctl enable mariadb
[root@mysql-master ~]# ss -antl
State      Recv-Q Send-Q      Local Address:Port                     Peer Address:Port              
LISTEN     0      50                      *:3306                                *:*                  
LISTEN     0      128                     *:22                                  *:*                  
LISTEN     0      100             127.0.0.1:25                                  *:*                  
LISTEN     0      128                    :::22                                 :::*                  
LISTEN     0      100                   ::1:25                                 :::*   

2.2安装proxysql

[root@proxysql ~]# cat <<EOF | tee /etc/yum.repos.d/proxysql.repo
[proxysql_repo]
name= ProxySQL
baseurl=http://repo.proxysql.com/ProxySQL/proxysql-1.4.x/centos/7
gpgcheck=1
gpgkey=http://repo.proxysql.com/ProxySQL/repo_pub_key
EOF
[proxysql_repo]
name= ProxySQL
baseurl=http://repo.proxysql.com/ProxySQL/proxysql-1.4.x/centos/7
gpgcheck=1
gpgkey=http://repo.proxysql.com/ProxySQL/repo_pub_key
[root@proxysql ~]# yum -y install proxysql
[root@proxysql ~]#  vi /etc/yum.repos.d/proxysql.repo 
[proxysql_repo]
name= ProxySQL
baseurl=http://repo.proxysql.com/ProxySQL/proxysql-1.4.x/centos/7
gpgcheck=1
enabled=1      \\设置开机启动
gpgkey=http://repo.proxysql.com/ProxySQL/repo_pub_key
[root@proxysql ~]# yum -y install mariadb-5.5.60-1.el7_5.x86_64
[root@proxysql ~]#  service proxysql start
Starting ProxySQL: 2019-03-14 15:23:54 [INFO] Using config file /etc/proxysql.cnf
DONE!
[root@proxysql ~]# ss -antl
State      Recv-Q Send-Q      Local Address:Port                     Peer Address:Port              
LISTEN     0      128                     *:6032                                *:*                  
LISTEN     0      128                     *:6033                                *:*                  
LISTEN     0      128                     *:6033                                *:*                  
LISTEN     0      128                     *:6033                                *:*                  
LISTEN     0      128                     *:6033                                *:*                  
LISTEN     0      128                     *:22                                  *:*         
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用docker搭建mysql双主双从加读写分离的详细步骤: 1. 安装docker和docker-compose 2. 创建docker-compose文件 在本地创建一个目录,例如`/mysql_cluster`,在该目录下创建一个`docker-compose.yml`文件,并添加以下内容: ``` version: '3' services: mysql-master1: image: mysql:5.7 container_name: mysql-master1 environment: MYSQL_ROOT_PASSWORD: root MYSQL_DATABASE: testdb volumes: - ./master1/conf:/etc/mysql/conf.d - ./master1/data:/var/lib/mysql ports: - "3301:3306" mysql-master2: image: mysql:5.7 container_name: mysql-master2 environment: MYSQL_ROOT_PASSWORD: root MYSQL_DATABASE: testdb volumes: - ./master2/conf:/etc/mysql/conf.d - ./master2/data:/var/lib/mysql ports: - "3302:3306" mysql-slave1: image: mysql:5.7 container_name: mysql-slave1 environment: MYSQL_ROOT_PASSWORD: root volumes: - ./slave1/conf:/etc/mysql/conf.d - ./slave1/data:/var/lib/mysql ports: - "3303:3306" depends_on: - mysql-master1 - mysql-master2 mysql-slave2: image: mysql:5.7 container_name: mysql-slave2 environment: MYSQL_ROOT_PASSWORD: root volumes: - ./slave2/conf:/etc/mysql/conf.d - ./slave2/data:/var/lib/mysql ports: - "3304:3306" depends_on: - mysql-master1 - mysql-master2 ``` 3. 创建配置文件 在`/mysql_cluster`目录下创建四个文件夹`master1`、`master2`、`slave1`、`slave2`,分别用于存放四个mysql实例的配置文件和数据。 在`master1`文件夹下创建一个`my.cnf`文件,并添加以下内容: ``` [mysqld] server-id=1 log-bin=mysql-bin binlog-do-db=testdb replicate-do-db=testdb ``` 在`master2`文件夹下同样创建一个`my.cnf`文件,并修改`server-id`为`2`。 在`slave1`文件夹下创建一个`my.cnf`文件,并添加以下内容: ``` [mysqld] server-id=3 log-bin=mysql-bin binlog-do-db=testdb replicate-do-db=testdb relay-log=slave-relay-bin log-slave-updates=1 read-only=1 ``` 在`slave2`文件夹下同样创建一个`my.cnf`文件,并修改`server-id`为`4`。 4. 启动容器 在`/mysql_cluster`目录下运行以下命令启动容器: ``` docker-compose up -d ``` 5. 配置主从复制 进入`mysql-slave1`容器,执行以下命令: ``` CHANGE MASTER TO MASTER_HOST='mysql-master1', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; ``` 进入`mysql-slave2`容器,执行以下命令: ``` CHANGE MASTER TO MASTER_HOST='mysql-master2', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; ``` 6. 配置读写分离 在`mysql-master1`和`mysql-master2`容器中执行以下命令: ``` GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION; FLUSH PRIVILEGES; ``` 7. 测试 现在我们已经成功搭建了mysql双主双从加读写分离的集群。我们可以使用以下命令测试: 在`mysql-master1`或`mysql-master2`中创建一个数据库: ``` create database testdb; ``` 在`mysql-slave1`和`mysql-slave2`中查看是否同步成功: ``` show databases; ``` 在`mysql-master1`或`mysql-master2`中创建一个表: ``` use testdb; create table t1(id int, name varchar(20)); ``` 在`mysql-slave1`和`mysql-slave2`中查看是否同步成功: ``` use testdb; show tables; ``` 在应用程序中测试读写分离是否成功: ``` jdbc:mysql://localhost:3301,localhost:3302/testdb?useUnicode=true&characterEncoding=utf-8&useSSL=false&autoReconnect=true ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值