C与引用和变量复制,复制状态与变量记录表

原标题:复制状态与变量记录表 | performance_schema全方位介绍(六)

server_id是必须安装在master和各类slave上的唯一标识ID,其取值范围
是1~4294967295里边,且同贰个复制组之内无法重新
server_uuid:server_uuid会在GTID复制中接纳。当MySQL运营现在,会
首先到数据文件目录下的auto.cnf中寻找是不是有指定的server_uuid,若是没有找到,则温馨生成1个server_uuid并保存到这一个文件中

server_id是必须设置在master和各样slave上的唯一标识ID,其取值范围
是1~4294967295以内,且同3个复制组之内不或者重复
server_uuid:server_uuid会在GTID复制中利用。当MySQL运营以往,会
首先到数据文件目录下的auto.cnf中检索是不是有指定的server_uuid,如若没有找到,则要好生成贰个server_uuid并保留到这些文件中

int& r = i; 和 int r = i;
差别之处应该是内存的分红吧,后者会再开发七个内存空间

图片 1

log_slave_updates:该参数用来支配是还是不是将接受的主库的换代数据的言语也记录在slave本身的bin
log中。符合规律景况下是不须要记录的,但若是是想 创造级联复制关系,比如A
-> B -> C,这之中B既要作为A的从库,也要作
为C的主库,则须求既开启log-bin参数,也要敞开log_slave_updates参数
relay-log:该参数用来指定relay-log文件的功底名称,专断认同的称谓为
host_name-relay-bin.xxxx,其中的xxxx结尾是逐一递增的数字

log_slave_updates:该参数用来决定是还是不是将吸纳的主库的革新数据的语句也记录在slave本身的bin
log中。符合规律状态下是不须求记录的,但假若是想 成立级联复制关系,比如A
-> B -> C,这之中B既要作为A的从库,也要作
为C的主库,则必要既开启log-bin参数,也要开启log_slave_updates参数
relay-log:该参数用来指定relay-log文件的基础名称,暗许的称谓为
host_name-relay-bin.xxxx,其中的xxxx结尾是逐一递增的数字

图片 2

出品 沃趣科技(science and technology)

replicate-do-db:该参数用来指定须要复制的数据库。
在依照语句复制的条件中,指定该参数之后,则slave的SQL
thread进程只会使用在本数据库下的靶子相关的口舌。假如有三个数据库须求复制,则那一个参数要利用频繁。但一旦是关联到跨库操作语句,则复制会丢掉,比如:
replicate-do-db=sales

replicate-do-db:该参数用来指定要求复制的数据库。
在根据语句复制的环境中,指定该参数之后,则slave的SQL
thread进度只会采用在本数据库下的对象相关的话语。如若有三个数据库须求复制,则这些参数要采用频仍。但即使是关乎到跨库操作语句,则复制会丢掉,比如:
replicate-do-db=sales

#includeusing namespace std;

IT从业多年,历任运行工程师,高级运营工程师,运营老董,数据库工程师,曾涉足版本公布连串,轻量级监控序列,运转管理平台,数据库管理平台的统筹与编制,熟知MySQL的连串布局时,InnoDB存储引擎,喜好专研开源技术,追求布帆无恙。

USE prices;
UPDATE sales.january SET amount=amount+1000; 
USE prices;
UPDATE sales.january SET amount=amount+1000; 

int main ()

不知不觉中,performance_schema连串快要接近尾声了,明日将指点大家一块儿踏上一而再串第4篇的征途(全系共五个篇章),在这一期里,大家将为大家无微不至授课performance_schema中的复制状态与变量总括表。上边,请跟随大家一齐伊始performance_schema系统的求学之旅吧~

在依照行复制的条件中,只要数据库对象是指定的库,则复制都能符合规律,比如上述update语句由于january表是属于sales库的,则slave会复制并应用
,同样上边的言语在依据行复制的环境中也不会实施:

在依照行复制的环境中,只要数据库对象是点名的库,则复制都能健康,比如上述update语句由于january表是属于sales库的,则slave会复制并应用
,同样下边的说话在依照行复制的环境中也不会进行:

