(转)mysql的单向复制

mysql的单向复制操作很简单:大概只需要二十分钟看完这篇文章就能搞定了。http://11837782.blog.51cto.com/11827782/1885967

为了提高主从服务器的健壮性,我们选择了mysql单向复制的方法,当主服务器宕机时,从服务器依旧可以接管,并且保持数据的相对完整性,而从服务器备份的时候不会干扰到主服务器的工作,可以说是一个强大的功能。

原理:将主服务器内数据更新封装为二进制文件的形式,发送到从服务器内更新,从服务器连接主服务器,主服务器也能得到它上次更新的位置。所有更新必须在主服务器上进行。

环境:rhel 6.5

主机:192.168.122.102(简称server2~)

次机:192.168.122.103 ( 简称server3~ )

首先在两台主机上安装mysql 环境(也可以选择多台从服务器),分别执行 

[[email protected] ~]# yum install mysqlmysql-server -y

[[email protected] ~]# yum install mysqlmysql-server -y

安装完毕后开始启动 server2 上的mysql,执行 

[[email protected] ~]# /etc/init.d/mysqld start

如上图,可以看到在开启mysql的时候出现了这种错误,这时需要删除以前的socker便可:执行

rm /var/lib/mysql/mysql.sock

可以看到这次启动就成功了然后在server2直接输入

mysql> GRANT REPLICATIONSLAVE,RELOAD,SUPER ON *.* TO [email protected]‘192.168.122.103‘ IDENTIFIED BY ‘adol‘;(建立主机的同步账号)

mysql> Flush privileges;

从而允许 server3来作为slave来登陆server2,继续在server2上更改/etc/my.cnf 文件

[[email protected] ~]# vim /etc/my.cnf

在[mysqld]内添加下面四行内容

log-bin=mysql-bin(启动二进制日志系统)

binlog-do-db=adol(二进制需要同步的数据库名)

server-id=1(必须为1到232–1之间的一个正整数值,而且不可重复)

binlog-ignore-db=mysql(避免同步 mysql 用户配置,以免不必要的麻烦)

:wq 退出保存

执行 /etc/init.d/mysql restart 更新配置

在server3上修改 /etc/my.cnf 文件

[[email protected] ~]# vim /etc/my.cnf

添加下列行到【mysqld】内

server-id=2 (不能与server2一样,这是身份标志位,联想身份证号)

master-host=192.168.122.102(主机server2的ip)

master-user=test (主机可用的用户名称)

master-password=adol(主机可用名对应的密码)

master-port=3306(3306是默认的mysql端口)

master-connect-retry=60(断开重新连接时间,单位是秒)

replicate-ignore-db=mysql(忽略避免同步的数据库MYSQL)

replicate-do-db=adol(需要同步的数据库)

[[email protected] ~]# /etc/init.d/mysqld restart (重启mysql)

在server2的mysql内执行

mysql> show master status;

可得出这样的结果,可获取它的File和position值。

在server3内进入数据库更新配置,如下

mysql> stop slave;

mysql> change master to master  changemaster_host=‘192.168.122.102‘,master_user=‘test‘,master_password=‘adol‘,master_log_file=‘mysql-bin.000002‘,master_log_pos=106;

mysql > start slave;

被颜色标记的就是我们从master 那里获得的数据。

Server3执行  mysql > show slave status\G

可以得到          Slave_IO_Running: Yes

Slave_SQL_Running: Yes

当他们的值为YES时,说明slave 就可以从master同步复制了。

检测:

我的Server2和server3内数据都如下

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| adol               |

| adold              |

| marjur             |

| mysql              |

| ooo                |

+--------------------+

6 rows in set (0.09 sec)

mysql> use adol;

Database changed

mysql> show tables;

+----------------+

| Tables_in_adol |

+----------------+

| a              |

| k              |

+----------------+

2 rows in set (0.00 sec)

现在在server2内添加表

mysql> create table dd(name varchar(20));

Query OK, 0 rows affected (0.06 sec)

在server3内进入数据库adol内执行

mysql> show tables;

