服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - 基于MySQL Master Slave同步配置的操作详解

基于MySQL Master Slave同步配置的操作详解

2019-12-30 15:39MYSQL教程网 Mysql

本篇文章是对MySQL Master Slave 同步配置进行了详细的分析介绍,需要的朋友参考下

环境:
PC:ubuntu 10.10  192.168.1.112(master) 192.168.10.245(slave) 
MySQL : 5.1.49-1ubuntu8.1-log

在master中已经存在数据库test 
首先修改mysql配置文件:/etc/mysql/my.cnf
[master]
#author:zhxia 

复制代码代码如下:


 #master 同步设置
 server-id               = 1
 log_bin                 = /var/log/mysql/mysql-test-bin.log
 expire_logs_days        = 10
 max_binlog_size         = 100M 
 binlog_format           =mixed


[slave]
#author:zhxia 

复制代码代码如下:


server-id               = 2
 replicate-do-db=test
 replicate-do-db=blog
 log_bin                 = /var/log/mysql/mysql-bin.log
 relay_log               =/var/log/mysql/mysql-relay-bin.log
 expire_logs_days        = 10
 max_binlog_size         = 100M
 #binlog_do_db           = test
 #binlog_ignore_db       = include_database_name
 binlog_format           = mixed
 slave-net-timeout=6012 master-connect-retry=10


接着在master上创建备份帐号

复制代码代码如下:


grant replication slave,replication client on *.* to 'slave'@'192.168.10.245' identified by '123456'; 


将master中的数据库 导入到slave中,
先锁表,禁止写入操作
flush tables with read lock; 
先从master导出:mysqldump -uroot -p test > /tmp/test.sql
再导入到slave: mysql -uroot -p test < /tmp/test.sql ,记得需要先建库test
进入master上的mysql,查看master状态

#author:zhxia 

复制代码代码如下:


mysql> show master status;
 +-----------------------+----------+--------------+------------------+
 | File                  | Position | Binlog_Do_DB | Binlog_Ignore_DB |
 +-----------------------+----------+--------------+------------------+
 | mysql-test-bin.000022 |      624 |              |                  |
 +-----------------------+----------+--------------+------------------+
 1 row in set (0.02 sec)


进入slave上的Mysql
#author:zhxia 

复制代码代码如下:


change master to  master_host='192.168.1.112', master_user='slave', master_password='123456', master_log_file='mysql-test-bin.000022', master_log_pos=106;


然后启动salve,并查看状态:  
#author:zhxia

复制代码代码如下:


start slave;

 mysql> show slave status\G;
 *************************** 1. row ***************************
                Slave_IO_State: Waiting for master to send event
                   Master_Host: 192.168.1.112
                   Master_User: slave
                   Master_Port: 3306
                 Connect_Retry: 60
               Master_Log_File: mysql-test-bin.000022
           Read_Master_Log_Pos: 624
                Relay_Log_File: mysql-relay-bin.000005
                 Relay_Log_Pos: 533
         Relay_Master_Log_File: mysql-test-bin.000022
              Slave_IO_Running: Yes
             Slave_SQL_Running: Yes
               Replicate_Do_DB: test,blog
           Replicate_Ignore_DB: 
            Replicate_Do_Table: 
        Replicate_Ignore_Table: 
       Replicate_Wild_Do_Table: 
   Replicate_Wild_Ignore_Table: 
                    Last_Errno: 0
                    Last_Error: 
                  Skip_Counter: 0
           Exec_Master_Log_Pos: 624
               Relay_Log_Space: 688
               Until_Condition: None
                Until_Log_File: 
                 Until_Log_Pos: 0
            Master_SSL_Allowed: No
            Master_SSL_CA_File: 
            Master_SSL_CA_Path: 
               Master_SSL_Cert: 
             Master_SSL_Cipher: 
                Master_SSL_Key: 
         Seconds_Behind_Master: 0
 Master_SSL_Verify_Server_Cert: No
                 Last_IO_Errno: 0
                 Last_IO_Error: 
                Last_SQL_Errno: 0
                Last_SQL_Error: 
 1 row in set (0.00 sec)

 ERROR: 
 No query specified


最后将master上的表解锁
 unlock tables;

延伸 · 阅读

精彩推荐
  • Mysqlmysql事务处理用法与实例代码详解

    mysql事务处理用法与实例代码详解

    这篇文章主要介绍了mysql事务处理用法与实例代码详解,详细的介绍了事物的特性和用法并实现php和mysql事务处理例子,非常具有实用价值,需要的朋友可以...

    咸鱼想翻身4302019-06-12
  • Mysqlmysql 日期和时间函数

    mysql 日期和时间函数

    这里是一个使用日期函数的例子。下面的查询选择所有 date_col 值在最后 30 天内的记录。 ...

    mysql教程网3342019-11-04
  • MysqlDebian 6.02 (squeeze)下编译安装 MySQL 5.5的方法

    Debian 6.02 (squeeze)下编译安装 MySQL 5.5的方法

    Debian 6.02 (squeeze)下编译安装 MySQL 5.5的方法,需要的朋友可以参考下。 ...

    MYSQL教程网3542019-11-27
  • Mysqlmysql命令提示行连接乱码的解决

    mysql命令提示行连接乱码的解决

    今天在dos下连接mysql数据库的时候,出现了乱码,需要的朋友可以参考下。 ...

    MYSQL教程网3572019-11-18
  • Mysql彻底卸载MySQL的方法分享

    彻底卸载MySQL的方法分享

    由于安装MySQL的时候,疏忽没有选择底层编码方式,采用默认的ASCII的编码格式,于是接二连三的中文转换问题随之而来,就想卸载了重新安装MYSQL,这一卸...

    MYSQL教程网2822019-11-22
  • Mysql更新text字段时出现Row size too large报错应付措施

    更新text字段时出现Row size too large报错应付措施

    个人建议:表的text字段很多建议建表时加上 row_format = dynamic当然,回过头来MySQL的报错也是有误导性的,感兴趣的你可以参考下本文 ...

    MYSQL教程网4372019-12-19
  • Mysql配置MySQL与卸载MySQL实例操作

    配置MySQL与卸载MySQL实例操作

    我们主要介绍的是正确通过rpm包安装、对MySQL进行配置与卸载的实际操作步骤,以下就是文章的具体内容描述,望你会有所收获。 ...

    MySQL教程网2982019-11-11
  • MysqlMySql 备忘录

    MySql 备忘录

    在MySQL中如果不为NOT NULL字段赋值(等同于赋NULL值)也就是说,MySQL中NOT NULL并不是一个约束条件了 ...

    MYSQL教程网3302019-12-01