{

01

USE sales;
UPDATE prices.march SET amount=amount-25;
USE sales;
UPDATE prices.march SET amount=amount-25;

int i;

复制新闻总结表

在slave的my.cnf上设置replicate-do-db=test,重启mysql

在slave的my.cnf上设置replicate-do-db=test,重启mysql

int& r = i;

普普通通,DBA或相关数据库运行人士在查阅从库的复制相关的音信,都习惯性的使用show
slave
status语句查看。大概你会说,笔者也会用performance_schema下的表查看有个别复制报错消息什么的。可是,你了然show
slave
status语句、mysql系统库下的复制音信记录表、performance_schema系统库下的复制新闻记录表之间有哪些分歧吗?不知道?别急,本文即将为您详细介绍show
slave
status语句与performance_schema系统库下的复制新闻记录表的区分(mysql系统库下的复制表差别详见后续
“mysql系统库全方位介绍”序列)。

在言语复制环境下查看对点名数据库的改动操作:

在讲话复制环境下查看对点名数据库的修改操作:

i = 5;

在起来详细介绍每一张复制音讯表从前,我们先费用一些篇幅来完全认识一下那些表。

[mysqld]
binlog-format=statement
主库上执行:
mysql> use test;
mysql> update test2.temp set name='ddd';
mysql> use test2;
mysql> update test.temp set name='eee';
在从库上查看复制结果:
mysql> use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from temp; 
-- 虽然是指定的同步数据库但并没有同步
 +------+------+
 | id | name |
 +------+------+
 | 1|abc|
 | 2|abc|
 | 3|abc|
 | 4|abc|
 | 5|abc|
 +------+------+
mysql> use test2;
mysql> select * from temp;
 +------+------+
 | id | name |
 +------+------+
 |10|ddd|
 |11|ddd|
 |12|ddd|
##虽然不是指定的同步数据库但数据有同步
[mysqld]
binlog-format=statement
主库上执行:
mysql> use test;
mysql> update test2.temp set name='ddd';
mysql> use test2;
mysql> update test.temp set name='eee';
在从库上查看复制结果:
mysql> use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from temp; 
-- 虽然是指定的同步数据库但并没有同步
 +------+------+
 | id | name |
 +------+------+
 | 1|abc|
 | 2|abc|
 | 3|abc|
 | 4|abc|
 | 5|abc|
 +------+------+
mysql> use test2;
mysql> select * from temp;
 +------+------+
 | id | name |
 +------+------+
 |10|ddd|
 |11|ddd|
 |12|ddd|
##虽然不是指定的同步数据库但数据有同步

cout << “Value of i : ” << i << endl;

performance_schema
系统库下提供了如下多少个与复制状态相关的表(表含义详见本文后续小节):

在行复制环境下查看对点名数据库的改动操作:

 mysql> show variables like '%binlog_format%';
 +---------------+-------+
 | Variable_name | Value |
 +---------------+-------+
 | binlog_format | ROW |
 +---------------+-------+

主库上实施:

mysql> use test;
mysql> update test2.temp set name='bcd';
mysql> use test2;
mysql> update test.temp set name='abc';
在从库上查看复制结果:
mysql> use test;
mysql> select * from temp; ##数据已复制
 +------+------+
 | id | name |
 +------+------+
 | 1|abc|
 | 2|abc|
 | 3|abc|
 | 4|abc|
 | 5|abc|
 +------+------+
mysql> use test2;
mysql> select * from temp; ##数据未复制
+------+------+
| id | name |
+------+------+
| 10 | aa |
| 11 | bb |
| 12 | cc |
+------+------+

另三个依据SQL语句复制和基于行复制的界别在于当语句中蕴藏对多少个数据库的表进行操作时。比如设置replicate-do-db=db1,

USE db1;
UPDATE db1.table1 SET col1 = 10, db2.table2 SET col2 = 20; 

据悉SQL语句的复制会将table1和table2都在备库修改,而依据行的复制只会在备库修改
table1表

USE db4;
UPDATE db1.table1 SET col1 = 10, db2.table2 SET col2 = 20; 

而对此上述讲话来说,基于SQL语句的复制不会在备库修改任何表,而据悉行的复制会
在备库修改table1表
倘若希望跨库的update语句在多个库上都起效果,可以应用replicate-do-
table=db_name.tbl_name

replicate-ignore-db:该参数决定了忽略指定数据库的复制,其作为和replicate-do-db
正好相反
replicate-do-table=db_name.tbl_name:通过该参数告知slave的SQL
thread仅复制指 定表上的数量。倘诺有两个表,则该参数要运用频仍
replicate-ignore-table=db_name.tbl_name:通过该参数告知slave的SQL
thread将指 定表上的多寡过滤掉
replicate-wild-do-table=db_name.tbl_name:通过该参数告知SQL的SQL
thread仅复
制符合匹配的表,可以接纳_和%作为通配符。比如replicate-wild-do-
table=foo%.bar%象征复制以foo打头的数据库下有所bar打头的表数据。即使是
replicate-wild-do-table=foo%.%,则意味着即复制foo打头的全部表的数量,也复制
create/drop/alter database foo打头的命令
replicate-wild-ignore-table=db_name.tbl_name:通过该参数告知SQL的SQL
thread 过滤掉符合匹配的表

设置replicate-do-table参数,重启mysql:
[mysqld]
replicate-do-db=test
replicate-do-table=test.temp

slave-parallel-workers: 该参数决定了slave上运转三个SQL
thread线程来并行应用数据的。默认值是0代表差异意并行,取值范围可以是0~1024
[mysqld] slave-parallel-workers=5

skip-slave-start
:该参数决定了在MySQL运转时是还是不是先不运转slave线程,即暂停复 制

[mysqld] 
skip-slave-start=1

slave-parallel-type=type
:该参数决定了当运行了交互之后,拔取什么样粒度的并行格局。专断认同值database代表依照不一致的数据库执行并行,LOGICAL_CLOCK则象征依据在binlog中的一组提交的事务作为并行粒度
slave-skip-errors=[err_code1,err_code2,…|all|ddl_exist_errors]:该参数决定了当slave的SQL
thread执行进度中相遇何种错误时方可忽略并继续接下去的多少复制。不荒谬情况下当有不当暴发时,复制会停下而须求人工干预修复才能持续拓展。除非尤其自信可以忽略有些错误,否则不要拔取这些参数,不然会招致固然复制执行不奇怪,但骨子里其中的数额已经完全不均等

sql_slave_skip_counter意味着在非GTID复制环境下,通过安装此参数来跳过多少个复制事件。
设置完该参数并非立刻生效,而是要等待下次start
slave命令的实施生效,并将该参数再度设 置为0
log-bin[=base_name]:该参数表示是还是不是开启binary
log。专擅认同情形下MySQL会利用
host_name-bin.xxxx作为文件的名字,其中xxxx是以数字递增的后缀。若是该参数指定了
base_name,则二进制文件会以base_name.xxxx来命名
binlog-do-db=db_name: 该参数决定了怎么库下的修改会被记录到bin
log中。其一举一动与
replicate-do-db类型,在依照SQL语句复制的环境下,只记录在当前数据库下的改动。比如指
定binlog-do-db=sales,一下语句不会被记录到bin log中:

USE prices;
UPDATE sales.january SET amount=amount+1000;

而以下语句则会被记录到bin log中:

USE sales; UPDATE prices.discounts SET percentage = percentage + 10; 

而据悉行复制的条件下,唯有属于指定数量的语句才会被记录到bin
log中。比如上面的语句会被记录:

USE prices; 
UPDATE sales.february SET amount=amount+100; 
-- 而下面的语句则不会被记录:
USE sales; 
UPDATE prices.march SET amount=amount-25; 
-- 针对跨库的语句来说,行为和replicate-do-db相同

binlog-ignore-db=db_name:该参数决定了在bin log中忽视的数据库,其一言一动与
replicate-ignore-db类型

binlog_format:该参数决定了bin
log中记录的格式,可以是statement,row,mixed,分别
代表基于SQL语句的复制,基于行复制和基于混合复制。在5.7.7本子此前的暗中认同设置是
statement,在5.7.7及其后,则暗许是row。当设置为混合形式时,则优先采取statement,
唯有当基于语句的复制无法保障复制的标准时会自动替换为row

反省复制状态方法

SHOW SLAVE STATUS\G
Slave_IO_State:    -- 代表当前slave的状态
Slave_IO_Running:     -- 代表负责读取主库bin log的IO线程是否是运行状态,正常情况下应 该是YES
Slave_SQL_Running:    -- 代表负责执行备库relay log的SQL线程是否是运行状态,正常情 况下应该是YES
Last_IO_Error, Last_SQL_Error:    -- 分别代表最后一次IO线程和SQL线程所发生的错误, 正常情况下应该是空代表没有错误 
Seconds_Behind_Master:    -- 代表备库的SQL线程比主库的bin log晚多少秒。0代表目前 没有复制延迟
(Master_Log_file, Read_Master_Log_Pos):    -- 表示IO线程在主库bin log中的坐标位置 
(Relay_Master_Log_File, Exec_Master_Log_Pos):    -- 表示SQL线程在主库bin log中的坐 标位置
(Relay_Log_File, Relay_Log_Pos):    -- 表示SQL线程在备库relay log中的坐标位置

在主库可以透过举办show processlist命令查看主库的bin log日志生成进度

mysql> SHOW PROCESSLIST \G;
*************************** 4. row ***************************
Id: 10
User: root
Host: slave1:58371
db: NULL
Command: Binlog Dump
Time: 777
State: Has sent all binlog to slave; waiting for binlog to be updated
Info: NULL

在行复制环境下查看对点名数据库的修改操作:

 mysql> show variables like '%binlog_format%';
 +---------------+-------+
 | Variable_name | Value |
 +---------------+-------+
 | binlog_format | ROW |
 +---------------+-------+

主库上进行:

mysql> use test;
mysql> update test2.temp set name='bcd';
mysql> use test2;
mysql> update test.temp set name='abc';
在从库上查看复制结果:
mysql> use test;
mysql> select * from temp; ##数据已复制
 +------+------+
 | id | name |
 +------+------+
 | 1|abc|
 | 2|abc|
 | 3|abc|
 | 4|abc|
 | 5|abc|
 +------+------+
mysql> use test2;
mysql> select * from temp; ##数据未复制
+------+------+
| id | name |
+------+------+
| 10 | aa |
| 11 | bb |
| 12 | cc |
+------+------+

另七个依照SQL语句复制和依据行复制的界别在于当语句中包括对几个数据库的表进行操作时。比如设置replicate-do-db=db1,

USE db1;
UPDATE db1.table1 SET col1 = 10, db2.table2 SET col2 = 20; 

依照SQL语句的复制会将table1和table2都在备库修改,而依照行的复制只会在备库修改
table1表

USE db4;
UPDATE db1.table1 SET col1 = 10, db2.table2 SET col2 = 20; 

而对于上述讲话来说,基于SQL语句的复制不会在备库修改任何表,而据悉行的复制会
在备库修改table1表
假使愿意跨库的update语句在多少个库上都起效果,可以应用replicate-do-
table=db_name.tbl_name

replicate-ignore-db:该参数决定了忽略指定数据库的复制,其一坐一起和replicate-do-db
正好相反
replicate-do-table=db_name.tbl_name:通过该参数告知slave的SQL
thread仅复制指 定表上的多寡。假如有多少个表,则该参数要动用频仍
replicate-ignore-table=db_name.tbl_name:通过该参数告知slave的SQL
thread将指 定表上的数据过滤掉
replicate-wild-do-table=db_name.tbl_name:通过该参数告知SQL的SQL
thread仅复
制符合匹配的表,可以利用_C与引用和变量复制,复制状态与变量记录表。和%看作通配符。比如replicate-wild-do-
table=foo%.bar%意味复制以foo打头的数据库下拥有bar打头的表数据。若是是
replicate-wild-do-table=foo%.%,则象征即复制foo打头的全体表的数量,也复制
create/drop/alter database foo打头的命令
replicate-wild-ignore-table=db_name.tbl_name:通过该参数告知SQL的SQL
thread 过滤掉符合匹配的表

设置replicate-do-table参数,重启mysql:
[mysqld]
replicate-do-db=test
replicate-do-table=test.temp

slave-parallel-workers: 该参数决定了slave上运维多少个SQL
thread线程来并行应用数据的。暗中同意值是0代表不同意并行,取值范围可以是0~1024
[mysqld] slave-parallel-workers=5

skip-slave-start
:该参数决定了在MySQL运营时是不是先不运行slave线程,即暂停复 制

[mysqld] 
skip-slave-start=1

slave-parallel-type=type
:该参数决定了当运行了相互之后,采取什么样粒度的并行格局。默许值database表示依据不一致的数据库执行并行,LOGICAL_CLOCK则意味着遵照在binlog中的一组提交的作业作为并行粒度
slave-skip-errors=[err_code1,err_code2,…|all|ddl_exist_errors]:该参数决定了当slave的SQL
thread执行进程中蒙受何种错误时得以忽略并三番五次接下去的数目复制。日常景况下当有荒唐发生时,复制会终止而急需人工干预修复才能持续展开。除非非凡自信可以忽略有个别错误,否则不要接纳那一个参数,不然会导致即使复制执行不荒谬,但实质上里面的数量现已完全不平等

sql_slave_skip_counter表示在非GTID复制环境下,通过设置此参数来跳过多少个复制事件。
设置完该参数并非立即生效,而是要等待下次start
slave命令的推行生效,并将该参数再一次设 置为0
log-bin[=base_name]:该参数表示是或不是开启binary
log。暗中同意情形下MySQL会利用
host_name-bin.xxxx作为文件的名字,其中xxxx是以数字递增的后缀。假设该参数指定了
base_name,则二进制文件会以base_name.xxxx来命名
binlog-do-db=db_name: 该参数决定了何等库下的修改会被记录到bin
log中。其行事与
replicate-do-db类型,在按照SQL语句复制的环境下,只记录在现阶段数据库下的改动。比如指
定binlog-do-db=sales,一下语句不会被记录到bin log中:

USE prices;
UPDATE sales.january SET amount=amount+1000;

而以下语句则会被记录到bin log中:

USE sales; UPDATE prices.discounts SET percentage = percentage + 10; 

而基于行复制的条件下,唯有属于指定数量的语句才会被记录到bin
log中。比如下边的语句会被记录:

USE prices; 
UPDATE sales.february SET amount=amount+100; 
-- 而下面的语句则不会被记录:
USE sales; 
UPDATE prices.march SET amount=amount-25; 
-- 针对跨库的语句来说,行为和replicate-do-db相同

binlog-ignore-db=db_name:该参数决定了在bin log中忽视的数据库,其行事与
replicate-ignore-db类型

binlog_format:该参数决定了bin
log中著录的格式,可以是statement,row,mixed,分别
代表基于SQL语句的复制,基于行复制和基于混合复制。在5.7.7版本之前的默许设置是
statement,在5.7.7及其后,则默许是row。当设置为混合情势时,则先行采纳statement,
只有当基于语句的复制不可能确保复制的可看重时会自动替换为row

自我批评复制状态方法

SHOW SLAVE STATUS\G
Slave_IO_State:    -- 代表当前slave的状态
Slave_IO_Running:     -- 代表负责读取主库bin log的IO线程是否是运行状态,正常情况下应 该是YES
Slave_SQL_Running:    -- 代表负责执行备库relay log的SQL线程是否是运行状态,正常情 况下应该是YES
Last_IO_Error, Last_SQL_Error:    -- 分别代表最后一次IO线程和SQL线程所发生的错误, 正常情况下应该是空代表没有错误 
Seconds_Behind_Master:    -- 代表备库的SQL线程比主库的bin log晚多少秒。0代表目前 没有复制延迟
(Master_Log_file, Read_Master_Log_Pos):    -- 表示IO线程在主库bin log中的坐标位置 
(Relay_Master_Log_File, Exec_Master_Log_Pos):    -- 表示SQL线程在主库bin log中的坐 标位置
(Relay_Log_File, Relay_Log_Pos):    -- 表示SQL线程在备库relay log中的坐标位置

在主库可以透过实践show processlist命令查看主库的bin log日志生成进度

mysql> SHOW PROCESSLIST \G;
*************************** 4. row ***************************
Id: 10
User: root
Host: slave1:58371
db: NULL
Command: Binlog Dump
Time: 777
State: Has sent all binlog to slave; waiting for binlog to be updated
Info: NULL

cout << “Value of i reference : ” << r  << endl;

  • replication_applier_configuration
  • replication_applier_status
  • replication_applier_status_by_coordinator
  • replication_applier_status_by_worker
  • replication_connection_configuration
  • replication_connection_status
  • replication_group_member_stats
  • replication_group_members

cout << “Addr of i: ” << &i << endl;

那一个复制表中记录的音讯生命周期如下(生命周期即指的是这么些表中的新闻什么日期写入,哪一天会被改动,哪天会被清理等):

cout << “Addr of r: ” << &r << endl;

  • 在推行CHANGE MASTE奥迪Q7 TO在此以前,这一个表是空的
  • 实践CHANGE MASTE揽胜极光TO之后,在配备参数表replication_applier_configuration和replication_connection_configuration中得以查看到安顿新闻了。此时,由于并从未运转复制,所以表中THREAD_ID列为NULL,SERVICE_STATE列的值为OFF(那八个字段存在与表replication_applier_status、replication_applier_status_by_coordinator、replication_applier_status_by_worker、replication_connection_status多少个表中)
  • 施行STASportageT
    SLAVE后,能够看来连接线程和协调器线程,工作线程状态表中的THREAD_ID字段被分配了三个值,且SEEscortVICE_STATE字段被改动为ON了,THREAD_ID字段值与show
    processlist语句中见到的线程id相同。 *
    尽管IO线程空闲或正在从主库接收binlog时,线程的SE奥德赛VICE_STATE值会一向为ON,THREAD_ID线程记录线程ID值,若是IO线程正在尝试连接主库但还未能如愿建立连接时,THREAD_ID记录CONNECTING值,THREAD_ID字段记录线程ID,即便IO线程与主库的连年断开,恐怕主动为止IO线程,则SELANDVICE_STATE字段记录为OFF,THREAD_ID字段被修改为NULL
  • 施行 STOP
    SLAVE之后,全部复制IO线程、协调器线程、工作线程状态表中的THREAD_ID列变为NULL,SERVICE_STATE列的值变为OFF。注意:截止复制相关线程之后,这么些记录并不会被清理
    ,因为复制意外终止大概暂且须要会执行甘休操作,或者必要取得一些动静新闻用于排错或然其余用途。
  • 履行RESET
    SLAVE之后,全数记录复制配置和复制状态的表中记录的音讯都会被免除。不过show
    slave
    status语句还能查看到一些复制状态和安顿新闻,因为该语句是从内存中获取,RESET
    SLAVE语句并不曾清理内存,而是清理了磁盘文件、表(还包罗mysql.slave_master_info和mysql.slave_relay_log_info多少个表)中著录的新闻。若是急需清理内存里报错的复制音信,需求运用RESET
    SLAVE ALL;语句
  • 注意:对于replication_applier_status_by_worker、replication_applier_status_by_coordinator表(以及mysql.slave_wroker_info表)来说,借使是以单线程复制运维,则replication_applier_status_by_worker表记录一条WOPRADOKEPRADO_ID=0的记录,replication_applier_status_by_coordinator表与mysql.slave_wroker_info表为空(使用三十二线程复制,该表中才有记录)。即,若是slave_parallel_workers系统变量大于0,则在执行STA途锐T
    SLAVE时这一个表就被填充相应多线程工作线程的音讯

int x;

performance_schema
系统库中保留的复制消息与SHOW SLAVE
STATUS输出的音信有所不相同(performance_schema 中著录的一些复制消息是show
slave status语句输出音信中从未的,可是也依旧有一部分show slave
status语句输出的复制音讯是performance_schema
中从不的),因为那些外部向全局工作标识符(GTID)使用,而不是基于binlog
pos位置,所以那几个回想品录server UUID值,而不是server ID值。show slave
status语句输出的新闻在performance_schema 中缺少的始末如下:

int y = x;

用来引用binlog file、pos和relay log
file、pos等音讯选项,在performance_schema表中不记录 。

x = 6;

PS1:如下系统状态变量被移位到了这几个复制状态表中举办记录(MySQL
5.7.5版以前运用以下状态变量查看):

cout << “Value of x : ” << x << endl;

  • Slave_retried_transactions
  • Slave_last_heartbeat
  • Slave_received_heartbeats
  • Slave_heartbeat_period
  • Slave_running

cout << “Value of y : ” << y  << endl;

PS2:对此组复制架构,组复制的督察新闻散布在如下几张表中

cout << “Addr of x: ” << &x << endl;

  • replication_group_member_stats
  • replication_group_members
  • replication_applier_status
  • replication_connection_status
  • threads

cout << “Addr of y: ” << &y << endl;

透过以上内容,大家从总体上可见大体明白了performance_schema中的复制消息表记录了怎样音信,上边依次详细介绍这几个复制音讯表。

return 0;

1.replication_applier_configuration表

}

