源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

linux系统中使用openssl实现mysql主从复制

  • 时间:2020-01-19 06:02 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:linux系统中使用openssl实现mysql主从复制
[b]        证书准备:[/b] CA证书: 第一步:创建CA私钥 [code][root@localhost CA]# (umask 066;openssl genrsa -out /etc/pki/CA/private/cakey.pem 2048)[/code] 第二步:生成自签证书 [code][root@localhost CA]# openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem  -days 7300 -out /etc/pki/CA/cacert.pem[/code] ————————————————————————————– mysql准备私钥及证书申请文件 : 第一步:创建mysql私钥: [code][root@localhost ~]# (umask 066;openssl genrsa -out /var/lib/mysql/ssl/mysql.key 2048)[/code] 第二步:生成证书申请文件及发送给CA服务端 [code][root@localhost ~]# openssl req -new -key /var/lib/mysql/ssl/mysql.key -days 365 -out /var/lib/mysql/ssl/mysql.csr[/code] 注意:国家,省 ,公司名称必须和CA一致 将证书申请文件发送至CA服务器                 ————————————————————————————– 在CA服务器端颁发证书: [code][root@localhost CA]# openssl ca -in /tmp/mysql.csr -out /tmp/mysql.crt -days 365[/code] 附上查看证书中的信息命令: [code]openssl x509 -in /PATH/FROM/CERT_FILE -noout -text|subject|serial|dates[/code]                 ————————————————————————————– 将证书发送至mysql服务器 以及将CA的自签证书发送至从服务器 证书准备动作到此结束 基于ssl功能实现主从复制,是主从双方都需要互相验证,即从服务器也要有自己的证书。 所以,按照上述流程,生成slave服务器的证书            ================================================ [b]        配置mysql服务端:[/b] 在主服务器端查看关于ssl有关的参数  及  主从复制–主服务器  的配置项: [code]MariaDB [(none)]> show variables like ‘%ssl%';[/code]              [img]http://files.jb51.net/file_images/article/201611/201611230822481.png[/img] 由于ssl功能配置项为全局配置参数,所以 编辑 /etc/my.cnf 文件 : 由于是客户端验证服务端,所以只需要配置  ssl_cert(mysql服务器端的证书位置)、ssl_key(mysql私钥位置)与ssl_ca(CA证书位置)即可 [img]http://files.jb51.net/file_images/article/201611/201611230822482.png[/img] 开启服务,并检查: [img]http://files.jb51.net/file_images/article/201611/201611230822483.png[/img]                 ————————————————————————————– 创建一个基于ssl功能,从服务器用于复制mysql主服务器数据库的最小权限账号: [code]MariaDB [(none)]> GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO ‘slave1'@'10.1.35.25' IDENTIFIED BY ‘passwd' REQUIRE ssl ;   [/code]  [img]http://files.jb51.net/file_images/article/201611/201611230822484.png[/img] 查看binlog位置,并记录,用于从服务器配置: MariaDB [(none)]> SHOW MASTER LOGS; [img]http://files.jb51.net/file_images/article/201611/201611230822485.png[/img]                ================================================ [b]从服务器配置:[/b] 编辑 /etc/my.cnf ,由于是从服务器,所以需要开启中继日志(relay_log),且server_id不应与同一层面的mysql服务器相同                                     [img]http://files.jb51.net/file_images/article/201611/201611230822496.png[/img] 启动mysql服务,并检查: [img]http://files.jb51.net/file_images/article/201611/201611230822497.png[/img] ————————————————————————————– 配置从服务器,指向主服务器(这是是全局配置参数,但是不建议写在配置文件/etc/my.cnf 中,因为如果slave因意外宕机,在为了检查数据完整性的情况下,再启动mysql的时候,也会自动启动复制功能,不利于排查错误) [code]MariaDB [(none)]> CHANGE MASTER TO MASTER_HOST='10.1.35.1′,MASTER_USER='slave1′,MASTER_PASSWORD='passwd',MASTER_LOG_FILE=' master-log.000025 ‘,MASTER_LOG_POS= 245 , MASTER_SSL =1, MASTER_SSL_CA ='/var/lib/mysql/ssl/cacert.pem', MASTER_SSL_CERT ='/var/lib/mysql/ssl/slave.crt', MASTER_SSL_KEY ='/var/lib/mysql/ssl/slave.key';[/code] [img]http://files.jb51.net/file_images/article/201611/201611230822498.png[/img] MariaDB [(none)]> START SLAVE; [img]http://files.jb51.net/file_images/article/201611/201611230822499.png[/img]                 ================================================ 验证主从效果:                 ————————————————————————————– 主服务器创建数据库 mydb                                 [img]http://files.jb51.net/file_images/article/201611/2016112308224910.png[/img]                 ————————————————————————————– 从服务器查看:                            [img]http://files.jb51.net/file_images/article/201611/2016112308224911.png[/img]                 ================================================ [b]    总结: [/b] 复制时应该注意的问题: 1、从服务设定为“只读”;(双主模式无需设置) 在从服务器启动read_only,但仅对非SUPER权限的用户有效; 阻止所有用户: [code]mysql> FLUSH TABLES WITH READ LOCK;[/code] 2、尽量确保复制时的事务安全 在master节点启用参数: sync_binlog = ON    #每次事务提交的时候,都立即将二进制日志时间都重内存同步到磁盘中,能确保从服务器能立即得到事件,而且能保护本地数据安全 如果用到的是InnoDB存储引擎: innodb_flush_logs_at_trx_commit=ON      #在事务提交时,立即刷写事务日志从内存到磁盘上 innodb_support_xa=ON    #支持分布式事务 #这两项启动起来,能在一定程度上确保从服务器能够立即得到主服务器的最新事件 3、从服务器意外中止时 尽量避免自动启动复制线程 由于数据是重要的,服务器能意外终止的时间都是奇异的,所以,终止后不要让从服务器自动启动复制线程,等人工手动排查后才从新开启复制线程;有可能复制线程复制到一半的时候出现意外,复制线程或许没有这种功能—–不知道时候需要再次复制上次中断的事件                 4、从节点:设置参数 每一个从服务器都会保存一个文件 relay-log-info,是记录在主服务器上复制二进制日志的位置,以及本地中继日志的位置,为避免产生繁忙的IO操作,这些参数都是先保存在内存上的,到一定程度才会同步到磁盘上的, 所以不安全 sync_master_info=ON sync_relay_log_info=ON 以上两项为立即刷写数据从内存到磁盘 以上就是本文的全部内容了,希望对大家熟悉mysql主从复制能够有所帮助
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部