MySQL 主从复制,不停机添加新从节点:

1、主库创建账号:

修改主库repl密码:

show master status;

alter user repl@‘%‘ identified by ‘123456‘;

grant replication slave,replication client on *.* to ‘repl‘@‘%‘;

flush privilegs;

2、从库配置(创建从库数据库过程简略):

开启binlog

[root@centos_TP data1]# cat /etc/my.cnf

[mysqld]

#datadir=/var/lib/mysql

#socket=/var/lib/mysql/mysql.sock

#user=mysql

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

basedir=/usr/local/mysql

datadir=/data1/data

socket=/tmp/mysql.sock

port=3306

server-id =60182

replicate-wild-ignore-table=mysql.%

replicate-wild-ignore-table=performance_schema.%

replicate-wild-ignore-table=information_schema.%

replicate-wild-ignore-table=sys.%

log-bin = /data1/log/mysql-bin

binlog_format = MIXED

skip-slave-start = 1

expire_logs_days=3

#validate_password_policy=0

#validate_password_length=3

relay-log-index=/data1/log/mysql-relay

relay-log=/data1/log/mysql-relay

log-bin=/data1/log/mysql-bin

#log-error=log.err

explicit_defaults_for_timestamp=true

[mysqld_safe]

log-error=/data1/log/mysql.err

pid-file=/data1/tmp/mysqld.pid

初始化数据库:

正常初始化:

[root@centos_TP bin]# ./mysqld --defaults-file=/etc/my.cnf  --initialize  --user=mysql

2020-01-14T08:48:27.965207Z 0 [Warning] InnoDB: New log files created, LSN=45790

2020-01-14T08:48:28.175008Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.

2020-01-14T08:48:28.270192Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: a2408f8d-36aa-11ea-a1c6-00505695cefc.

2020-01-14T08:48:28.273709Z 0 [Warning] Gtid table is not ready to be used. Table ‘mysql.gtid_executed‘ cannot be opened.