该表中记录从库线程延迟复制的计划参数(延迟复制的线程被叫作普通线程,比如CHANNEL_NAME和DESIRED_DELAY字段记录有些复制通道是还是不是须要履行延迟复制,假诺是MG途乐集群,则记录组复制从节点的延迟复制配置参数),该表中的记录在Server运维时方可利用CHANGE
MASTERTO语句进行更改,大家先来看看表中著录的总结音讯是怎么着子的。

出口结果:

# 如若是单主或多主复制,则该表中会为种种复制通道记录一条看似如下消息

Value of i : 5

admin@localhost : performance_schema 02:49:12> select * from
replication_applier_configuration;

Value of i reference : 5

+————–+—————+

Addr of i: 0x7ffffc9517b4

| CHANNEL_NAME |DESIRED_DELAY |

Addr of r: 0x7ffffc9517b4

+————–+—————+

Value of x : 6

|| 0 |

Value of y : 4197104

+————–+—————+

Addr of x: 0x7ffffc9517b0

1row inset ( 0. 00sec)

Addr of y: 0x7ffffc9517ac

# 如若是MG凯雷德集群,则该表中会记录类似如下MGLAND集群消息

root@localhost : performance_schema 10:56:49> select * from
replication_applier_configuration;

+—————————-+—————+

