Mysql主从复制步骤
1.关闭防火墙
[root@CentOS ~]# chkconfig iptables off
2.关闭selinux
vi /etc/sysconfig/selinux
//将SELINUX=enforcing修改为disabled然后重启生效
红色安装mysql不是用的这个yum源,这个源没有。用的是163的yum源数据。
3、配置CentOS 6.0第三方yum源(CentOS默认的标准源里没有nginx软件包)
//下载wget工具
[root@CentOS ~]# yum install wget
//下载atomic yum源
[root@CentOS ~]# wget http://www.atomicorp.com/installers/atomic
[root@CentOS ~]# sh ./atomic
//安装提示输入时输yes
#更新yum软件包
[root@CentOS ~]# yum check-update
[root@CentOS ~]# yum remove mysql
7.安装mysql主从都要安装同一版本mysql
[root@CentOS ~]# yum install mysql mysql-server mysql-devel
[root@CentOS ~]# service mysqld start
[root@CentOS ~]# chkconfig --levels 235 mysqld on
//为root用户设置密码
[root@CentOS ~]# mysqladmin -u root password "wuapeng"
//mysql –u root –p登陆MySQL
MySQL 要设置如下才允许远程访问数据库:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
flush privileges;
(1)首先确保主从服务器上的Mysql版本相同
(2)在主服务器上,设置一个从数据库的账户,使用REPLICATION SLAVE赋予权限,如:
mysql> GRANT REPLICATION SLAVE ON *.* TO 'slave001'@'192.168.0.99' IDENTIFIED BY
'123456';
Query OK, 0 rows affected (0.13 sec)
(3)修改主数据库的配置文件my.cnf,开启BINLOG,并设置server-id的值,修改之后必须重启Mysql服务
[mysqld]
log-bin = mysql-bin
server-id=1
(4)之后可以得到主服务器当前二进制日志名和偏移量,这个操作的目的是为了在从数据库启动后,从这个点开始进行数据的恢复
mysql> show master status\G;
*************************** 1. row ***************************
File: mysql-bin.000003
Position: 243
Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)
(5)好了,现在可以停止主数据的的更新操作,并生成主数据库的备份,我们可以通过mysqldump到处数据到从数据库,当然了,你也可以直接用cp命令将数据文件复制到从数据库去
注意在导出数据之前先对主数据库进行READ LOCK,以保证数据的一致性
mysql> flush tables with read lock;
Query OK, 0 rows affected (0.19 sec)
之后是mysqldump
mysqldump -h127.0.0.1 -p3306 -uroot –p123456 test > /home/chenyz/test.sql
最好在主数据库备份完毕,恢复写操作
mysql> unlock tables;
Query OK, 0 rows affected (0.28 sec)
(6)将刚才主数据备份的test.sql复制到从数据库,进行导入
(7)接着修改从数据库的my.cnf,增加server-id参数,指定复制使用的用户,主数据库服务器的ip,端口以及开始执行复制日志的文件和位置
[mysqld]
server-id=21(要不一样两个)
log_bin = mysql-bin
replicate-do-db =test(这是要同步的数据库)
此时启动完数据库后,在从库上执行如下命令;master_host是主的IP,master_user是REPLICATION SLAVE的用户,master_password是其密码。master_log_file和master_log_pos可以不用写自己试的。写的话是主库的相应 show master status 显示的信息。
change master to master_host='192.168.0.100(主的IP)', master_user='slave', master_password='******', master_log_file='mysql-bin.000010', master_log_pos=16860;
(8)在从服务器上,启动slave进程
mysql> start slave;
(9)在从服务器进行show salve status验证
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: localhost
Master_User: root
Master_Port: 3306
Connect_Retry: 3
Master_Log_File: mysql-bin.003
Read_Master_Log_Pos: 79
Relay_Log_File: gbichot-relay-bin.003
Relay_Log_Pos: 548
Relay_Master_Log_File: mysql-bin .003
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
(10)好了,现在可以在我们的主服务器做一些更新的操作,然后在从服务器查看是否已经更新