2020-01-14T08:48:28.278708Z 1 [Note] A temporary password is generated for root@localhost: (,%E6LnwWrrq

指定初始化配置文件:

/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf  --initialize  --user=mysql

#开启数据库

/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf &

#登录数据库,修改root密码

mysql -p

之前初始化的密码

set sql_log_bin=0;

mysql> alter user root@‘localhost‘ identified by ‘123456‘;

mysql>flush privileges;

set sql_log_bin=1;

增加root远程登录用户:

mysql> create user root@‘%‘ identified by ‘123456‘;

Query OK, 0 rows affected (0.01 sec)

mysql> grant all privileges on *.* to root@‘%‘;

mysql> flush privileges;

#创建slave账号

mysql> grant replication slave,replication client on *.* to ‘repl‘@‘%‘ identified by ‘123456‘;

#在slave节点上执行

mysql> set global read_only=1;

#由于从库随时会提升成主库,不能写在配置文件里

3、备份主库:

[root@localhost dbdata]# mysqldump -uroot -p --routines --single_transaction --master-data=2 -B cat qc_bh > all.sql

参数说明:

--routines:导出存储过程和函数

--single_transaction:导出开始时设置事务隔离状态,并使用一致性快照开始事务,然后unlock tables;而lock-tables是锁住一张表不能写操作,直到dump完毕。

--master-data:默认等于1,将dump起始(change master to)binlog点和pos值写到结果中,等于2是将change master to写到结果中并注释。

4、从库创建数据库,并导入数据

将dump的数据拷贝到从库后开始导数据

mysql>

create database  cat;

create database  qc_bh;

mysql> source /data1/all.sql

...

Query OK, 0 rows affected (0.01 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected, 1 warning (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.01 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

5、查看备份文件的binlog 和 pos值

[root@centos_TP data1]# head -25 all.sql

-- MySQL dump 10.13  Distrib 5.7.20, for linux-glibc2.12 (x86_64)

--

-- Host: localhost    Database: cat

-- ------------------------------------------------------

-- Server version       5.7.20-log

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;

/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;

/*!40101 SET NAMES utf8 */;

/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;

/*!40103 SET TIME_ZONE=‘+00:00‘ */;

/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;

/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;

/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE=‘NO_AUTO_VALUE_ON_ZERO‘ */;

/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--

-- Position to start replication or point-in-time recovery from

--

-- CHANGE MASTER TO MASTER_LOG_FILE=‘mysql-bin.000037‘, MASTER_LOG_POS=621697642;

--

-- Current Database: `cat`

可以看到 MASTER_LOG_FILE=‘mysql-bin.000037‘, MASTER_LOG_POS=

621697642

;

6、启动从库

mysql> change master to

-> master_host=‘192.168.60.181‘,

-> master_user=‘repl‘,

-> master_password=‘123456‘,

-> master_log_file=‘mysql-bin.000037‘,

-> master_log_pos=621697642;

mysql> start slave;

Query OK, 0 rows affected (0.01 sec)

mysql> show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Queueing master event to the relay log

Master_Host: 192.168.60.181

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000037

Read_Master_Log_Pos: 677960018

Relay_Log_File: mysql-relay.000002

Relay_Log_Pos: 24887

Relay_Master_Log_File: mysql-bin.000037

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB:

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table: mysql.%,performance_schema.%,information_schema.%,sys.%

Last_Errno: 0

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 621722209

Relay_Log_Space: 56262899

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: 6606

Master_SSL_Verify_Server_Cert: No

Last_IO_Errno: 0

Last_IO_Error:

Last_SQL_Errno: 0

Last_SQL_Error:

Replicate_Ignore_Server_Ids:

Master_Server_Id: 60181

Master_UUID: a524c954-c8a8-11e9-8082-00505697e9db

Master_Info_File: /data1/data/master.info

SQL_Delay: 0

SQL_Remaining_Delay: NULL

Slave_SQL_Running_State: Reading event from the relay log

Master_Retry_Count: 86400

Master_Bind:

Last_IO_Error_Timestamp:

Last_SQL_Error_Timestamp:

Master_SSL_Crl:

Master_SSL_Crlpath:

Retrieved_Gtid_Set:

Executed_Gtid_Set:

Auto_Position: 0

Replicate_Rewrite_DB:

Channel_Name:

Master_TLS_Version:

1 row in set (0.01 sec)

ERROR:

No query specified

显示:

看到IO和SQL线程均为YES,说明主从配置成功。

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Read_Master_Log_Pos: 677960018表示一直在追binlog日志。

转自:http://blog.itpub.net/22996654/viewspace-2673361/

mysql5.7.17主从_MySQL 5.7主从不停机添加新从库相关推荐

  1. mysql不停機添加節點_MySQL 5.7主从不停机添加新从库

    MySQL 主从复制,不停机添加新从节点: 1.主库创建账号: 修改主库repl密码: show master status; alter user repl@'%' identified by '1 ...

  2. mysql 5.5 主从_Mysql 5.5主从搭建

    领导突然让做主从服务器,mysq让用5.5版本的,以前搭建过5.1,本来感觉很easy,哪知道却有很大区别调试了好长时间,终于弄好了! mysql5.5安装起来也和以前的大不一样,以前的configu ...

  3. mysql在同一台机器上实现主从_MySQL 5.7主从搭建(同一台机器)

    主从复制原理:复制是 MySQL 的一项功能,允许服务器将更改从一个实例复制到另一个实例.1)主服务器将所有数据和结构更改记录到二进制日志中.2)从属服务器从主服务器请求该二进制日志并在本地应用其内容 ...

  4. mysql gtid 主主_mysql GTID主从复制(主库在线,添加新丛库)

    要求: 1.         主库上线,主库不停止服务的前提下做主从复制 2.         新添加一个丛库 操作: 1.         在主库导出数据(主库正常运行): 2.         将 ...

  5. MySQL主从配置和gtid主从配置

    文章目录 1.为什么需要主从复制? 2.什么是mysql的主从复制? 3.GTID的工作原理: 4.GTID与传统主从复制的区别是什么 5.mysql主从 5. 1mysql主从配置 5.1.1 确保 ...

  6. Linux环境中MySQL主从同步--添加新的从库

    当前我认为数据库主从有两大应用价值: 1.从库相当于主库的备份.虽然数据库的主从并不能代替/取代备份,例如错误的数据可能毁掉所有的数据库,但主从也是在一种可读的状态下保持备份的一种实现方式. 2.从库 ...

  7. mysql 5.6 互为主从_mysql5.6主从同步,互为主从配置

    由于业务需要,需要做主从同步,互为主从等的mysql设置.主从设置主要涉及主从同步时使用的账号密码配置,my.cnf的配置,进入数据库进行master,slave配置.主要是这四个配置. 1,账号密码 ...

  8. 【转】centos 6.2 安装mysql-5.5.17

    转自:http://icooke.blog.51cto.com/4123148/764796 1.安装相关库文件(没有的话就安装,有就不用安装了) # yum install bison gcc gc ...

  9. mysql 5.02审计_CentOS 7.2 mysql-5.7.17 审计插件安装、开启与设定

    最近因为一些事情的发生,出现了好端端的页面,变成了空页面.转头开发同事就来质问我,是不是我动了什么,后来经过调查发现,是平台运营的同事误删资料导致的. 所以如果运维或者开发部门有很多人都分配了数据库的 ...

最新文章

  1. 2022-2028年中国二次供水产业发展动态及投资战略规划报告
  2. MuJoCo要开源!DeepMind收购物理引擎MuJoCo,将推动全球机器人研发
  3. 威胁生存!科学家警告灾难性“气候临界点”已逼近
  4. ‘Series‘ object has no attribute ‘sort‘
  5. python中几种推导式的特殊用法
  6. 录播软件开始麦克风应该打开还是关闭
  7. mysql root密码重置
  8. Github Pages 搭建网站
  9. win32 注册表操作
  10. 基于Rx-netty和Karyon2的云就绪微服务
  11. 打印两个有序链表的公共部分~~
  12. APP运营者如何对用户的数据进行分析?
  13. sql server 2008语言基础: 连接查询习题
  14. [MATLAB]图像处理——交通标志的识别
  15. retainall的问题
  16. 爬虫福利二之妹子图网批量下载MM
  17. 如何自动加载scratch3.0的页面上实现自动加载原有的作品
  18. 计算机论文a会c会,参考文献代码大全
  19. ubuntu如何打拼音
  20. CF-GYM 103119 L. Random Permutation

热门文章

  1. RIM 将在今天发布新的 BlackBerry 7 OS 手机
  2. 利用Bandwidth Splitter限制带宽
  3. 读写EXCEL的例子
  4. PhpStorm函数注释的设置
  5. 帕金森患者的新曙光!AI无线智能探测系统诞生
  6. 团队作业1(陈爽、夏江华、李瑞超、甘彩娈、吕乐乐)
  7. 云无边界,阿里云混合云数据同步发布
  8. usermod命令的一些用法详解
  9. 全球75亿美元的网络安全险 会是保险业下一块金矿吗?
  10. Mahout-协同过滤-CF-推荐算法基本概念及代码示例