mysql从3.23.15版本以后提供数据库复制功能。利用该功能可以实现两个数据库同步,主从模式(A->B),互相备份模式(A<=>B)的功能。

主从模式(A->B)的配置过程:

假设数据库A为主机、B为从机:
A机器:
IP = 192.168.1.101
B机器:
IP = 192.168.1.102

为了方便测试,分别在主机A、从机B,MYSQL中添加以下数据库以及表:

主机A中:

    CREATE DATABASE backup_db; 

    USE backup_db; 

    CREATE TABLE `backup_table` ( 

    `id` int(11) NOT NULL auto_increment, 

    `name` varchar(20) character set utf8 NOT NULL, 

    `sex` varchar(2) character set utf8 NOT NULL, 

    PRIMARY KEY (`id`) 

    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

从机B中:

CREATE DATABASE backup_db; 

USE backup_db; 

CREATE TABLE `backup_table` ( 

`id` int(11) NOT NULL auto_increment, 

`name` varchar(20) character set utf8 NOT NULL, 

`sex` varchar(2) character set utf8 NOT NULL, 

PRIMARY KEY (`id`) 

) ENGINE=InnoDB DEFAULT CHARSET=latin1;

1, 配置主机A的MYSQL配置文件、Linux下路径一般为:/etc/my.cnf,在配置文件中添加以下内容:

server-id=1

log-bin=/var/lib/mysql/mysqlback.log #同步事件的日志记录文件

binlog-do-db=backup_db #提供数据同步服务的数据库

2, 配置从机B的MYSQL配置文件、Linux下路径一般为:/etc/my.cnf,在配置文件中添加以下内容:

server-id=2

master-host=192.168.1.101 #主机A的地址

master-user=root #主机A提供给B的用户,该用户中需要包括数据库backup_db的权限

master-password=password #访问密码

master-port=3306 #端口,主机的MYSQL端口

master-connect-retry=60 #重试间隔60秒

replicate-do-db=backup_db #同步的数据库

注意:上面的配置,只适应MySQL5.5以前版本的,MySQL5.5以及之后的版本需要如下配置:

需要在从机B的MYSQL命令行执行:

change master to master_host='192.168.1.101', master_user='root', master_password='password';

#master_host='192.168.1.101' 主机A的地址

#master_user='root' 主机A提供给B的用户,该用户中需要包括数据库backup_db的权限

#master_password='password' 访问密码

3, 完成了以上配置之后,将A的mysql数据的权限给B

需要在主机A的MYSQL命令行执行:

grant replication slave on *.* to 'root'@'192.168.1.102' identified by 'password';

#'root'@'192.168..1.102' 从机B的的用户以及地址

#identified by 'passw0rd' 其中 'password'为从机B的密码

4, 重启AB数据库,后:

B机器:

mysql>start slave; #开启主从复制,stop slave; 为关闭主从复制

查看同步配置情况

A机器:

mysql>show master status \G;

B机器:

mysql>show slave status \G;

5, 在主机A数据库表中插入数据,看是否复制到从机B数据库表中,如果发现没有复制过去,可以查看mysql错误日志,根据错误提示调试,直至复制成功。

mysql错误日志的路径可以通过mysql命令查看:

mysql> show variables like 'log_error';
+---------------+--------------------------+
| Variable_name | Value                    |
+---------------+--------------------------+
| log_error     | /var/lib/mysql/mysql.err |
+---------------+--------------------------+

/var/lib/mysql/mysql.err 为mysql错误日志的路径

互相备份模式(A<=>B)的配置,重复上面的1-5步骤即可,不同的是调换AB的主从,即B为主机、A为从机。

Linux下 MYSQL 主从复制、同步的更多相关文章

  1. Linux下Mysql主从复制(Master-Slave)与读写分离(Amoeba)实践

    一.为什么要做Mysql的主从复制(读写分离)?通俗来讲,如果对数据库的读和写都在同一个数据库服务器中操作,业务系统性能会降低.为了提升业务系统性能,优化用户体验,可以通过做主从复制(读写分离)来减轻 ...

  2. Linux下MySQL主从复制(Binlog)的部署过程

    什么是 MySQL 的主从复制 Mysql内建的复制功能是构建大型高性能应用程序的基础, 将Mysql数据分布到多个系统上,这种分布机制是通过将Mysql某一台主机数据复制到其它主机(slaves)上 ...

  3. Linux下MySQL主从复制(GTID)+读写分离(ProxySQL)-实施笔记

    GTID概念: GTID( Global Transaction Identifier)全局事务标识.GTID 是 5.6 版本引入的一个有关于主从复制的重大改进,相对于之前版本基于 Binlog 文 ...

  4. mysql学习(3)-linux下mysql主从复制

    前言:为什么MySQL要做主从复制(读写分离)?通俗来讲,如果对数据库的读和写都在同一个数据库服务器中操作,业务系统性能会降低.为了提升业务系统性能,优化用户体验,可以通过做主从复制(读写分离)来减轻 ...

  5. Linux下MySQL主从同步配置

    Centos6.5 MySQL主从同步 MySQL版本5.6.25 主服务器:centos6.5 IP:192.168.1.101 从服务器:centos6.5 IP:192.168.1.102 一. ...

  6. linux下mysql主从复制,实现数据库同步

    运行环境: 查看linux版本命令:lsb_release -a 主服务器:centos release 6.5 mysql 5.6.10-log  IP:172.17.200.25从服务器:cent ...

  7. linux下mysql主从复制搭建

    目标:搭建两台MySQL服务器,一台作为主服务器,一台作为从服务器,实现主从复制 环境: 主数据库: 192.168.1.1 从数据库: 192.168.1.2 mysql安装可参考:https:// ...

  8. Linux下MySQL主从同步故障:"Slave_SQL_Running:No"的解决方法

    故障现象: 进入slave服务器,运行: mysql> show slave status\G          .......              Relay_Log_File: loc ...

  9. linux下mysql基于mycat做主从复制和读写分离之基础篇

    Linux下mysql基于mycat实现主从复制和读写分离1.基础设施 两台虚拟机:172.20.79.232(主) 172.20.79.233(从) 1.1软件设施 mysql5.6.39 , my ...

随机推荐

  1. linux 一个跟踪文件删除的小技巧

    最近有同事问我说他有个现场环境,经常会丢失业务文件,每天都出现,几百个里面丢失1到两个. 为了解决这个问题,我让他布置audit,具体可以man一下auditctl. 过了一天,他说audit.log ...

  2. 【384】reduce归纳、map映射、filter筛选 的用法

    参考:4. Map, Filter and Reduce — Python Tips 0.1 documentation 参考:Python的functools.reduce用法 Map:映射,对于列 ...

  3. jquery 初始化数据 添加html 第一次玩0.0

    /** * Created by Eee_xiang on 2018/04/12. * 联动响应事件 */ (function () { $.linkEvent = function (options ...

  4. Delphi动态配置ODBC数据源--SQL Server版本

    (摘自)http://jxlearnew.blog.163.com/blog/static/549786592007102451431413/ 这里介绍一种用Delphi来实现动态注册的方法,希望对各 ...

  5. 重装unbantu 问题集合,下载别人的代码运行问题集合

    安装angular 的时候要全局设置 npm install -g angular-cli nodemon server.js 出现[nodemon] Internal watch failed:xx ...

  6. (转)NHibernate+MySql常见问题

    http://blog.51cto.com/4837471/1567675 版本: NHibernate :NHibernate 4.0.1GA MySql:MySql 5.0.1 常见问题一: “N ...

  7. python批量操作Linux服务器脚本,key登录(执行命令、上传、下载)(二)

       -*-   2 #批量操作linux服务器(执行命令,上传,下载)   3 #!/usr/bin/python   4 import paramiko   5 import datetime   ...

  8. django中使用mysql数据库的事务

    django中怎么使用mysql数据库的事务   Mysql数据库事务: 在进行后端业务开始操作修改数据库时,可能会涉及到多张表的数据修改,对这些数据的修改应该是一个整体事务,即要么一起成功,要么一起 ...

  9. jquery iframe父子框架中的元素访问方法

    在web开发中,经常会用到iframe,难免会碰到需要在父窗口中使用iframe中的元素.或者在iframe框架中使用父窗口的元素 js 在父窗口中获取iframe中的元素 1. 格式:window. ...

  10. SQL语句中LEFT JOIN、JOIN、INNER JOIN、RIGHT JOIN的区别?

    w3school的一套sql教程: http://www.w3school.com.cn/sql/index.asp left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录.r ...