mysql主从同步备份方案-

 

环境:
主服务器上的MySQL数据库版本同为5.5.29
主机IP:192.168.0.1
从机IP:192.168.0.2


一. MySQL主服务器配置(0.1机器)


1.编辑配置文件/data/dbroot/my.cnf

# 确保有如下行
server-id = 1
log-bin=mysql-bin
binlog-do-db = home  #需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
binlog-do-db = uc
binlog-do-db = edm
binlog-ignore-db=mysql  #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作

2.建立用户


先进入mysql
    mysql -u root -p pwd
建立用户
    grant replication slave on *.* to ‘用户名’@'主机’ identified by ‘密码’;
mysql> grant replication slave on *.* to [email protected] identified by ‘123456′;

# 可在Slave上做连接测试: mysql -h  -u test -p (在从服务器上0.2上测试这个)

3.锁主库表(为了记录file和position保持一致,也可以不锁表)

mysql> FLUSH TABLES WITH READ LOCK;

4.显示主库信息

记录File和Position,从库设置将会用到(0.2那台设置用到这个。)

=====================
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_do_db | Binlog_ignore_db |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 106      |              |                  |
+------------------+----------+--------------+------------------+

    ps:如果这里没有显示结果,需要重启一下mysql,再查看,

5.另开一个终端,打包主库


cd /data/dbroot/  #mysql库目录
tar zcvf home.tar.gz home

============================


二.MySQL从服务器配置(0.2机器)

1、传输拿到主库数据包、解包
    mysql根目录 /usr/local/mysql/data
    scp [email protected]:/data/dbroot/home.tar.gz /usr/local/mysql/data
    tar zxvf home.tar.gz

2.编辑 /etc/my.cnf (如果没有就创建一个)
    server-id=2
    log-bin=mysql-bin
    master-host=192.168.0.1 <主服务器地址>
    master-user=test       <主服务器上创建的用户名>
    master-password=123456
    master-port=3306
    replicate-do-db=home  #需要备份的数据库名

    replicate-ignore-db=mysql #忽略的数据库
    master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
    log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
    slave-skip-errors #是跳过错误,继续执行复制操作

3、验证连接MASTER


    # mysql -h 192.168.0.1 -u test -p  123456
    mysql> show grants for [email protected];
    验证完记得quit;

4、在SLAVE上设置同步
    #mysql -u root -p

    设置连接MASTER MASTER_LOG_FILE为主库的File,MASTER_LOG_POS为主库的Position (就是主服务器执行SHOW MASTER STATUS;得的结果)
    ============================
    mysql> slave stop;
    mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.1',MASTER_USER='test',MASTER_PASSWORD='123456',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=106;

5、启动SLAVE服务

mysql> slave start;

6、查看SLAVE状态

mysql> SHOW SLAVE STATUS\G;
其中 Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行。
mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.0.1
                  Master_User: test
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 85783
                Relay_Log_Pos: 30477
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB:
          Replicate_Ignore_DB:


三、 解锁主库表(主服务器的0.1机器)

mysql> UNLOCK TABLES;
到此主从库搭建成功。可以在主库上插入数据测试同步是否正常。

 

【转】http://blog.sina.com.cn/s/blog_777af16d0101lego.html

 

http://my.oschina.net/u/1169079/blog/228957

http://www.jb51.net/article/27221.htm

http://my.oschina.net/innovation/blog/283024

猜你喜欢

转载自lehsyh.iteye.com/blog/2181729
今日推荐