MySQL主从服务器的原理和设置

一 主从配置的原理
    mysql的Replication是一个异步的复制过程,从一个mysql
instance(Master)复制到另一个mysql instance(Slave),
在master与slave之间的整个复制过程主要由三个线程完成,分别为Master端得IO线程和Slave端得IO线程和Sql线程。整
个过程如下:
    1 Slave上的IO线程连接上Master,并请求从指定日志的指定位置之后的日志内容
    2 Master收到来自Slave的IO线程请求后,通过Master上的IO线程根据请求信息读取日志信息返回给Slave端IO线程。
      除了日志所包含的信息之外,还包含本次返回信息在Master端得Binary Log文件的名称以及位置
    3 Slave的IO线程接收到信息后,将接收到的日志内容依次写到Slave端得RelayLog文件末尾,并读取Master端得Binary
      Log文件名和位置记录到master-info中,以便下次的IO请求
    4 Slave的Sql线程检测到Relay Log中有新增内容后,马上解析可执行的Sql语句,并在本机上执行

二 设置过程
1 首先准备两台服务器:主服务器wwwlinuxidc.com 从服务器www.linuxidc.net

2 在主数据库服务器中为从服务器添加一个拥有访问主库的用户,其命令为:

GRANT REPLICATION SLAVE ON *.* TO ‘username’@’www.linuxidc.net’ IDENTIFIED BY ‘password‘

注: username是你创建的可以访问主库的用户名,IP为从机IP,password为用户登录密码
      添加后在从服务器上用 mysql -hwwwlinuxidc.com -uusername -ppassword 来测试下是否可以访问主数据库

3 修改主服务器的配置文件
   vi /etc/my.cnf
   server-id = 1  ##数据库服务器都有唯一的server-id,通常主服务器制定为1,www.linuxidc.com默认的配置文件中已经存在,特别注意从服务器配置中要将此行注释掉
   log-bin=mysql-bin ##mysql进行主从复制是通过二进制的日志文件来进行的,所以必须开启mysql的日志功能
   以上两行配置都已经存在,还需额外添加如下配置:
   log_bin = /home/mysql/mysql/log/mysql-bin.log #二进制文件存放目录,www.linuxidc.com可自行定义,但需注意目录有写权限
   read-only = 0 #主机读写都可以
   binlog-do-db = test1 #设定同步的数据库,多库可以多行设置
   binlog-do-db = test2
   binlog-ignore-db = test3 #设定不用同步的数据库,多库可以多行设置
   binlog-ingore-db = test4 17jquery.com

4 修改从服务器的配置文件
   vi /etc/my.cnf
   首先找到server-id = 1 这行,用#将这行注释掉,不然会和主机冲突,然后添加
   server-id = 2
   replicate-do-db = test1 #允许同步的数据库,多库可以多行设置
   replicate-do-db = test2
   replicate-ignore-db = test3 #不需同步的数据库,多库可以多行设置
   replicate-ignore-db = test4
   master-connect-retry=30
   master-host= wwwlinuxidc.com #主服务器地址
   master-user=username #刚刚添加访问主服务器的用户名
   master-password=password #主机密码
   master-port=3306
   read-only=1 #只允许读操作(连接用户不能有SUPER权限,否则无效)
5 重启主服务器和从服务器
  在主服务器上登录mysql 输入

show master status\G 
可查看主服务器状态
  在从服务器上登录

mysql start slave
(启动从机) 然后show slave  status \G ,如果以下两项都为yes即是从机配置成功。
     Slave_IO_Running: Yes
     Slave_SQL_Running: Yes
 
  从数据库服务器的通常操作命令有:
  start slave;  ####启动复制线程
  stop slave;   ####停止复制线程
  reset slave;  ####重置复制线程
  change master to; ###动态改变到主服务器的配置 如change master to master_user=‘username‘;

原文地址:https://www.cnblogs.com/raobenjun/p/8184371.html

时间: 2024-08-25 21:43:33

MySQL主从服务器的原理和设置的相关文章

mysql主从服务器复制原理

在实际企业应用环境当中,单台mysql数据库是不足以满足日后业务需求的.譬如服务器发生故障,没有备份服务器来提供服务的话,业务就得停止.介于这种情况,我们来学习一下mysql主从复制. 将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重新执行一遍来实现的.复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环.这些日志可以记录发送到从服

