位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享linux系统中使用openssl实现mysql主从复制(linux oos),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux o+t,linux oci,linux oos,linux oos,linux oos,linux oos,linux o+t,linux-o,内容如对您有帮助,希望把文章链接给更多的朋友!

证书准备:

CA证书:

第一步:创建CA私钥

[root@localhost CA]# (umask ;openssl genrsa -out /etc/pki/CA/private/cakey.pem )

第二步:生成自签证书

[root@localhost CA]# openssl req -new -x -key /etc/pki/CA/private/cakey.pem -days -out /etc/pki/CA/cacert.pem

————————————————————————————?

mysql准备私钥及证书申请文件 :

第一步:创建mysql私钥:

[root@localhost ~]# (umask ;openssl genrsa -out /var/lib/mysql/ssl/mysql.key )

第二步:生成证书申请文件及发送给CA服务端

[root@localhost ~]# openssl req -new -key /var/lib/mysql/ssl/mysql.key -days -out /var/lib/mysql/ssl/mysql.csr

注意:国家,省 ,公司名称必须和CA一致

将证书申请文件发送至CA服务器

————————————————————————————?

在CA服务器端颁发证书:

[root@localhost CA]# openssl ca -in /tmp/mysql.csr -out /tmp/mysql.crt -days

附上查看证书中的信息命令:

openssl x -in /PATH/FROM/CERT_FILE -noout -text|subject|serial|dates

————————————————————————————?

将证书发送至mysql服务器

以及将CA的自签证书发送至从服务器

证书准备动作到此结束

基于ssl功能实现主从复制,是主从双方都需要互相验证,即从服务器也要有自己的证书。

所以,按照上述流程,生成slave服务器的证书

================================================

配置mysql服务端:

在主服务器端查看关于ssl有关的参数 及 主从复制?主服务器 的配置项:

MariaDB [(none)]> show variables like ‘%ssl%';

由于ssl功能配置项为全局配置参数,所以 编辑 /etc/my.cnf 文件 :

由于是客户端验证服务端,所以只需要配置 ssl_cert(mysql服务器端的证书位置)、ssl_key(mysql私钥位置)与ssl_ca(CA证书位置)即可

开启服务,并检查:

————————————————————————————?

创建一个基于ssl功能,从服务器用于复制mysql主服务器数据库的最小权限账号:

MariaDB [(none)]> GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO ‘slave1'@'.1..' IDENTIFIED BY ‘passwd' REQUIRE ssl ;

查看binlog位置,并记录,用于从服务器配置:

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

MariaDB [(none)]> SHOW MASTER LOGS;

================================================

从服务器配置:

编辑 /etc/my.cnf ,由于是从服务器,所以需要开启中继日志(relay_log),且server_id不应与同一层面的mysql服务器相同

启动mysql服务,并检查:

————————————————————————————?

配置从服务器,指向主服务器(这是是全局配置参数,但是不建议写在配置文件/etc/my.cnf 中,因为如果slave因意外宕机,在为了检查数据完整性的情况下,再启动mysql的时候,也会自动启动复制功能,不利于排查错误)

MariaDB [(none)]> CHANGE MASTER TO MASTER_HOST='.1..1′,MASTER_USER='slave1′,MASTER_PASSWORD='passwd',MASTER_LOG_FILE=' master-log. ‘,MASTER_LOG_POS= , 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';

MariaDB [(none)]> START SLAVE;

================================================

验证主从效果:

————————————————————————————?

主服务器创建数据库 mydb

————————————————————————————?

从服务器查看:

================================================

总结:

复制时应该注意的问题:

1、从服务设定为“只读”;(双主模式无需设置)

在从服务器启动read_only,但仅对非SUPER权限的用户有效;

阻止所有用户:

mysql> FLUSH TABLES WITH READ LOCK;

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

以上两项为立即刷写数据从内存到磁盘

标签: linux oos

本文链接地址:https://www.jiuchutong.com/biancheng/349284.html 转载请保留说明!

上一篇:MySQL5.6.22 绿色版 安装详细教程(图解)(mysql5.6下载)

下一篇:MySQL 读写分离实例详解(mysql读写分离实现原理)

  • 税收分类方法表格
  • 青岛山公寓二手房出售
  • 个税申报人员报送成功怎么删除
  • 两处工资薪金所得
  • 发票勾选是否为转内销凭证是什么意思
  • 小规模没有成本票怎么做账
  • 确认增值税时要通过未缴增值税科目吗
  • 运输业务增值税
  • 收到退款如何做账
  • 收到去年所得税汇算清缴退税账务处理
  • 高速公路通行费怎么计算的
  • 工会经费有关的增值税能否抵扣?
  • 财税2012年第15号文
  • 退休人员再任职个人所得税
  • 财务审核火车票真伪辨别
  • 金税盘报税的服务费怎么抵扣增值税?
  • 残保金逾期未申报的税务怎么处理
  • 员工把发票丢了怎么处理
  • 文化事业建设费税收优惠政策2023
  • 合伙企业收到投资款要缴纳印花税吗
  • 公司名下的车怎么上牌
  • win10windows资源管理器怎么打开
  • 佣金可以开票吗
  • 制造费用主要包括哪些内容
  • 进口应税消费品的组成计税价格为
  • php输出mysql
  • wordpress导入主题教程
  • 电脑如何设置屏幕常亮
  • 宏基笔记本一键恢复系统
  • 总公司给分公司调货
  • 非货币性资产交换的记忆口诀
  • vscode简单入门
  • 动销率怎么看
  • thinkphp3.x连接mysql数据库的方法(具体操作步骤)
  • php中get_magic_quotes_gpc()函数说明
  • sklearn报错
  • Diffusion models代码实战:从零搭建自己的扩散模型
  • string对象放在哪里
  • 直接进入税金及附加的科目
  • 免收印花税
  • 无票收入后又开票怎么办
  • 税控盘每年的服务费可以全额抵扣吗
  • 排污收费制度在排污费征收方面存在的问题
  • 季报现金流量表可以不填吗
  • 资产减值损失会计科目编码
  • 企业所得税中资产计税基础怎么填
  • 债务重组账务记忆口诀
  • 职工福利费税前扣除标准是应发工资还是实发工资
  • 发票金额跟实际金额为什么不一样
  • 十二月份没出现问题
  • 原材料采用实际成本法,在会计核算上应设置的账户是
  • 盘亏的固定资产是资产吗
  • 顺风车没有发票是否合法
  • 闲置固定资产如何折旧
  • 确认收入一定要交增值税吗
  • 会计科目的设置原则包括( )
  • 差旅费报销属于自制原始凭证吗
  • mysql中具体到删某一个数据
  • SQL Server中通过reverse取某个最后一次出现的符号后面的内容(字符串反转)
  • xp禁用win键
  • mac自带的看图软件怎么使用
  • windows7开始菜单不见了
  • WARNING: /tmp: File system full, swap space limit exceeded的解决办法
  • 如何用mac制作ppt
  • winedt中文界面
  • linux检查文件内容
  • canvas画心形
  • linux定时执行任务
  • 深入了解的高级表达
  • 批处理技术有哪些
  • python3.8基础教程
  • python爬虫类
  • python gensim
  • javascript面向对象精要pdf下载
  • jquery foreach循环
  • 电子发票怎么汇总清卡
  • 治理体系治理能力十九届四中
  • 国税局登录密码修改
  • 长期挂账的其他应付款的规定
  • 山东省工会经费收支管理办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设