• ADADADADAD

    实现SSL加密的主从复制[ mysql数据库 ]

    mysql数据库 时间:2024-12-03 12:12:40

    作者:文/会员上传

    简介:

    实验环境centos7.6最小化安装关闭防火墙、selinux一、建立CA并生成证书1、生成CA的私钥mkdir /etc/my.cnf.d/sslcd /etc/my.cnf.d/sslopenssl genrsa 2048 > cakey.pem2、CA

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    实验环境

    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

    3、生成主节点私钥和证书申请文件

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

    生成证书

    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

    生成证书

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

    [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/mysqllog-binserver-id=57                                                                         ssl-ca=/etc/my.cnf.d/ssl/cacert.pemssl-cert=/etc/my.cnf.d/ssl/master.crtssl-key=/etc/my.cnf.d/ssl/master.key

    systemctl restart mariadb     

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

    mysql --ssl-ca=cacert.pem --ssl-cert=master.crt --ssl-key=master.key   #客户端连接加密,证书如果不在当前路径需要,如果证书有问题会报错的

    创建只允许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/mysqlserver-id=27read-onlyssl-ca=/etc/my.cnf.d/ssl/cacert.pemssl-cert=/etc/my.cnf.d/ssl/slave.crt                                                           ssl-key=/etc/my.cnf.d/ssl/slave.key

    测试是否可以用ssl连接主服务器

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

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

    CHANGE MASTER TOMASTER_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  #在配置文件中配置的话此处不显示证书路径

    如果是在CHANGE MASTER TO中指定证书路径 show slave status\G 是可以看到证书路径的,其他没有区别

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

    实现SSL加密的主从复制.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载