centos mysql ssl主从_mysql+ssl主从复制

本文详细介绍了如何在CentOS7环境下,使用MySQL5.7设置基于SSL安全连接的主从复制。首先在主服务器上生成SSL/RSA文件,并启用二进制日志,然后创建复制账号。接着在从服务器上配置SSL相关证书,修改my.cnf文件,重启服务。通过SSL测试连接确保从服务器能安全连接到主服务器,最后配置主从复制并检查同步状态。整个过程提高了数据传输的安全性。
摘要由CSDN通过智能技术生成

a7a1953cd2b2438401661238b9fcaa21.png

一、作为主服务器Master, 会把自己的每一次改动都记录到 二进制日志 Binarylog 中。 (从服务器I/O thread会负责来读取master binary log, 然后写入自身relay log中然后在用自身的sql thread读取relay log并在自身服务器执行一遍。)

到这里主服务器上的更改就同步到从服务器上了。

环境:

centos7

master

slave

mysql5.7

192.168.41.10

192.168.41.20

1、实现基于 ssl 安全连接的主从复制

1) 在主 mysql 创建 SSL/RSA 文件

cd56700da5c7e4d4feb08384664d8752.png

b66be14a94259094378fcf3a8dbf7b9c.png

9270a6ad716d0056f0a5fc0b89b868d9.png

注:启用 mysql 支持 ssl 安全连接主要用于 mysql 主从复制(局域网可以非 ssh 连接即明文

复制,但 internet 复制建议采用 ssl 连接)

在主 mysql 上的操作完成,再生成一个复制帐号:REQUIRE SSL

mysql>grant replication slave on . to 'rep'@'192.168.41.%' identified by '123456' require ssl;

在master上启用二进制日志并重启mysql服务

vim /etc/my.cnf

添加log-bin = mysql-bin

systemctl restart mysqld

2374842981718a0c21c0ac1d36e9167c.png

防火墙规则3306/tcp通信

[root@localhost bin]# firewall-cmd --permanent --add-port=3306/tcp

success

[root@localhost bin]# firewall-cmd --reload

success

2)从服务器配置

slave的/etc/my.cnf

[mysqld]

basedir= /usr/local/mysql

datadir= /usr/local/mysql/data

server_id= 2socket= /usr/local/mysql/mysql.sock

log-error = /usr/local/mysql/data/mysqld.error

relay-log = /usr/local/mysql/data/relay-log-bin

relay-log-index = /usr/local/mysql/data/slave-relay-bin.index

注:server_id 要唯一,不能和其他 mysql 主机的重复

在master主机把主 mysql 生成的证书给了从服务器

cd /usr/local/mysql/data/

scp ca.pam client-cert-pem client-key.pam root@192.168.41.20:/usr/local/mysql/data/

设置 slave client-key.pem 的 r 权限

chmod +r client-key.pam

ls -l client-key.pam

继续在从上配置 SSL:修改/etc/my.cnf 文件,添加如下内容

ssl-ca = /usr/local/mysql/data/ca.pam

ssl-cert = /usr/local/mysql/data/client-cert.pam

ssl-key = /usr/local/mysql/data/client-key.pam

重启mysqld服务

systemctl restart mysqld

ss -napt |grep 3306

进入mysql查看ssl是否持久化

1b4ac0ac28f1b7d03b66c75019c636dd.png

那么在配置主从复制之前可以在从 mysql 上用 SSL 连接主服务器试试:

1affd04d9faca906f008605a9b3ec842.png

45cd53f273457bab4d56803c3910a2bf.png

SSL 测试连接成功,并且登入的 SSL 协议是: Cipher in use is DHE-RSA-AES256-SHA

最后开始配置主从 replicate, 登录slave mysql

在从上 change master to

416db14cdc76f205db0e9f098bdbbd93.png

start slave \启动从同步进程:

查看从的状态,以下两个值必须为 yes,代表从服务器能正常连接主服务器

Slave_IO_Running:Yes

Slave_SQL_Running:Yes

7a06b4e3bd31f2551a963165a0523989.png

测试:

master:

d6ac2779de165b0424328032d773cc52.png

slave:

60f41dea86c170f3763e4aae27ec2d21.png

注意:

主从同步slave同步master,master不同步slave

SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security, TLS)

是为网络通信提供安全及数据完整性的一种安全协议。复制默认是明文进行传输的,通过

SSL 加密可以大大提高数据的安全性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值