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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 二维数组转换成List<List<String>>[通俗易懂]

    Java 二维数组转换成List<List<String>>[通俗易懂]在拿到二维数组的数据时,需要将它转换成嵌套的list,如下工具类:importjava.util.ArrayList;importjava.util.List;/***将二维数组转换成List>形式工具**@authorqiulinhe**2017年3月1日下午3:09:52*/publicclassArrayToListTe

    2022年6月20日
    193
  • 基于gitlab的CICD流程规范

    基于gitlab的CICD流程规范前言:这篇文章主要讲一讲基于gitlab的CICD流程规范基于gitlab的CICD流程规范一、简介二、CICD流程图三、CICD说明四、结合CICD流程拓展1、业务代码-数据库基于flyway实现版本控制2、数据库版本控制3、二进制或内置五、代码质量检查及自动化测试(未来)六、疑问解答与加群交流学习一、简介为了提升线下测试效率,缩短测试时间,提升提测代码质量,规范流程,缩短测试准备和执行时间,缩短问题定位时间,提供预测性指标,规范CICD流程,以提升整体团队效率。二、CICD流程图三、CICD

    2022年6月14日
    110
  • 使用 Vue + LayUI 做后台管理、RESTful 交互

    使用 Vue + LayUI 做后台管理、RESTful 交互一、前言1、之前使用了React/Angular,使用起来显然是比jQuery好多了,但时隔半年,最近再次深入研究了vue,很惊喜。故以后选择MVC/MVVM框架的话,建议首选vue,主要是其代码结构,清晰简单。2、使用vue+layui了,但layui里边的layui.js模块vue.js冲突,因此放弃使用layui.js,导致很多高级…

    2022年6月25日
    28
  • 去哪儿网正式开源内部使用的消息中间件 QMQ

    去哪儿网正式开源内部使用的消息中间件 QMQ

    2021年6月17日
    110
  • 资源岛官网_shrna质粒构建

    资源岛官网_shrna质粒构建XNATouch:MicrosoftXNAGamesRunningOnTheiOSPlatformhttp://monogame.codeplex.com/Rendering,GraphicsandGameEnginesSynapseGamingSunBurnEngine2.0–NiceGameEngineloadedwithf

    2022年8月30日
    1
  • 树莓派连接wifi个人热点和远程windows远程登录

    树莓派连接wifi个人热点和远程windows远程登录1.安装完系统后在该目录下新建wpa_supplicant.conf文件填入以下信息country=CNctrl_interface=DIR=/var/run/wpa_supplicantGROUP=netdevupdate_config=1network={ssid="WiFi-A"psk="12345678"key_mgmt=WPA-PSKpriority=1}…

    2022年5月5日
    79

发表回复

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

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