一、最近一直在学习mysql的东西,刚好看到mysql如何搭建主从数据库,搜集了很多资料后大致了解了mysql主从复置的原理。以下是我的理解:

举例master为主数据库,slave为从数据库。

  1. slave需要通过自身的IO进程连接上master数据库,并读取master指定日志文件的指定位置之后的内容(slave会向master请求,“我要XXX日志文件XXX位置之后的内容”);
  2. 这时候master接收到来自slave的请求后会找到该日志文件的制定位置,并复制该位置之后的内容返回给slave;
  3. slave将接收到的日志内容依次添加到slave端的relay-log文件的最末端,并将读取到的master端的bin-log的文件名和位置记录到master-info文件中,以便在下一次读取的时候能够清楚的告诉master“我需要从哪个bin-log的什么位置开始读取”;
  4. slave的Sql进程检测到relay-log中新增加了内容后,会马上解析relay-log的内容成为在Master端真实执行时候的那些可执行的内容,并在自身执行。  

二、现在我们开始配置主从数据库:

  这里我准备了两台服务器,系统均为centos7,服务器的系统可以有差别;数据库的话建议大家使用统一版本的。这里我的服务器ip分别是192.168.0.109(master)、192.168.0.133(slave).

  • 服务器:centos7
  • 数据库:Ver 15.1 Distrib 5.5.50-MariaDB, for Linux (x86_64) using readline 5.1
  1. 登录到master的数据库,在master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予REPLICATION SLAVE权限。用户名的密码都会存储在文本文件master.info中

    命令如下:

    mysql > GRANT REPLICATION SLAVE ON *.*
    TO 'slave'@'192.168.0.133'
    IDENTIFIED BY '';//建立root账户,密码是123456,只允许该账户在192.168.0.133这个ip登录(slave的ip),授予REPLICATION SLAVE权限
    mysql > flush privileges;//使权限立即生效
  2. 配置master,slave数据库
    配置master
    vi /etc/my.cnf #编辑配置文件,在[mysqld]部分添加下面内容 server-id= #设置服务器id,为1表示主服务器。
    log_bin=mysql-bin #启动MySQ二进制日志系统。
    binlog-do-db=abc #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
    binlog-ignore-db = mysql,information_schema #忽略写入binlog的库 重启master数据库 systemctl restart mariadb //我这里安装的mysql服务端是mariadb-server 登录master数据库,查看master状态 show master status;

    +------------------+----------+--------------+--------------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
    +------------------+----------+--------------+--------------------------+
    | mysql-bin.000001 | 2722 | | mysql,information_schema |
    +------------------+----------+--------------+--------------------------+

    配置slave
    vi /etc/my.cnf #编辑配置文件,在[mysqld]部分添加下面内容
    server-id= #设置服务器id,为2表示从服务器,这个server-id不做规定,只要主从不一致就好
    log_bin=mysql-bin #启动MySQL二进制日志系统,如果该从服务器还有从服务器的话,需要开启,否则不需要
    binlog-do-db=abc #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
    binlog-ignore-db = mysql,information_schema #忽略写入binlog的库,如果该从服务器还有从服务器的话,需要开启,否则不需要
    重启slave数据库 
    
    systemctl restart mariadb //我这里安装的mysql服务端是mariadb-server
    
    登录从数据库,
    
    change master to master_host='192.168.0.133',master_user='slave',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=2722;//mysql-bin.000001,2722为之前master查到的状态值。
    
    start slave;//开启从数据库
    show slave status; //查看从数据库的状态
  3. 在主mysql创建数据库abc,再从mysql查看已经同步成功!
    create database abc;

    发现从数据库中也会出现数据库abc,说明我们的主从数据库搭建成功啦~

