Mysql学习linux系统中使用openssl实现mysql主从复制
《Mysql学习linux系统中使用openssl实现mysql主从复制》要点: MYSQL学习????????证书准备: MYSQL学习CA证书: MYSQL学习第一步:创建CA私钥 MYSQL学习 MYSQL学习第二步:生成自签证书 MYSQL学习 MYSQL学习――――――――――――――――――――――――――――C MYSQL学习mysql准备私钥及证书申请文件 : MYSQL学习第一步:创建mysql私钥: MYSQL学习 MYSQL学习第二步:生成证书申请文件及发送给CA服务端 MYSQL学习 MYSQL学习注意:国家,省,公司名称必须和CA一致 MYSQL学习将证书申请文件发送至CA服务器 MYSQL学习??????????????? ――――――――――――――――――――――――――――C MYSQL学习在CA服务器端颁发证书: MYSQL学习 MYSQL学习附上查看证书中的信息命令: MYSQL学习 MYSQL学习??????????????? ――――――――――――――――――――――――――――C MYSQL学习将证书发送至mysql服务器 MYSQL学习以及将CA的自签证书发送至从服务器 MYSQL学习证书准备动作到此结束 MYSQL学习基于ssl功能实现主从复制,是主从双方都需要互相验证,即从服务器也要有自己的证书. MYSQL学习所以,按照上述流程,生成slave服务器的证书 MYSQL学习?????????? ================================================ MYSQL学习??????? 配置mysql服务端: MYSQL学习在主服务器端查看关于ssl有关的参数 ?及 ?主从复制C主服务器 ?的配置项: MYSQL学习 MYSQL学习? ? ? ? ? ?? MYSQL学习由于ssl功能配置项为全局配置参数,所以 编辑 /etc/my.cnf 文件 : MYSQL学习由于是客户端验证服务端,所以只需要配置 ?ssl_cert(mysql服务器端的证书位置)、ssl_key(mysql私钥位置)与ssl_ca(CA证书位置)即可 MYSQL学习 MYSQL学习开启服务,并检查: MYSQL学习 MYSQL学习??????????????? ――――――――――――――――――――――――――――C MYSQL学习创建一个基于ssl功能,从服务器用于复制mysql主服务器数据库的最小权限账号: MYSQL学习 MYSQL学习 MYSQL学习查看binlog位置,并记录,用于从服务器配置: MYSQL学习MariaDB [(none)]> SHOW MASTER LOGS; MYSQL学习 MYSQL学习?????????????? ================================================ MYSQL学习从服务器配置: MYSQL学习编辑 /etc/my.cnf,由于是从服务器,所以需要开启中继日志(relay_log),且server_id不应与同一层面的mysql服务器相同 MYSQL学习? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? MYSQL学习启动mysql服务,并检查: MYSQL学习 MYSQL学习――――――――――――――――――――――――――――C MYSQL学习配置从服务器,指向主服务器(这是是全局配置参数,但是不建议写在配置文件/etc/my.cnf 中,因为如果slave因意外宕机,在为了检查数据完整性的情况下,再启动mysql的时候,也会自动启动复制功能,不利于排查错误) MYSQL学习 MYSQL学习 MYSQL学习MariaDB [(none)]> START SLAVE; MYSQL学习 MYSQL学习? ? ? ? ? ? ? ? ================================================ MYSQL学习验证主从效果: MYSQL学习??????????????? ――――――――――――――――――――――――――――C MYSQL学习主服务器创建数据库 mydb MYSQL学习? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? MYSQL学习??????????????? ――――――――――――――――――――――――――――C MYSQL学习从服务器查看: MYSQL学习?????????????????????????? MYSQL学习? ? ? ? ? ? ? ? ================================================ MYSQL学习??? 总结: MYSQL学习复制时应该注意的问题: MYSQL学习1、从服务设定为“只读”;(双主模式无需设置) MYSQL学习在从服务器启动read_only,但仅对非SUPER权限的用户有效; MYSQL学习阻止所有用户: MYSQL学习 MYSQL学习2、尽量确保复制时的事务安全 MYSQL学习在master节点启用参数: MYSQL学习sync_binlog = ON ? ?#每次事务提交的时候,都立即将二进制日志时间都重内存同步到磁盘中,能确保从服务器能立即得到事件,而且能保护本地数据安全 MYSQL学习如果用到的是InnoDB存储引擎: MYSQL学习innodb_flush_logs_at_trx_commit=ON ? ? ?#在事务提交时,立即刷写事务日志从内存到磁盘上 MYSQL学习innodb_support_xa=ON ? ?#支持分布式事务 MYSQL学习#这两项启动起来,能在一定程度上确保从服务器能够立即得到主服务器的最新事件 MYSQL学习3、从服务器意外中止时 尽量避免自动启动复制线程 MYSQL学习由于数据是重要的,服务器能意外终止的时间都是奇异的,所以,终止后不要让从服务器自动启动复制线程,等人工手动排查后才从新开启复制线程;有可能复制线程复制到一半的时候出现意外,复制线程或许没有这种功能―C不知道时候需要再次复制上次中断的事件 ? ? ? ? ? ? ? ? MYSQL学习4、从节点:设置参数 MYSQL学习每一个从服务器都会保存一个文件 relay-log-info,是记录在主服务器上复制二进制日志的位置,以及本地中继日志的位置,为避免产生繁忙的IO操作,这些参数都是先保存在内存上的,到一定程度才会同步到磁盘上的,所以不安全 MYSQL学习sync_master_info=ON MYSQL学习sync_relay_log_info=ON MYSQL学习以上两项为立即刷写数据从内存到磁盘 MYSQL学习以上就是本文的全部内容了,希望对大家熟悉mysql主从复制能够有所帮助 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Mysql必读解析MySQL的information_schema数据库
- 警告:mysqli_real_connect():( HY000 / 2002):第1452行/p
- Mysql必读MySQL用作备份还原的导入和导出命令用法整理
- Mysql必读窥探mysql存储过程细节
- 如何在mysql中连接多个一对多表?
- MYSQL教程MySQL计划任务(事件调度器) Event Scheduler介绍
- MySQL存储过程获取记录排名(一般用于投票系统)
- java – 通过WebLogic进行数据库连接
- mysql – 在更长的时间段和时区存储统计信息
- MYSQL5.7数据库性能怎么样?有实测过吗?MySQL5.7使用InnoD