可以看到,server3多出了一个为dd的表,说明单向复制是成功的。

(注意:默认复制只能复制adol数据库内的内容,adol外的内容变动不会对 

server3 产生影响 。)

时间: 2024-10-17 12:01:32

(转)mysql的单向复制的相关文章

mysql的单向复制

mysql单向复制    为了提高主从服务器的健壮性,我们选择了mysql单向复制的方法,当主服务器宕机时,从服务器依旧可以接管,并且保持数据的相对完整性,而从服务器备份的时候不会干扰到主服务器的工作,可以说是一个强大的功能. 原理:将主服务器内数据更新封装为二进制文件的形式,发送到从服务器内更新,从服务器连接主服务器,主服务器也能得到它上次更新的位置.所有更新必须在主服务器上进行. 环境:rhel 6.5 主机:192.168.122.102(简称server2~) 次机:192.168.12

MySQL 主从数据库设置

1.复制的介绍 MySQL 支持单向.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引 以跟踪日志循环.这些日志可以记录发送到从服务器的更新.当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置. 从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新. 请注意当你进行复制时,所有对复制中的表的更新必须在主服务器上进行.否则,你必须要小心,以避免用户对主服务器

mysql单向复制

mysql单向复制    为了提高主从服务器的健壮性,我们选择了mysql单向复制的方法,当主服务器宕机时,从服务器依旧可以接管,并且保持数据的相对完整性,而从服务器备份的时候不会干扰到主服务器的工作,可以说是一个强大的功能. 原理:将主服务器内数据更新封装为二进制文件的形式,发送到从服务器内更新,从服务器连接主服务器,主服务器也能得到它上次更新的位置.所有更新必须在主服务器上进行. 环境:rhel 6.5 主机:192.168.122.102(简称server2~) 次机:192.168.12

MySQL主从复制的配置

MySQL主从复制的配置 环境 操作系统:CentOS-6.6-x86_64-bin-DVD1.iso MySQL版本:mysql-5.6.26.tar.gz 主节点IP:192.168.1.205     主机名:edu-mysql-01 从节点IP:192.168.1.206     主机名:edu-mysql-02 主机配置:4核CPU.4G内存 依赖课程 <高可用架构篇--第13节--MySQL源码编译安装(CentOS-6.6+MySQL-5.6)> MySQL主从复制官方文档 ht

MySQL数据的主从复制、半同步复制和主主复制详解

一.MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费多久,不容乐观的未来,但是我们还是要能熟练掌握MySQL数据的架构和安全备份等功能,毕竟现在它还算是开源界的老大吧! MySQL数据库支持同步复制.单向.异步复制,在复制的过程中一个服务器充当主服务,而一个或多个服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环

mysql AB复制理论

Mysql AB复制(主从复制)理论 MySQL 支持单向.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.即从Master复制到一个或多个Slave上. 实现整个主从复制需要由Master上的IO进程,和Slave上的sql进程和IO进程共同完成.首先打开Master上的 binary log (bin-log)功能(修改配置文件),因为整个复制实际就是slave从master端获取相应的二进制日志,然后在slave端按顺序执行日志中的各种操作.(二进制日志几乎

mysql同步,replication

MySQL 支持单向.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环.这些日志可以记录发送到从服务器的更新.当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置. 从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新.请注意当你进行复制时,所有对复制中的表的更新必须在主服务器上进行.否则,你必须要小心,以避免用户对主服务器上的表进行的更新与对

mysql主从、主主配置

MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费多久,不容乐观的未来,但是我们还是要能熟练掌握MySQL数据的架构和安全备份等功能,毕竟现在它还算是开源界的老大吧! MySQL数据库支持同步复制.单向.异步复制,在复制的过程中一个服务器充当主服务,而一个或多个服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环.这

MySQL主从复制实现数据库服务器双机热备详细讲解

1.mysq主从复制简介 1.1.复制介绍 MySQL支持单向.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环.这些日志可以记录发送到从服务器的更新.当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置.从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新.如果你想要设置链式复制服务器,从服务器本身也可以充当主服务器.请注意当你进行复制时,所