更新

其实本文主要来自www.digitalocean.com ,但是我没有买他们家的 VPS 用来 demo 了.只是用vagrant 来模拟了.

介绍

说说关于通过两台 vps 来扩展 mysql. 之前我们说到了在2台 vps 直接通过nginx 来设置负载均衡, 你可以读读它

所谓 Mysql 的复制就是实时的把单一的数据集复制到另外一台服务器上. 这个配置称之为主从复制. 这是一个典型的操作配置. 我们接下来会有一个更加好的方案来实现. 以为多主(主-主)复制能够允许数据拷贝到的其他的服务器,这个大家都有,但是主要的不同在于能够提高单一服务器的读写性能. 这个设置会添加数据冗余,但是提高我们读取数据的性能.

假设我们下面的配置在2台 vps 上.我们称之为服务器 C 和服务器 D.

  • server c 3.3.3.3
  • server d 4.4.4.4

第一步, 安装和配置 mysql 在 c 机器上

首先,我们要安装mysql-server 和mysql-client 在服务器上,通过下面的命令来:

sudo apt-get install mysql-server mysql-client

mysql 默认只接受本地(127.0.0.1)的连接, 我们需要修改一些默认的配置来实现这个,我们需要修改/ etc/mysql/my.cnf 看到下面的内容:

#server-id              = 1
#log_bin = /var/log/mysql/mysql-bin.log
#binlog_do_db = include_database_name
bind-address = 127.0.0.1

第一行用来标示当前的服务器,在我们的这个mysql 复制的配置中,我们需要这个标示,我们把它注释取消.第二行说明当前的binlog目录. 第三行说明当前需要同步那个数据库. 当然你可以指定很多的数据库,但是这里我们就需要一个. 最后一行说明我们允许连接的客户端在哪里.我们不需要本地的连接.注释了.

server-id               = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = example
# bind-address = 127.0.0.1

重启服务器:

sudo service mysql restart

接下来,我们需要通过mysql 命令行来修改一些设置,

mysql -uroot -p

成功登陆之后,

mysql>

我们需要创建一个用户,用来复制数据, 我们给他叫replicator, 密码自取.

create user 'replicator'@'%' identified by 'password';

然后给他权限来复制数据.

grant replication slave on *.* to 'replicator'@'%';

这个用户不能够复制所有的库,它只能复制在配置文件中指定的数据库.

接下来,我们需要获取当前mysql server 的一些状态, 它会被用在之后的服务器 D 的设置上. 基本上就完成了本服务器的设置.

show master status;

它会输出下面的一些信息:

+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | example | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

第二步,安装配置服务器 D

刚开始的步骤是一样的,就是按照 mysql 服务器和客户端, 然后修改配置文件:

/etc/mysql/my.cnf

这个时候,它和 c 服务器有点区别, 我们会把它改为下面的内容:

server-id              = 2
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = example
# bind-address = 127.0.0.1

之后重启服务器, 登录创建用户.

sudo service mysql restart
mysql -u root -p 
create user 'replicator'@'%' identified by 'password';

接下来,需要在 d 这里创建一个数据库example,那个你想要同步的数据库.

create database example;

接着给这个用户权限用来复制:

grant replication slave on *.* to 'replicator'@'%';

下面就是最关键的一步了. 通过我们在 c 服务器上获取的信息连通两台服务器.

还是在 D 服务器 mysqlclient 上,键入下面的命令:

slave stop;
change master to master_host = '3.3.3.3', master_user = 'replicator', master_password = 'password', MASTER_LOG_FILE = 'mysql-bin.000001', MASTER_LOG_POS = 107;
slave start; 这里关于`MASTER_LOG_FILE`和`MASTER_LOG_POS`,他们就是来自 c 服务器上 status 输出的信息. 现在 D 是挂到了 C 上,我们需要反过来把 C 也挂到 D 上,查看一下 D 的` master status`:

show master status

+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000004 | 107 | example | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

第三步,在 C 上完成复制

其实很上面的设置一样的,就是:

slave stop;
CHANGE MASTER TO MASTER_HOST = '4.4.4.4', MASTER_USER = 'replicator', MASTER_PASSWORD = 'password', MASTER_LOG_FILE = 'mysql-bin.000004', MASTER_LOG_POS = 107;
slave start;

注意修改你对应的 mysql 输出的信息,还有你的密码

上面的命令 mysql 会输出下面的类似信息:

Query OK, 0 rows affected (0.01 sec)

到这里,配置已经完成.

测试

我们这样,在 c 上创建一个表,然后在 d 上把它干掉,看看 c 上还有没有.

create database example;
create table example.dummy (id varchar(10)); #note here is ` not '

然后在 d 上看看有没有这个表:

show tables in example;

你会看到:

+-------------------+
| Tables_in_example |
+-------------------+
| dummy |
+-------------------+
1 row in set (0.00 sec)

然后在 d 上:

drop table dummy;

c 上:

show tables;

你会看到:

