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. Delphi接口的底层实现

    引言 接口是面向对象程序语言中一个很重要的元素,它被描述为一组服务的集合,对于客户端来说,我们关心的只是提供的服务,而不必关心服务是如何实现的:对于服务端的类来说,如果它想实现某种服务,实现与该服务相 ...

  2. 修改Http消息的消息头Host

    在 HttpURLConnection 类中直接使用如下代码无法修改Host的值: connection.setRequestProperty("Host", host); 需要在 ...

  3. JavaScript中的setInterval用法

    setInterval动作的作用是在播放动画的时,每隔一定时间就调用函数,方法或对象.可以使用本动作更新来自数据库的变量或更新时间显示.setInterval动作的语法格式如下:setInterval ...

  4. android listview中item通过viewpager实现《IT蓝豹》

    android listview中item通过viewpager实现 android listview中item通过viewpager实现,每一个item都支持viewpager实现图片切换功能.本项 ...

  5. tensorflow 高级api使用分布式之配置

    """Constructor. Sets the properties `cluster_spec`, `is_chief`, `master` (if `None` i ...

  6. 关于ubuntu14.04,忘记root密码解决方案(经测试,内核3.13和4.2可行)。

    网上已经有很多方案啦,我这里就不画蛇添足,直接上链接: http://jingyan.baidu.com/article/c843ea0b9e851077931e4aea.html 注意,有些机子没有 ...

  7. 指向字符串的指针和char类型的数组

    指针数组的效率比二维字符数组的效率高 指针数组不能修改字符串字面量,而二维字符数组中的内容可以更改

  8. 通过网址request到response经历的过程

    前言当我们在浏览器中输入一个网址,比如www.google.cn,浏览器就会加载出百度的主页.那么浏览器背后完成的具体是怎么样的呢? 总结起来大概的流程是这样的: (1)浏览器本身是一个客户端,当你输 ...

  9. JS-事件对象(鼠标键盘事件)

    一  事件对象 1 需要获取键盘和鼠标的信息的时候,用到事件对象.(e) 例如:document.onclick = function(e){ var  e = e || event;(做兼容) } ...

  10. SAP 000 客户端初始登录

    Solution 在SAP系统DB中删除账号SAP*,SAP系统会自动创建SAP*这个账号,然后初始密码是“PASS”,这样就获得Client 000 SAP*账号. Step by Step 以Or ...