| CHANNEL_NAME |DESIRED_DELAY |

+—————————-+—————+

|group_replication_applier | 0 |

| group_replication_recovery |0|

+—————————-+—————+

2 rows inset (0.00 sec)

表中各字段含义及与show slave
status输出字段对应关系如下:

图片 3

对于replication_applier_configuration表,不允许实施TRUNCATE
TABLE语句。

2. replication_applier_status表

该表中著录的是从库当前的貌似工作执市价况(该表也记录组复制架构中的复制状态新闻)

  • 此表提供了全部线程binlog重播事务时的平时状态音信。线程重播事务时特定的图景新闻保存在replication_applier_status_by_coordinator表(单线程复制时该表为空)和replication_applier_status_by_worker表(单线程复制时表中记录的音信与多线程复制时的replication_applier_status_by_coordinator表中的记录类似)

大家先来看望表中著录的计算音信是什么样样子的。

#
单线程复制和八线程复制时表中的记录一致,如果是多主复制,则逐个复制通道记录一行消息

admin@localhost : performance_schema 02:49:28> select * from
replication_applier_status;

+————–+—————+—————–+—————————-+

| CHANNEL_NAME |SERVICE_STATE | REMAINING_DELAY
|COUNT_TRANSACTIONS_RETRIES |

+————–+—————+—————–+—————————-+

