1.复制概述

Mysql内建的复制功能是构建大型,高性能应用程序的基础。将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重新执行一遍来实现的。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环。这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。

请注意当你进行复制时,所有对复制中的表的更新必须在主服务器上进行。否则,你必须要小心,以避免用户对主服务器上的表进行的更新与对从服务器上的表所进行的更新之间的冲突。

1.1 mysql支持的复制类型:

  (1)基于语句的复制:在主服务器上执行的SQL语句,在从服务器上执行同样的语句。MySQL默认采用基于语句的复制,效率比较高。一旦发现没法精确复制时,会自动选着基于行的复制。
  (2)基于行的复制:把改变的内容复制过去,而不是把命令在从服务器上执行一遍. 从mysql5.0开始支持
  (3)混合类型的复制: 默认采用基于语句的复制,一旦发现基于语句的无法精确的复制时,就会采用基于行的复制。

1.2 复制解决的问题

MySQL复制技术有以下一些特点:
(1) 数据分布 (Data distribution )
(2) 负载平衡(load balancing)
(3) 备份(Backups)
(4) 高可用性和容错行 High availability and failover

1.3 复制如何工作

整体上来说,复制有3个步骤:

(1) master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events);
(2) slave将master的binary log events拷贝到它的中继日志(relay log);
(3) slave重做中继日志中的事件,将改变反映它自己的数据。

2 .复制配置

有两台MySQL数据库服务器Master和slave,Master为主服务器,slave为从服务器,初始状态时,Master和slave中的数据信息相同,当Master中的数据发生变化时,slave也跟着发生相应的变化,使得master和slave的数据信息同步,达到备份的目的。

要点:

负责在主、从服务器传输各种修改动作的媒介是主服务器的二进制变更日志,这个日志记载着需要传输给从服务器的各种修改动作。因此,主服务器必须激活二进制日志功能。从服务器必须具备足以让它连接主服务器并请求主服务器把二进制变更日志传输给它的权限。

一、安装MySQL

说明:在两台MySQL服务器192.168.21.169和192.168.21.168上分别进行如下操作,安装MySQL 5.5.22

二、配置MySQL主服务器(192.168.21.169)

mysql -u root -p #进入MySQL控制台create database AMT_DB; #建立数据库AMT_DBinsert into mysql.user(Host,User,Password) values ('localhost','archermind',password('123456')); #创建用户archermind,建立MySQL主从数据库同步用户replication密码123456 flush privileges; #刷新系统授权表#授权用户replication只能从192.168.21.168这个IP访问主服务器192.168.21.169上面的数据库,并且只具有数据库备份的权限grant replication slave on *.* to 'replication'@'192.168.21.168' identified by '123456' with grant option;复制代码

三、把MySQL主服务器192.168.21.169中的数据库AMT_DB导入到MySQL从服务器192.168.21.168中

1、导出数据库AMT_DB

mysqldump -u root -p AMT_DB > /home/replication.sql #在MySQL主服务器进行操作,导出数据库AMT_DB到/home/replication.sql复制代码

备注:在导出之前可以先进入MySQL控制台执行下面命令

flush tables with read lock; #数据库只读锁定命令,防止导出数据库的时候有数据写入unlock tables; #解除锁定复制代码

2、导入数据库到MySQL从服务器

mysql -u root -p #进入从服务器MySQL控制台create database AMT_DB; #创建数据库use AMT_DB #进入数据库source /home/replication.sql #导入备份文件到数据库mysql -u replication -h 192.168.21.169 -p #测试在从服务器上登录到主服务器复制代码

四、配置MySQL主服务器的my.cnf文件

#vim /etc/my.cnf #编辑配置文件,在[mysqld]部分添加下面内容  server-id=1 #设置服务器id,为1表示主服务器,注意:如果原来的配置文件中已经有这一行,就不用再添加了。  log_bin=mysql-bin #启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。  binlog-do-db=AMT_DB #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行  binlog-ignore-db=mysql #不同步mysql系统数据库#service mysqld restart #重启MySQL复制代码
mysql -u root -p #进入mysql控制台show master status; 查看主服务器,出现以下类似信息+------------------+----------+--------------+------------------+|File |Position | Binlog_Do_DB | Binlog_Ignore_DB |+------------------+----------+--------------+------------------+| mysql-bin.000001 | 7131 | AMT_DB |mysql |+------------------+----------+--------------+------------------+1 row in set (0.00 sec)复制代码

注意:这里记住File的值:mysql-bin.000001和Position的值:7131,后面会用到。

五、配置MySQL从服务器的my.cnf文件

#vim /etc/my.cnf #编辑配置文件,在[mysqld]部分添加下面内容server-id=2 #配置文件中已经有一行server-id=1,修改其值为2,表示为从数据库log-bin=mysql-bin #启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。replicate-do-db=AMT_DB #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行replicate-ignore-db=mysql #不同步mysql系统数据库:wq! #保存退出#service mysqld restart #重启MySQL复制代码

注意:MySQL 5.1.7版本之后,已经不支持把master配置属性写入my.cnf配置文件中了,只需要把同步的数据库和要忽略的数据库写入即可。

mysql -u root -p #进入MySQL控制台slave stop; #停止slave同步进程change master to master_host='192.168.21.169',master_user='replication',master_password='123456',master_log_file='mysql-bin.000001' ,master_log_pos=7131; #执行同步语句slave start; #开启slave同步进程SHOW SLAVE STATUSG #查看slave同步信息,出现以下内容*************************** 1. row *************************** Slave_IO_State:Waiting for master to send event Master_Host:192.168.21.169 Master_User:replication Master_Port:3306 Connect_Retry:60 Master_Log_File:mysql-bin.000001 Read_Master_Log_Pos:7131 Relay_Log_File:MySQLSlave-relay-bin.000001 Relay_Log_Pos:253 Relay_Master_Log_File:mysql-bin.000001 Slave_IO_Running:Yes Slave_SQL_Running:Yes Replicate_Do_DB:AMT_DB Replicate_Ignore_DB:mysql Replicate_Do_Table: Replicate_Ignore_Table:1 row in set (0.00 sec)复制代码

