redhat下MySQL主从备份

    在一家小公司做Java程序员,除了编代码,做的事情也很杂,这次有机会接触到MySQL数据的主从备份,之前部门老大有做过一次主从,也算是有一份check list照做,即使这样,中间还是出了很多问题,经过几天的折腾,今天算是把问题解决了,因此决定写一篇博客记录一下,方便以后遇上类似的问题的时候查看,也希望能给遇到相同问题的人带来帮助!

    前置条件:两台DB服务器,MySQL版本都是5.5.29,一个数据库在用,一个用来备份。

    目标:将两个db做成主从备份,实现自动备份

    步骤:1,停掉使用数据库的程序,以sql的形式备份数据库并将数据同步到备份数据库。

            2,编辑主数据库的/etc/my.cnf文件,在mysqld部分添加如下代码

                 

server-id = 1 #用来标识主数据库,如果有多个数据库做主从,这个数字要唯一 
log_bin = /var/log/mysql/mysql-bin.log #确保此文件可写 
read-only =0 #主机,读写都可以  
binlog-do-db =test #需要备份数据,多个写多行  
binlog-ignore-db=mysql #不需要备份的数据库,多个写多行

            3,修改了my.cnf文件,重启主数据库,service mysql restart

            4,创建备份用的数据库用户,并给从机授权,这里直接授权并刷新数据库权限,MySQL会自动先创建               用户

   

GRANT REPLICATION SLAVE ON *.* TO ‘slave’@’192.168.1.101‘ IDENTIFIED BY ‘123456’;
FLUSH PRIVILEGES;

               5,修改从机my.cnf文件,,在mysqld部分添加如下代码并重启MySQL

   

server-id = 2  
log_bin = /var/log/mysql/mysql-bin.log  
replicate-do-db =test #只复制某个库  
replicate-ignore-db=mysql #不复制某个库  

             6,在从机上设置主机的信息,登录mysql,执行下面的sql语句

  1. mysql>stop slave;  
  2. mysql>CHANGE MASTER TO MASTER_HOST=’192.168.1.100’, MASTER_USER=’slave’, MASTER_PASSWORD=’123456‘,   
  3. MASTER_LOG_FILE=’mysql-bin.0xx‘, MASTER_LOG_POS=33421;  
  4. mysql>start slave; 

             7,上面代码中的Master_host为主机的地址,master_user和pwd分别是主机上创建的用于备份的slave用户和对应的密码,master_log_file和log_pos非常重要,设置错了就很容易出现1236的错误

Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file'

           8,因此为了避免出错,在执行步骤6之前,先登录主机MySQL,执行下面的sql语句查看主机的log file和log pos,然后在步骤6执行sql语句的时候将对应的信息写对

show master status;

           9,上面的步骤完成之后,主从就算是配置好了,在从机上可以使用show slave status sql命令查看slave的状态,如果slave_io_running和slave_sql_running都显示yes表示成功了!可以在主数据库上执行更新和插入的操作,然后到从机数据库中验证!

           ps:最初是5.5.29版本,使用了上面的方法配置,没能成功,网上也找了很多原因,都以失败告终,今天将数据库版本替换成5.6.10之后使用上面的方法才配置成功的。先将数据备份好 ,rpm -qa|grep -i mysql查看已经安装的mysql,然后使用rpm  -e ***mysql的方法卸载mysql,清空/var/lib/mysql下的binlog和错误日志文件,清空后注意要编辑mysql-bin.index文件,将里面对应的信息删除,然后保存,安装时可以将原来配置好的my.cnf文件移走,等安装成功后再覆盖回来。

猜你喜欢

转载自focus-zhong.iteye.com/blog/1838412
今日推荐