|| ON |NULL | 0 |

+————–+—————+—————–+—————————-+

1row inset ( 0. 00sec)

# 如果是MG奥迪Q5集群,则该表会记录如下MGTiguan集群音信

root@localhost : performance_schema 10:58:33> select * from
replication_applier_status;

+—————————-+—————+—————–+—————————-+

| CHANNEL_NAME |SERVICE_STATE | REMAINING_DELAY
|COUNT_TRANSACTIONS_RETRIES |

+—————————-+—————+—————–+—————————-+

|group_replication_applier | ON |NULL | 0 |

| group_replication_recovery |OFF | NULL |0|

+—————————-+—————+—————–+—————————-+

2 rows inset (0.00 sec)

表中各字段含义及与show slave
status输出字段对应关系如下:

图片 4

对于replication_applier_status表,不一致意实施TRUNCATE
TABLE语句。

3. replication_applier_status_by_coordinator表

该表中记录的是从库使用二十四线程复制时,从库的协调器工作情景记录,当从库使用十六线程复制时,逐个通道下将创立二个协调器和七个工作线程,使用协调器线程来管理这几个工作线程。假若从库使用单线程,则此表为空(对应的笔录转移到replication_applier_status_by_worker表中著录),大家先来看看表中著录的计算消息是哪些样子的。

