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


相关推荐

  • x201换风扇_笔记本怎么换风扇 ThinkPad X201i换风扇图文教程

    x201换风扇_笔记本怎么换风扇 ThinkPad X201i换风扇图文教程ThinkPadX201i换电扇图文教程:拆机之前,我们需求先对X201i的散热电扇在停止了开端的理解,得知价钱从10元左右的单电扇,到上百的散热全体都有,而且还分东芝产和松下产等不同产地的,小编选择了松下产的整套散热(包括散热片和电扇),价钱为150,电扇固定办法为小螺丝。假定拿到电脑修理店去换的话,小编猜测我们所需求的费用至少在200-300元之间。一:拆机前的准备螺丝刀,小毛刷和安排螺丝的…

    2022年6月27日
    44
  • 全网最全Linux 运行jar包的几种方式[通俗易懂]

    全网最全Linux 运行jar包的几种方式[通俗易懂]一、Linux运行jar包的几种方式方式一:java-jarxxx.jar最常用的启动jar包命令,特点:当前ssh窗口被锁定,可按CTRL+C打断程序运行,或直接关闭窗口,程序退出方式二:java-jarxxx.jar&&代表在后台运行,ctrl+c后程序也会继续运行方式三:nohupjava-jarxxx.jar&nohup即nohangup不挂断,关闭SSH客户端连接,程序不会中止运行缺省情况下该作业的所

    2022年10月5日
    1
  • git rebase详解(图解+最简单示例,一次就懂)[通俗易懂]

    git rebase详解(图解+最简单示例,一次就懂)[通俗易懂]在拉公共分支最新代码的时候使用rebase,也就是gitpull-r但往公共分支上合代码的时候,使用merge

    2022年8月22日
    3
  • .net基础笔记4

    .net基础笔记4

    2021年8月16日
    49
  • ASP .NET DropDownList多级联动事件

    ASP .NET DropDownList多级联动事件思路假如有三级省、市、区,先加载出所有省选择省之后,加载出该省所有市选择市之后,加载出该市所有区重新选择省,则清空市和区重新选择市,则清空区想好数据结构,不同的数据结构做法不同例子数据结构publicclassArea{publicintPKID{get;set;}publicintParentID{get;set;}…

    2022年9月11日
    0
  • java setattribute_java – HttpSession setAttribute并不总是插入新对象「建议收藏」

    java setattribute_java – HttpSession setAttribute并不总是插入新对象「建议收藏」我正在从WLS10g和JavaEE6升级到WLS12c和JavaEE7.我注意到HttpSession.setAttribute的工作方式有所不同.在WLS10中,任何已存储在某个键下的对象都将被替换.在WLS12中,如果newObject.equals(oldObject),则不替换该对象.这对我们来说是个问题,因为应用程序有这样的对象:classValueObject{intkey;St…

    2022年8月31日
    2

发表回复

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

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