2-18,19 搭建MySQL主从服务器并并通过mysql-proxy实现读写分离

MySQL主从服务器 实现方式: MySQL  REPLICATION Replication可以实现将数据从一台数据库服务器(master)复制到一台或多台数据库服务器(slave) 默认情况下这种情况属于异步复制,无需维持长连接 通过配置,可以复制所有库或者几个库,甚至库中的一些表 它是MySQL内建的,自带 Replication的原理 主服务器master将数据库的改变写入二进制日志文件,从服务器slave同步这些二进制日志,并生成中继日志,从服务器根据中继日志,执行这些改变 DML:S

搭建mysql主从服务器

搭建mysql主从服务器: //注:注释掉my.cn文件中的skip-federated字段[[email protected] ]# /bin/cp -r /usr/local/mysql/share/mysql/my-huge.cnf  /etc/my.cnf 配置主服务器:修改my.cnf文件server-id=1 //每个数据库服务器都要指定唯一一个server-id log-bin=mysql-bin //mysql进行主从复制时通过二进制日志文件来进行的,所以必须开启mysql日志功

解读mysql主从配置及其原理分析(Master-Slave)

在windows下配置的,后面会在Linux下配置进行测试,需要配置mysql数据库同步的朋友可以参考下. 1.在主数据库服务器为从服务器添加一个拥有权限访问主库的用户:GRANT REPLICATION SLAVE ON *.* TO ' test'@'%' IDENTIFIED BY 'test'; (%表示允许所有IP,可设置指定从服务器IP)添加用户后:可在从服务器上用mysql -h127.0.0.1 -utest -ptest; 来测试是否有权限访问主数据库 2.在主据库配置文件加上

mysql主从服务器搭建

当业务流量过大时,我们的一台服务器可能难以负载,我们需要用到主从服务器的配置. 具体配置如下: 172.17.10.57位主服务器 172.17.55.206 从服务器 正确的安装数据库后,确保两台的能互通. mysql>GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456'; //一般不用root帐号,"%"表示所有客户端都可能连,只要帐号,密码正确,此处可用具体客户端IP代替,如192.16

mysql主从同步以及原理

mysql主从复制介绍 当前的生产工作中,大多数应用的mysql主从同步都是异步的复制方式,即不是严格实时的数据同步. 实时和异步: 同步复制: 指的是客户端连接到MySQL主服务器写入一段数据, MySQL主服务器同步给MySQL从服务器需要等待从服务器发出同步完成的响应才返回客户端OK, 这其中等待同步的过程是阻塞的, 如果有N台从服务器, 效率极低 异步复制: 指的是客户端连接到MySQL主服务器写入一段数据, MySQL主服务器将写入的数据发送给MySQL从服务器, 然后直接返回客户端O

mysql 主从服务器 切换

mysql 从服务器切换为主服务器: 步骤如下: 1 确认从服务器已经完成所有同步操作: stop slave io_thread  show processlist  直到看到状态都为:xxx has read all relay log 表示更新都执行完毕 2 停止从服务器slave服务 stop slave 3 将从服务器切换为主服务器: reset master 完成切换. PS: 如果从服务器设置了 read only 选项,则需要将这个参数去掉并重新启动数据库.

mysql主从服务器的配置

使用mysql主从复制的好处有: 1.采用主从服务器这种架构,稳定性得以提升.如果主服务器发生故障,我们可以使用从服务器来提供服务. 2.在主从服务器上分开处理用户的请求,可以提升数据处理效率. 3.将主服务器上的数据复制到从服务器上,保护数据免受意外的损失. 环境描述: 新企业要搭建架构为主从复制的mysql数据库. 主服务器(mysql-master):IP地址:192.168.48.128,mysql已安装,没有用户数据. 从服务器(mysql-slave):IP地址:192.168.48

MySQL主从服务器slave无法连接master:SSL连接错误:协议版本不匹配

首次发文 刚学2个月的小白在VM上练习主从复制时候遇到了一个错误: ERROR 2026 (HY000): SSL connection error: protocol version mismatch 在查看Firewalls和selinux都关闭后,无奈了 反复连接都是这个错误,换了服务器连接还是提示同样的错误,崩溃了 最后解决方法是 在主从服务器上分别在/etc/my.cnf文件下加入一行代码 skip_ssl 注意是两个都要加 保存,重启mysqld 然后可以连接了 go on!主从复制