MYSQL分布式集群使用-主从复制

MYSQL分布式集群使用-主从复制

大家好,又见面了,我是全栈君。

要达到分布式布局,需要满足2个条件:

1. 框架程序的支持,如Thinkphp、YII2。

> TP的支持文档:http://document.thinkphp.cn/manual_3_2.html#distributed_database

2. 数据库的配置,使其支持主从或主主关系拷贝。

> 主从复制(亦叫 读写分离)
> 主主复制(亦叫 互为主从,主主互备或双机热备)

主从复制,亦可称为读写分离

假设:
主服务器 -> 192.168.1.110
从服务器 -> 192.168.1.111

  • 主服务器配置

    • A) 修改配置文件 (开启bin-log)

    • B) 创建授权帐号

  • 从服务器配置

    • A) 修改配置文件 (另置server-id)

    • B) 使用命令开启slave

    • C) 检查从服务器复制功能状态

主服务器配置

A) 修改配置文件 (开启bin-log)

开启日志记录文件

vim /etc/my.cnf
server-id=1      #[必须]服务器唯一ID,同步的时候,根据此ID判断,如果server_id是自己就不需要同步
log-bin=mysql-bin   #[必须]启用二进制日志
sync_binlog=1    #sync_binlog=n,每n次写入binlog缓存时交换到硬盘里。默认为0,就是根据系统周期进行交换,效率最高,但安全性低,如果要做同步,设置为1。
  
#保存后,重启数据库
service mysqld restart

B) 创建授权帐号

mysql>GRANT REPLICATION SLAVE ON *.* to 'backup'@'%' identified by '123456'; //此处可用具体客户端IP代替,如192.168.1.111,加强安全。
mysql>flush privileges;  

C) 查看MASTER状态

mysql>show master status;  
+------------------+----------+--------------+------------------+  
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |  
+------------------+----------+--------------+------------------+  
| mysql-bin.000004 |      308 |              |                  |  
+------------------+----------+--------------+------------------+  
1 row in set (0.00 sec)  
注:执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化

从服务器配置

A) 修改配置文件 (另置server-id)

vim /etc/my.cnf
server-id=2      #[必须]服务器唯一ID
  
#保存后,重启数据库
service mysqld restart

B) 使用命令开启slave

mysql>change master to master_host='192.168.1.110',master_user='backup',master_password='123456',master_log_file='mysql-bin.000004',master_log_pos=308;  
mysql>start slave; #启动从服务器复制功能

C) 检查从服务器复制功能状态

mysql> show slave status\G
  
*************************** 1. row ***************************  
  
           Slave_IO_State: Waiting for master to send event
           Master_Host: 192.168.2.222  //主服务器地址
           Master_User: mysync   //授权帐户名,尽量避免使用root
           Master_Port: 3306    //数据库端口,部分版本没有此行
           Connect_Retry: 60  
           Master_Log_File: mysql-bin.000004  
           Read_Master_Log_Pos: 600     //#同步读取二进制日志的位置,大于等于Exec_Master_Log_Pos
           Relay_Log_File: ddte-relay-bin.000003  
           Relay_Log_Pos: 251  
           Relay_Master_Log_File: mysql-bin.000004  
           Slave_IO_Running: Yes    //此状态必须YES
           Slave_SQL_Running: Yes     //此状态必须YES
                 ......  
  
lave_IO及Slave_SQL进程必须正常运行,即YES状态,否则都是错误的状态(如:其中一个NO均属错误)。

以上操作过程,主从服务器配置完成,可以开始测试了。
在主服务器上插入一条数据,就可以看看从服务器的数据库是否已更新就OK了。

MYSQL分布式集群使用-主从复制

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111896.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Eureka集群原理

    Eureka集群原理问题:微服务RPC远程服务调用最核心的是什么?高可用,试想你的注册中心只有一个onlyone,它出故障了那就呵呵o( ̄︶ ̄)o了,会导致整个微服务环境不可用。解决办法:搭建Eureka注册中心集群,实现负载均衡+故障容错Eureka集群的原理:互相注册,相互守望。一个Eureka集群包含7001和7002等许多服务,在这个集群中,7001指向其他所有服务…

    2022年5月28日
    43
  • 理解51单片机最小系统的工作原理「建议收藏」

    理解51单片机最小系统的工作原理「建议收藏」51单片机最小应用系统概述要想使用单片机,第一个要搭建的电路就是单片机的最小系统,有了这个最小系统单片机就可以去正常的工作,即使没有其他的外围电路(显示器啥的),也可以对单片机进行程序的编写,程序也可以在单片机里面正常的运行。其包括MCS-51系列芯片一块,(51初步认识)电源电路,时钟电路,复位电路。51单片机最小系统原理图1.电源电路任何的电子设备都需要给其供应相对应的工作电源才可以正常工作,此芯片可用+5V的直流电源供电电源电路2.时钟电路单片机的芯片是数字电路芯片,数字芯片要想正常

    2022年6月23日
    35
  • JBPM学习第4篇:10分钟熟悉Eclipse[通俗易懂]

    JBPM学习第4篇:10分钟熟悉Eclipse

    2022年3月12日
    39
  • C#代码集

    C#代码集C#入门代码示例记录一、示例静态计算工具类1publicstaticclassCalculator2{3publicstaticdoubleAdd(doublea,doub

    2022年7月1日
    39
  • 关于个人能力提升

    关于个人能力提升

    2020年11月12日
    156
  • 转blog!!

    转blog!!

    2021年4月27日
    143

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号