MySQL数据同步-复制
2012-09-22 17:39
295 查看
一,复制的基本步骤
建立一个简单的复制只需要三个步骤
配置一个服务器作为主库,就是Master库。
配置另一个服务器作为从库,就是slave库。
将从库连接到主库。
二,配置主库
将服务器配置为主库,必要条件是该服务器有一个活动的二进制日志和唯一的服务器ID,这个二进制日志上保存了所有在主库上的数据改变,而服务器ID用于区分标识服务器。要创建二进制日志和服务器ID,需要先将服务器停止,然后配置my.cnf配置文件。
在主库的操作主要包括两上部分,配置二进制日志文件以及添加用于复制的账户;
2.1 配置二进制日志文件
我在我主库的配置文件里添加下面三行:
其实除了这三个配置以外,也可以加一些其它的配置,比如binlog-ignore-db配置不需要同步的数据库等等
2.2 添加复制账户
创建账户 : create user repl_user;
给账户复制权限:grant replication slave on *.* to repl_user identified by 'pwd';
三,配置从库
配置完主库之后,还需要配置从库。和主库一样,需要为每个从库分配一个唯一的服务器ID,并添加中继日志文件和中继日志索引文件。如果不添加文件名,会根据hostname有一个默认的文件。
我在从库所在的配置文件里添加:
四,连接主库和从库
这一步的主要目的是将从库指向主库,让从库知道数据应该从哪个地方复制过来。我们需要了解关于主库的几个基本的信息:
主机名
端口号
主库上拥有REPLICATION SLAVE权限的用户账户。
该用户的受权密码。
使用 CHANGE MASTER TO 命令将从库指向主库,然后使用 START SLAVE 命令启动复制。
CHANGE MASTER TO MASTER_HOST='192.168.1.105', MASTER_PORT=3306 ,MASTER_USER='repl_user' ,MASTER_PASSWORD='pwd';
这个命令除了这几个参数外,还可以有一些其它的参数,比如设置些次同步的文件MASTER_LOG_FILE,文件的偏移值MASTER_LOG_POS,甚至还可以设置连接主库不成功时重试的次数MASTER_CONNECT_RETRY等参数。
这个命令执行完之后,就可以启动从库了。
在启动完从库之后,用 SHOW SLAVE STATUS命令查看从库是否正常工作。主要是IO和MYSQL线程状态是否正常,当Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行,如果出现错误,可以从Last_Error这个参数中看出哪里出错,然后进行排查。。
在这以后,在主库上的任何改动,从库也会随之而改动。
按照上面的操作,经测试,数据库可以正常复制
五,维护主库的主要命令
show processlist; 查询当前的MYSQL进程。
show master status
show slave hosts
show {master|binary} logs
show binlog events
purge {master|binary} logs to 'log_name'
purge {master|binary} logs before 'date'
reset master(老版本flush master)
set sql_log_bin={0|1}
六,维护从库的主要命令
slave start
slave stop
slave stop IO_THREAD //此线程把master段的日志写到本地
slave start IO_THREAD
slave stop SQL_THREAD //此线程把写到本地的日志应用于数据库
slave start SQL_THREAD
reset slave
set global sql_slave_skip_counter
load data from master
show slave status(SUPER,REPLICATION CLIENT)
CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= //动态改变master信息
PURGE MASTER [before 'date'] 删除master端已同步过的日志
建立一个简单的复制只需要三个步骤
配置一个服务器作为主库,就是Master库。
配置另一个服务器作为从库,就是slave库。
将从库连接到主库。
二,配置主库
将服务器配置为主库,必要条件是该服务器有一个活动的二进制日志和唯一的服务器ID,这个二进制日志上保存了所有在主库上的数据改变,而服务器ID用于区分标识服务器。要创建二进制日志和服务器ID,需要先将服务器停止,然后配置my.cnf配置文件。
在主库的操作主要包括两上部分,配置二进制日志文件以及添加用于复制的账户;
2.1 配置二进制日志文件
我在我主库的配置文件里添加下面三行:
log-bin =master-bin log-bin-index =master-bin.index server-id =1在我添加这三行之后,重新启动服务,发现在数据目录下多出了两个文件: master-bin.000001,master-bin.index。这两个文件在主从同步中,起到很大的作用。
其实除了这三个配置以外,也可以加一些其它的配置,比如binlog-ignore-db配置不需要同步的数据库等等
2.2 添加复制账户
创建账户 : create user repl_user;
给账户复制权限:grant replication slave on *.* to repl_user identified by 'pwd';
三,配置从库
配置完主库之后,还需要配置从库。和主库一样,需要为每个从库分配一个唯一的服务器ID,并添加中继日志文件和中继日志索引文件。如果不添加文件名,会根据hostname有一个默认的文件。
我在从库所在的配置文件里添加:
server-id =2 relay-log-index =slave-relay-bin.index relay-log =slave-relay-bin
四,连接主库和从库
这一步的主要目的是将从库指向主库,让从库知道数据应该从哪个地方复制过来。我们需要了解关于主库的几个基本的信息:
主机名
端口号
主库上拥有REPLICATION SLAVE权限的用户账户。
该用户的受权密码。
使用 CHANGE MASTER TO 命令将从库指向主库,然后使用 START SLAVE 命令启动复制。
CHANGE MASTER TO MASTER_HOST='192.168.1.105', MASTER_PORT=3306 ,MASTER_USER='repl_user' ,MASTER_PASSWORD='pwd';
这个命令除了这几个参数外,还可以有一些其它的参数,比如设置些次同步的文件MASTER_LOG_FILE,文件的偏移值MASTER_LOG_POS,甚至还可以设置连接主库不成功时重试的次数MASTER_CONNECT_RETRY等参数。
这个命令执行完之后,就可以启动从库了。
在启动完从库之后,用 SHOW SLAVE STATUS命令查看从库是否正常工作。主要是IO和MYSQL线程状态是否正常,当Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行,如果出现错误,可以从Last_Error这个参数中看出哪里出错,然后进行排查。。
在这以后,在主库上的任何改动,从库也会随之而改动。
按照上面的操作,经测试,数据库可以正常复制
五,维护主库的主要命令
show processlist; 查询当前的MYSQL进程。
show master status
show slave hosts
show {master|binary} logs
show binlog events
purge {master|binary} logs to 'log_name'
purge {master|binary} logs before 'date'
reset master(老版本flush master)
set sql_log_bin={0|1}
六,维护从库的主要命令
slave start
slave stop
slave stop IO_THREAD //此线程把master段的日志写到本地
slave start IO_THREAD
slave stop SQL_THREAD //此线程把写到本地的日志应用于数据库
slave start SQL_THREAD
reset slave
set global sql_slave_skip_counter
load data from master
show slave status(SUPER,REPLICATION CLIENT)
CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= //动态改变master信息
PURGE MASTER [before 'date'] 删除master端已同步过的日志
相关文章推荐
- MySQL数据的主从复制、半同步复制和主主复制详解
- mysql主从复制显示正常,数据没同步现象。
- MYSQL数据同步、复制、分发
- MySQL数据的主从复制、半同步复制和主主复制详解
- 运维工程师必备之MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解-转
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解
- 多个mysql服务器的数据同步复制
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL5.6主从复制(mysql数据同步配置)
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL5.7主从复制配置,数据同步
- MySQL 半同步复制数据安全与一致性分析
- 运维工程师必备之MySQL数据的主从复制、半同步复制和主主复制详解
- MySQL数据的主从复制、半同步复制和主主复制详解-转
- MySQL5.6主从复制(mysql数据同步配置)