天天看點

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

1.安裝和配置Docker

伺服器版本

阿裡雲CentOS7.4

docker版本

18.06.0-ce

docker安裝步驟

https://docs.docker.com/install/linux/docker-ce/centos/#install-docker-ce-1

# docker pull mysql:5.7

啟動兩個mysql鏡像,分别映射3306和3316端口

主庫:3306端口

備庫:3316端口

# docker run -p 3306:3306 --name mysql3306 -v /opt/mysql/data/data3306:/var/lib/mysql  -v /opt/mysql/logs/logs3306:/logs -e MYSQL_ROOT_PASSWORD=xxxxxxxxxxxx -d mysql:5.7

# docker run -p 3316:3306 --name mysql3316 -v /opt/mysql/data/data3316:/var/lib/mysql  -v /opt/mysql/logs/logs3316:/logs -e MYSQL_ROOT_PASSWORD=xxxxxxxxxxxx -d mysql:5.7

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

2.配置主從複制

從主庫的docker容器中把預設的配置檔案拷貝出來

# docker cp 37735c072370:/etc/mysql/mysql.conf.d/mysqld.cnf /opt/mysql/conf/conf3306

修改配置檔案增加兩行

#vim mysqld.cnf

[mysqld]

log-bin=mysql-bin #開啟二進制日志

server-id=1 #設定server-id

将修改後的配置檔案拷回容器裡,并重新開機容器

# docker cp /opt/mysql/conf/conf3306/mysqld.cnf 37735c072370:/etc/mysql/mysql.conf.d/

# docker restart 37735c072370

建立主從複制需要的mysql賬戶,并配置設定權限

mysql>CREATE USER 'repl'@'xxx.xxx.xxx.xxx' IDENTIFIED BY 'repl123';

mysql>GRANT REPLICATION SLAVE ON *.* TO 'repl'@'xxx.xxx.xxx.xxx'

檢視主庫狀态,記錄下File和Position

mysql>SHOW MASTER STATUS;

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

修改從庫配置檔案

#vim mysqld.cnf

[mysqld]

server-id=2 #設定server-id

同樣拷進從庫鏡像,并重新開機容器

mysql中執行配置主庫的語句

mysql>change master to master_host='xxx.xxx.xxx.xxx', #Master 伺服器Ip

master_port=3306,

master_user='repl',

master_password='repl123',

master_log_file='master-bin.000001',#Master伺服器産生的日志

master_log_pos=2986;

mysql>start slave;

mysql>show slave status\G

如果slave_io_running和slave_sql_running都為yes,表示啟動同步成功

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

建立兩個用戶端連接配接并建立測試庫

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

主庫建立student表并插入一條記錄,可以看到,從庫自動同步了資料,配置成功

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離
mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離
mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離
mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

3.用mysql-proxy實作讀寫分離

下載下傳mysql-proxy

https://downloads.mysql.com/archives/proxy/

解壓并配置mysql-proxy

# tar zxvf mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz

# cd mysql-proxy-0.8.5-linux-el6-x86-64bit

# vim /etc/mysql-proxy.cnf

[mysql-proxy]

user=root #運作mysql-proxy使用者

admin-username=proxy #主從mysql共有的使用者

admin-password=proxy123 #共有使用者密碼

proxy-read-only-backend-addresses=xxx.xxx.xxx.xxx:3316 #備庫位址

proxy-backend-addresses=xxx.xxx.xxx.xxx:3306 #主庫位址

proxy-lua-script=/usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/rw-splitting.lua #指定讀寫分離配置檔案位置

admin-lua-script=/usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/admin-sql.lua #指定管理腳本

daemon=true #以守護程序方式運作

keepalive=true #mysql-proxy崩潰時,嘗試重新開機

修改讀寫分離配置檔案

# vim /usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/rw-splitting.lua

min_idle_connections = 1, #預設超過4個連接配接數時才開始讀寫分離,改為1

max_idle_connections = 1,

mysql-proxy的bin目錄下啟動mysql-proxy

# ./mysql-proxy --defaults-file=/etc/mysql-proxy.cnf

主庫和從庫分别建立使用者

mysql>GRANT ALL ON *.* TO 'proxy'@'xxx.xxx.xxx' identified by 'proxy123';

建立mysql-proxy的資料裡連接配接(預設端口4040),可以看到之前驗證主從複制時履歷的test庫和student表

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

隻修改從庫的資料,然後通過mysql-proxy查詢,可以看到讀取的資料是從庫修改過的資料,讀分離驗證成功。

主庫:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

從庫:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

mysql-proxy:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

停止從庫的docker容器,通過mysql-proxy插入一條資料,主庫中重新整理也有新增的資料,寫分離驗證成功。

mysql-proxy:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

主庫:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

從庫:

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離

至此,mysql的主從複制已經通過mysql-proxy實作讀寫分離已實作。

mysql proxy 讀寫分離_MySQL主從複制 mysql-proxy實作讀寫分離