#
单线程主从复制时,该表为空,为多线程主从复制时表中记录协调者线程状态新闻,多主复制时逐个复制通过记录一行消息

admin@localhost : performance_schema 02:49:50> select * from
replication_applier_status_by_coordinator;

+————–+———–+—————+——————-+——————–+———————-+

| CHANNEL_NAME |THREAD_ID | SERVICE_STATE |LAST_ERROR_NUMBER |
LAST_ERROR_MESSAGE |LAST_ERROR_TIMESTAMP |

+————–+———–+—————+——————-+——————–+———————-+

|| 43 |ON | 0 || 0000-00-00 00:00:00 |

+————–+———–+—————+——————-+——————–+———————-+

1row inset ( 0. 00sec)

# 假设是MG奇骏集群,则该表中会记录类似如下MGEvoque集群消息

root@localhost : performance_schema 11:00:11> select * from
replication_applier_status_by_coordinator;

+—————————+———–+—————+——————-+——————–+———————-+

| CHANNEL_NAME |THREAD_ID | SERVICE_STATE |LAST_ERROR_NUMBER |
LAST_ERROR_MESSAGE |LAST_ERROR_TIMESTAMP |

+—————————+———–+—————+——————-+——————–+———————-+

|group_replication_applier | 91 |ON | 0 || 0000-00-00 00:00:00 |