mysql数据库主从搭建的更多相关文章

  1. mysql数据库主从同步

    环境: Mater:   CentOS7.1  5.5.52-MariaDB  192.168.108.133 Slave:   CentOS7.1  5.5.52-MariaDB  192.168. ...

  2. Spring AOP实现Mysql数据库主从切换(一主多从)

    设置数据库主从切换的原因:数据库中经常发生的是“读多写少”,这样读操作对数据库压力比较大,通过采用数据库集群方案, 一个数据库是主库,负责写:其他为从库,负责读,从而实现读写分离增大数据库的容错率.  ...

  3. mysql数据库主从同步读写分离(一)主从同步

    1.mysql数据库主从同步读写分离 1.1.主要解决的生产问题 1.2.原理 a.为什么需要读写分离? 一台服务器满足不了访问需要.数据的访问基本都是2-8原则. b.怎么做?  不往从服务器去写了 ...

  4. ubuntu 下 mysql数据库的搭建 及 数据迁移

    1.mysql的安装 我是使用apt-get直接安装的 :sudo apt-get install mysql-server sudo apt-get install mysql-client 2.配 ...

  5. (转)Mysql数据库主从心得整理

    Mysql数据库主从心得整理 原文:http://blog.sae.sina.com.cn/archives/4666 管理mysql主从有2年多了,管理过200多组mysql主从,几乎涉及到各个版本 ...

  6. MySQL数据库主从同步延迟分析及解决方案

    一.MySQL的数据库主从复制原理 MySQL主从复制实际上基于二进制日志,原理可以用一张图来表示: 分为四步走: 1. 主库对所有DDL和DML产生的日志写进binlog: 2. 主库生成一个 lo ...

  7. Linux下MySQL数据库主从同步配置

    说明: 操作系统:CentOS 5.x 64位 MySQL数据库版本:mysql-5.5.35 MySQL主服务器:192.168.21.128 MySQL从服务器:192.168.21.129 准备 ...

  8. MySQL数据库主从切换脚本自动化

    MySQL数据库主从切换脚本自动化 本文转载自:https://blog.csdn.net/weixin_36135773/article/details/79514507 在一些实际环境中,如何实现 ...

  9. MySQL数据库主从同步实战过程

       Linux系统MySQL数据库主从同步实战过程 安装环境说明 系统环境: [root@~]# cat /etc/redhat-release CentOS release 6.5 (Final) ...

随机推荐

  1. java数字字符串累加1的解决方案

    近期操作项目遇到这样的问题,研究了下搞出了一个解决方案. //num也可以是在数字字符串里面截取的,比如我有14位的数字字符串前六位是市级,7,8位代表县区,后两位代表乡镇,最后四位是累计+1的,这个 ...

  2. DTD

    DTD(文档类型定义)的作用是定义 XML 文档的合法构建模块. 它使用一系列的合法元素来定义文档结构. DTD 可被成行地声明于 XML 文档中,也可作为一个外部引用. 内部的 DOCTYPE 声明 ...

  3. C#集合基础与运用

    C#集合基础与运用   C#集合基础与运用 1. 集合接口与集合类型............................................... 1 (1) 集合的命名空间..... ...

  4. iOS基础 - 史上最难游戏

    步骤一:隐藏状态栏 步骤二:屏幕适配 步骤三:设置窗口的根控制器为导航控制器,并且设置导航条和状态栏. 步骤四:搭建设置界面 步骤五:控制器连线 步骤六:搭建关卡控制器 加载pilst文件 创建关卡模 ...

  5. JAVA面试精选

    JAVA面试精选[Java基础第一部分] 这个系列面试题主要目的是帮助你拿轻松到offer,同时还能开个好价钱.只要能够搞明白这个系列的绝大多数题目,在面试过程中,你就能轻轻松松的把面试官给忽悠了.对 ...

  6. 配置restful webservice 框架restkit

    (配置restful webservice 框架restkit) RestKit 是一个开源的 objective-c 框架,容许在 iOS 和 Mac OS X 的 Objective-C 中与 R ...

  7. STM8S TIM1 PWM初始化设置

    #define TIM1_DIV1 (uint16)(1-1) #define TIM1_DIV2 (uint16)(2-1) #define TIM1_DIV4 (uint16)(4-1) #def ...

  8. win7 VS2008 ffmpeg release 版本崩溃 0x00905a4d 处未处理的异常

    这个坑, 我始终不相信编码的问题,但还是花了一上午加各种调试代码.一般加个断点,调试几下就知道是什么问题.在最后找不到解决办法的情况下google了一下,短短几分钟解决了这个问题. 程序都是踩着各种坑 ...

  9. hibernate4 spring3.2 事务不提交分析

    最近在做微信项目,我搭建了一个基于servlet,spring3.2,hibernate4.1的框架.因为基于消息的servlet和基于业务层是分开做的,也就是先把业务层做了,再去将所有的请求转到业务 ...

  10. Android 中单位讲解

    1. dip(dp): device independent pixels(设备独立像素). dp也就是dip.这个和sp基本类似.如果设置表示长度.高度等属性时可以使用dp 或sp.但如果设置字体, ...