注意查看:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
以上这两个参数的值为Yes,即说明配置成功!

六、测试MySQL主从服务器双机热备是否成功

1、进入MySQL主服务器

mysql -u root-p #进入主服务器MySQL控制台use AMT_DB #进入数据库CREATETABLE test ( id int not null primary key,name char(20)); #创建test复制代码

2、进入MySQL从服务器

mysql -u root-p #进入MySQL控制台use AMT_DB #进入数据库show tables; #查看AMT_DB表结构,会看到有一个新建的表test,表示数据库同步成功复制代码

至此,MySQL数据库配置主从服务器实现双机热备

mysql 导出dmp文件_一文带你了解MySQL主从复制(Master-Slave)相关推荐

  1. mysql 导出dmp文件_Linux环境下使用crontab实现mysql定时备份

    在Linux服务器环境维护中,通常会mysqldump命令来备份数据库,通常命令如下 mysqldump -uusername -ppassword --databases databasename ...

  2. mysql 导出dmp文件_Mysql数据库的各种命令:

    一.连接MYSQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL. 首先打开DOS窗口,然后进入目录mysqlbin,再键入命令mysql -u root ...

  3. mysql 导出dmp文件_MySQL数据库基础讲解

    # 简介 MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),使用最常用的数据库管理语言(SQL)进行数据库管理. MySQL是开放源代码的,因此任何人都可以在General Publi ...

  4. mysql 导出dmp文件_PLSQL Developer导入导出表数据结构

    一.导出数据结构和表数据 导出表结构: 找到工具-->导出用户对象-->选择当前用户-->导出文件为xxx.sql位置自己选择(导出的只是数据结构) 导出表数据: 找到工具--> ...

  5. mysql 导出dmp文件_15款优秀的mysql管理工具与应用程序推荐

    对于开发人员来说,mysql管理工具可以说是必不可缺的,它能帮助开发人员在许多方面支持包括PostgreSQL.MySQL.Redis.MongoDB等在内的多种数据库:同时还能提供包括触发器.事件. ...

  6. rds mysql 导出数据文件_阿里云RDS上用mysqldump导入导出

    文章转载自: http://blog.csdn.net/jk0803_wantao/article/details/9179217 1. 开通云服务器服务. 2. 开通RDS服务,如果开通成功,会返回 ...

  7. stream模式不能接受blob文件_一文带你层层解锁文件下载的奥秘

    今天带来的主题是关于文件下载,通过本文带你领略文件下载的奥秘.本文会花费你较长的时间阅读,建议先收藏/点赞,然后查看你感兴趣的部分,平时也可以充当当做字典的效果来查询. :) 不整不知道,一整,居然整 ...

  8. php mysql导出csv文件_详解PHP导入导出CSV文件

    我们先准备mysql数据表,假设项目中有一张记录学生信息的表student,并有id,name,sex,age分别记录学生的姓名.性别.年龄等信息. CREATE TABLE `student` ( ...

  9. mysql三国人物库_一文带你使用neo4j生成三国人物社交关系图

    简介 最近给孩子买了三国演义,可是三国人物关系太复杂,就想着把三国人物关系做成一张图,这样方便看,整好neo4j图数据库非常适合社交关系的处理,下面就一起来看看,如何使用neo4j生成三国人物社交关系 ...

最新文章

  1. 记一次 Kubernetes 集群被入侵,服务器变矿机
  2. 极客广州——EOS Asia郭达峰担任SegmentFault思否黑客马拉松技术顾问
  3. [译]Java 设计模式之命令
  4. 程序员需要谨记的九大安全编码规则
  5. arraylist从大到小排序_java基础算法之二叉树排序(递归)
  6. 误删了公司数据库,但我还是活下来了
  7. 不吹牛逼,撸个注解有什么难的
  8. 选择排序----详细算法分析
  9. 【数值分析】—— 对数函数、指数函数(数值稳定性)
  10. vue3.0项目引入高德地图
  11. 2019-06-12-pintos 实验1
  12. 全新型号 Dell EMC PowerEdge R750xa机架式服务器 全新型号2U
  13. python连接传感器_关于树莓派Pi2通过UART连接攀藤G5传感器的python
  14. 红帽杯find_it
  15. kindle出现电池感叹号,充电黄灯亮,怎么解决?按AWZ客服的回复弄好了。
  16. CS61A 2022 fall lab0
  17. 智能投顾Betterment优于传统88%的收益率背后掩盖着什么真相?
  18. OKR文化:明确职责与庆功会
  19. rabbitmq关于delivery_tag
  20. 秒懂算法 | 搜索基础

热门文章

  1. 深入框架本源系列 —— Virtual Dom
  2. 阿里巴巴旗下平台口碑推出无人收银技术,改造便利店市场;重庆法院运用 AI 探索“智能判案”...
  3. 在 Angularjs 中 ui-sref 和 $state.go 如何传递参数
  4. Redis的编译安装
  5. Asp.Net MVC开源CMS - Orchard
  6. C#中的事件和委托(续)
  7. Eclipse常用插件下载地址
  8. 上凸包和下凸包_使用凸包聚类
  9. Pytorch高阶API示范——DNN二分类模型
  10. leetcode1267. 统计参与通信的服务器(dfs)