mysql主从配置与数据移植

配置mysql的主从模式,当一台mysql出现问题后,另外一台可以正常工作。
两台机器IP:192.168.1.60(master)、192.168.1.61(slave)
注意:在配置之前,确保两台节点都有需同步的数据库。

1、master节点配置

1.1、修改配置文件

192.168.1.60:master节点
vim /etc/my.cnf
添加如下内容:

 [mysqld]
 log-error=/data/mysql_log/error.log  # mysql的error日志
 log=/data/mysql_log/mysql.log  # mysql的操作日志
 log-bin=/data/mysql_log/binlog  # 配置binlog,通过binlog将两个mysql同步
 server-id=1  # 配置本台机器mysql的id
 binlog-do-db = mytest # 配置需要同步的数据库

1.2、master节点需要授权slave节点访问

mysql>GRANT REPLICATION SLAVE ON *.* to 'root'@'192.168.1.61' identified by 'test123456';
mysql>FLUSH PRIVILEGES;

如果要允许所有主机访问,用%代替ip即可:

mysql>GRANT REPLICATION SLAVE ON *.* to 'root'@'%' identified by 'test123456';
mysql>FLUSH PRIVILEGES;

1.3、重启服务

service mysqld restart
重启服务的过程中可能遇到启动失败的情况:

/usr/local/mysql/bin/mysqld: File '/data/mysql_log/binlog.index' not found (Errcode: 13)

这个主要是因为这个目录mysql用户没有权限导致的。
chown mysql /data/mysql_log 即可解决问题。

1.4、查看master进程的状态

MySQL [mytest]> show master status;
+---------------+----------+--------------+------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| binlog.000004 |      106 | mytest       |                  |
+---------------+----------+--------------+------------------+
1 row in set (0.00 sec)

slave节点配置

192.168.1.61:slave节点

2.1、修改配置文件

vim /etc/my.cnf
添加如下内容:

[mysqld]
log-error=/data/mysql_log/error.log  # mysql的error日志
log=/data/mysql_log/mysql.log  # mysql的操作日志
server-id=2  # 配置本台机器mysql的id
master-host=192.168.1.60  # master节点的ip
master-user=root  # 访问master节点的用户名
master-password=test123456  # 访问master节点的密码
master-port=3306  # 访问master节点的端口
replicate-do-db=mytest  # 配置需要同步的数据库

2.2 启动slave进程

mysql> slave start;
Query OK, 0 rows affected (0.04 sec)

2.3 查看slave状态

MySQL [mytest]> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 100.110.5.77
                  Master_User: root
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: binlog.000004
          Read_Master_Log_Pos: 106
               Relay_Log_File: TENCENT64-relay-bin.000014
                Relay_Log_Pos: 248
        Relay_Master_Log_File: binlog.000004
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: mytest
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 

看到Slave_IO_Running: Yes 和 Slave_SQL_Running: Yes
,就说明配置成功。

3、测试

master 插入一个表:

MySQL [mytest]> CREATE TABLE IF NOT EXISTS `runoob_tbl`(
    ->    `runoob_id` INT UNSIGNED AUTO_INCREMENT,
    ->    `runoob_title` VARCHAR(100) NOT NULL,
    ->    `runoob_author` VARCHAR(40) NOT NULL,
    ->    `submission_date` DATE,
    ->    PRIMARY KEY ( `runoob_id` )
    -> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected, 2 warnings (0.00 sec)

slave 查看效果:

MySQL [mytest]> show tables;
+------------------+
| Tables_in_mytest |
+------------------+
| runoob_tbl       |
+------------------+
1 row in set (0.00 sec)

master 插入数据:

MySQL [mytest]> insert into runoob_tbl(runoob_title,runoob_author,submission_date) values("ad","bb",now());
Query OK, 1 row affected, 1 warning (0.00 sec)

MySQL [mytest]> insert into runoob_tbl(runoob_title,runoob_author,submission_date) values("ae","bb",now());
Query OK, 1 row affected, 1 warning (0.00 sec)

MySQL [mytest]> insert into runoob_tbl(runoob_title,runoob_author,submission_date) values("af","bb",now());
Query OK, 1 row affected, 1 warning (0.00 sec)

slave查看数据:

MySQL [mytest]> select * from runoob_tbl;
+-----------+--------------+---------------+-----------------+
| runoob_id | runoob_title | runoob_author | submission_date |
+-----------+--------------+---------------+-----------------+
|         1 | ad           | bb            | 2018-03-08      |
|         2 | ae           | bb            | 2018-03-08      |
|         3 | af           | bb            | 2018-03-08      |
+-----------+--------------+---------------+-----------------+
3 rows in set (0.00 sec)

以上则说明配置测试成功。

4、master节点数据复制到slave节点

4.1 主库操作:

  1. 停止主库的数据更新操作

mysql>flush tables with read lock;

  1. 新开终端,生成主数据库的备份(导出数据库)

mysqldump -uroot -ptest123 cmdb > cmdb.sql

  1. 将备份文件传到从库

scp cmdb.sql root@192.168.8.11:/root/
4、主库解锁

mysql>unlock tables;

4.2 从库操作:

1)停止从库slave

mysql>slave stop;

2)新建数据库cmdb

mysql> create database cmdb default charset utf8;

3)导入数据

mysql -uroot -ptest123 cmdb < cmdb.sql

4)查看从库已有该数据库和数据

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| cmdb               |
| mysql              |
| performance_schema |
| test               |
+--------------------+

5 启动slave进程

mysql>slave start;

上述是5.1版本的配置,5.7版本又有些不同的配置,如下:

  1. 不存在log=/data/mysql_log/mysql.log 配置
  2. slave节点配置时,不能通过配置文件配置用户名,密码,接口等等,需要通过命令:
mysql> CHANGE MASTER TO MASTER_HOST='192.168.8.10',
  MASTER_PORT=3306,
  MASTER_USER='rep1',
  MASTER_PASSWORD='test123456',
  MASTER_LOG_FILE='binlog.000001',
  MASTER_LOG_POS=1304; #后面两个参数的值与主库保持一致
  1. 启动slave时不能通过slave start命令,而是 start slave命令。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容