實現SSL加密的主從複製

實驗環境

centos7.6最小換安裝

關閉防火牆、selinux

一、建立CA並生成證書

1、生成CA的私鑰

mkdir /etc/my.cnf.d/ssl

cd /etc/my.cnf.d/ssl

openssl genrsa 2048 > cakey.pem

2、CA自簽名證書

openssl req -new -x509 -key cakey.pem -out cacert.pem -days 3650

image.png

3、生成主節點私鑰和證書申請文件

openssl req -newkey rsa:1024  -days 365 -nodes -keyout master.key > master.csr

生成證書

image.png

openssl x509 -req -in master.csr -CA cacert.pem -CAkey cakey.pem -set_serial 01 > master.crt

4、生成從節點私鑰和證書申請文件

openssl req -newkey rsa:1024  -days 365 -nodes -keyout slave.key > slave.csr

生成證書

image.png

openssl x509 -req -in slave.csr -CA cacert.pem -CAkey cakey.pem -set_serial 02 > slave.crt

image.png

[root@localhost ssl]#scp -r /etc/my.cnf.d/ssl/  192.168.12.27:/etc/my.cnf.d/    #將證書複製到從服務器

二、配置SSL主從

MariaDB [(none)]> status   #查看客戶端登錄時是否使用ssl

MariaDB [(none)]> show variables like '%ssl%';   #查看是否啓用加密

1、配置主服務器

vi /etc/my.cnf      #修改配置文件

[mysqld]
datadir=/var/lib/mysql
log-bin
server-id=57                                                                         
ssl-ca=/etc/my.cnf.d/ssl/cacert.pem
ssl-cert=/etc/my.cnf.d/ssl/master.crt
ssl-key=/etc/my.cnf.d/ssl/master.key

systemctl restart mariadb     

MariaDB [(none)]> show variables like '%ssl%';    #可以看到加密功能啓用

image.png

mysql --ssl-ca=cacert.pem --ssl-cert=master.crt --ssl-key=master.key   #客戶端連接加密,證書如果不在當前路徑需要,如果證書有問題會報錯的

image.png

創建只允許ssl登錄賬號

MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.12.%' identified by '123456' require ssl;

[root@localhost ssl]#mysqldump -A -F --single-transaction --master-data=1 >all.sql   #備份數據庫

[root@localhost ssl]#scp all.sql 192.168.12.27:/

2、配置從服務器

vi /etc/my.cnf    #修改配置文件

[mysqld]
datadir=/var/lib/mysql
server-id=27
read-only
ssl-ca=/etc/my.cnf.d/ssl/cacert.pem
ssl-cert=/etc/my.cnf.d/ssl/slave.crt                                                           
ssl-key=/etc/my.cnf.d/ssl/slave.key

測試是否可以用ssl連接主服務器

mysql -urepluser -p123456 -h192.168.12.57 --ssl-ca=cacert.pem --ssl-cert=slave.crt --ssl-key=slave.key   

image.png

vi /all.sql    #在原有的基礎上修改

CHANGE MASTER TO
MASTER_HOST='192.168.12.57',
MASTER_USER='repluser',
MASTER_PASSWORD='123456',
MASTER_SSL=1,                                                                                  
MASTER_LOG_FILE='mariadb-bin.000009', MASTER_LOG_POS=245;

[root@localhost ssl]#mysql < /all.sql 

MariaDB [(none)]> start slave;

MariaDB [(none)]> show slave status\G  #在配置文件中配置的話此處不顯示證書路徑

image.png

如果是在CHANGE MASTER TO中指定證書路徑 show slave status\G 是可以看到證書路徑的,其他沒有區別

image.png

MariaDB [(none)]> show slave status\G

image.png

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章