Empty set (0.00 sec)

see more

http://qiita.com/xiangzhuyuan/items/b366eb5463d7b56e1aaa

怎么设置 mysql 多主复制的更多相关文章

  1. 分布式数据存储 - MySQL双主复制

    上篇文章<分布式数据存储 - MySQL主从复制>,我们说到MySQL主从复制很好的保障了从库,读的高可用性.so,问题来了: 1.针对主库,写的高可用性又是如何做到高可用性? 2.如果需 ...

  2. MySQL双主复制

    原文发表于cu:2017-06-12 本文简单介绍MySQL双主复制原理及1个简单是双主复制验证. 一.MySQL双主复制原理 1. 双主复制原理 master-master复制的两台服务器,既是ma ...

  3. keepalived+mysql双主复制高可用方案

    MySQL双主复制,即互为Master-Slave(只有一个Master提供写操作),可以实现数据库服务器的热备,但是一个Master宕机后不能实现动态切换.而Keepalived通过虚拟IP,实现了 ...

  4. 利用LVS+Keepalived搭建Mysql双主复制高可用负载均衡环境

    应用背景: MySQL复制(主主,主从...)能在保证数据的备份的同时也能够做读写分离分摊系统压力,但是发生单点故障时,需要手动 切换到另外一台主机.LVS和Keppalived可以设定一个VIP来实 ...

  5. linux环境下配置mysql双主复制

    简单来说,双主复制就是让两台mysql服务器中的数据保持同步,可以用来实现灾备和负载均衡 主机1 IP:192.168.200.128 主机2 IP:192.168.200.131 两台主机系统均为c ...

  6. keeplived + mysql双主复制部署 --原创

    环境: master 1: 192.168.100.10  oracle  linux 7.4  mysql 5.7.1 master 2: 192.168.100.11 oracle  linux ...

  7. mysql 双主复制 centos7

    mysql 安装请看:http://www.cnblogs.com/leohe/p/6839705.html 双主复制设置 1. 两台虚拟机,都是 centos7 主: 10.1.1.115 从: 1 ...

  8. mysql双主复制总结

    双主复制: 1).在两台服务器上各自建立一个具有复制权限的用户: 2).修改配置文件: # 主服务器A上 [mysqld] server-id = 10 log-bin = mysql-bin rel ...

  9. 配置mysql为主主复制步骤

    mysql版本:mysql-5.6.24-solaris10-sparc-64bit.tar 操作系统:solaris 11g u10 操作用户:使用非root进行操作安装,a路服务器ip地址为192 ...

随机推荐

  1. window.location.hash

    我们知道JavaScript中很早就提供了window.history对象,利用history对象的forward().go().back()方法能够方便实现不同页面之间的前进.后退等这种导航功能.但 ...

  2. 学习日记day7:代码结构规范

    1:绝对定位不是随便用的. 2:一定要用相对定位控制文档流,在相对定位里面使用绝对定位控制具体的位置. 3:代码结构尽量简化. 不要加不必要的span: 不要加不必要的类: 4:控制字体样式的类尽量写 ...

  3. 使用Mozilla Firefox插件RestClient测试Http API接口

    RESTClient是Mozilla Firefox一个用于测试http请求插件.在火狐附加组件里面查询并安装,非常小巧,界面非常简单,使用非常的方便,看下面这张图你就全明白了,希望对新手有帮助! 1 ...

  4. 转:union 联合体(共用体)

    转自:http://blog.csdn.net/xiao3404/article/details/22276485 2.共用体 2.1共用体的概念 共用体是一种构造类型的数据结构.在一个“共用体”内可 ...

  5. OpenGL的glClearColor和glClear改变背景颜色

    OpenGL的glClearColor和glClear改变背景颜色 结合以下两个函数void glClearColor(GLclampf red,    GLclampf green, GLclamp ...

  6. 转!!MYSQL数据类型

    这篇文章主要介绍了MySQL数据类型和常用字段属性总结,本文总结了日期和时间数据类型.数值数据类型.字符串数据类型等,需要的朋友可以参考下     前言 好比C++中,定义int类型需要多少字节,定义 ...

  7. 【Python】输出中文字符串的两种方法

    print u"中文"   # -*- coding: utf-8 -*-   这句话放在最上面,记得是最上面,顶格写 这样,print后,字符串前就不用加u了

  8. dom4j解析xml作为测试数据

    构造函数: public AppTestData(File xmlFile) throws Exception { file = xmlFile; try { saxReader = new SAXR ...

  9. Hibernate的Restrictions用法

    Restrictions.eq --> equal,等于. Restrictions.allEq --> 参数为Map对象,使用key/value进行多个等于的比对,相当于多个Restri ...

  10. 队列中使用Database Driver

    队列允许你将一个耗时的任务进行延迟处理. 首先要在.evn文件中配置 QUEUE_DRIVER=database 要使用 database 这个队列驱动的话,则需要创建一个数据表来记住任务,使用命令: ...