+—————————+———–+—————+——————-+——————–+———————-+

1row inset ( 0. 00sec)

表中各字段含义及与show slave
status输出字段对应关系如下:

图片 5

对于replication_applier_status_by_coordinator表,不允许实施TRUNCATE
TABLE语句。

4. replication_applier_status_by_worker表

只要从库是单线程,则该表记录一条WOKugaKELAND_ID=0的SQL线程的图景。尽管从库是多线程,则该表记录系统参数slave_parallel_workers指定个数的行事线程状态(WO奥迪Q7KE兰德酷路泽_ID从1从头编号),此时协调器/SQL线程状态记录在replication_applier_status_by_coordinator表,每2个大路都有友好独自的办事线程和协调器线程(各个通道的办事线程个数由slave_parallel_workers参数变量指定,若是是MG奥德赛集群时,则该表中著录的做事线程记录为slave_parallel_workers个group_replication_applier线程+1个group_replication_recovery线程),大家先来探望表中著录的计算消息是什么样体统的。

# 单线程主从复制时表中记录的始末如下

root@localhost : performance_schema 12:46:10> select * from
replication_applier_status_by_worker;

+————–+———–+———–+—————+———————–+——————-+——————–+———————-+

| CHANNEL_NAME |WORKER_ID | THREAD_ID |SERVICE_STATE |
LAST_SEEN_TRANSACTION |LAST_ERROR_NUMBER | LAST_ERROR_MESSAGE
|LAST_ERROR_TIMESTAMP |

+————–+———–+———–+—————+———————–+——————-+——————–+———————-+

|| 0 |82| ON || 0 || 0000-00-00 00:00:00 |

+————–+———–+———–+—————+———————–+——————-+——————–+———————-+

1row inset ( 0. 00sec)

#
四线程主从复制时表中的记录内容如下(即使是多主复制,则各种复制通道记录slave_parallel_workers参数指定个数的worker线程音信)

admin@localhost : performance_schema 02:50:18> select * from
replication_applier_status_by_worker;

+————–+———–+———–+—————+———————–+——————-+——————–+———————-+

| CHANNEL_NAME |WORKER_ID | THREAD_ID |SERVICE_STATE |
LAST_SEEN_TRANSACTION |LAST_ERROR_NUMBER | LAST_ERROR_MESSAGE
|LAST_ERROR_TIMESTAMP |

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图