文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mysql怎么增加节点

2024-04-02 19:55

关注

本篇内容介绍了“Mysql怎么增加节点”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

我们知道,一组优秀的集群环境有一个很必要的特性,那就是可拓展性。Group Replication的拓展性怎么样呢?我们设定如下几个场景,来看看Group Replicaiton是否方便拓展:
总执行的事务量较少,而且所有的binlog都保留完整。
总事务量较少,binlog只保留部分。
总事务量很大,binlog保留完整。
总事务量很大,binlog只保留部分。
我们在对以上几种场景进行分析
总事务量较少,binlog保留完整。那么我们可以直接应用所有binlog,来创建一个和现有环境相同的实例。
总事务量较少,binlog保留部分。此场景中binlog丢失,无法应用所有binlog来创建一个和现有环境相同的实例。那么我们要得到一个和现有环境相同的实例,只有复制一个现有环境中的实例,然后再将这个实例添加到集群。复制的方法我能想到的有如下几种:
mysqldump
xtrabackup
总事务量较多,binlog保留完整。我们可以和第一种环境一样,应用所有binlog来创建新实例。但是事务较多应用binlog需要非常多的时间。为了提高效率,我们还是采用复制实例的方式来创建新实例。
总事务较多,binlog只保留部分。这个场景和第二个场景差不多,我们也只能采用复制实例的方式来创建新的实例。

所以,除了第一个场景外,其它的最好还是备份前的的数据后,恢复到新的server上再开启同步,下面就做一下这个试验:


机器名        IP                        角色
qht131    172.17.61.131        primary  
qht132    172.17.61.132        secdnode1
qht133    172.17.61.133        secdnode2
qht134    172.17.61.134        secdnode3

1.检查当前mgr的状态:


mysql>  select * from performance_schema.replication_group_members ;

±--------------------------±-------------------------------------±------------±------------±-------------+

| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST | MEMBER_PORT | MEMBER_STATE |

±--------------------------±-------------------------------------±------------±------------±-------------+

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e89b | qht131      |        3306 | ONLINE       |

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e90b | qht132      |        3306 | ONLINE       |

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e91b | qht133      |        3306 | ONLINE       |

±--------------------------±-------------------------------------±------------±------------±-------------+
1
建立一个表做测试数据:


mysql> drop table  test_mgr;

Query OK, 0 rows affected (0.05 sec)

mysql> create table  test_mgr (c1 int(11) primary key);

Query OK, 0 rows affected (0.07 sec)

mysql> insert into test_mgr values(1);

Query OK, 1 row affected (0.01 sec)
1
将全库备份一下复制到目标新库:
[root@qht131 backup]# mysqldump -uroot -p --all-databases --triggers --routines --events --master-data=2 > dbdump.db
[root@qht131 backup]# scp dbdump.db 172.17.61.134:/u01/backup
1
备份之后再对数据库做一些操作:


mysql> insert into test_mgr values(2);

Query OK, 1 row affected (0.00 sec)

mysql>  insert into test_mgr values(3);

Query OK, 1 row affected (0.03 sec)

mysql> select * from  test_mgr;

±—+

| c1 |

±—+

|  1 |

|  2 |

|  3 |

±—+
1

2.qht134安装好数据库,将备份恢复过来:
[root@qht134 backup]# mysql -uroot -p < dbdump.db
3.配置my.cnf,配置文件注意server_id以及loose-group_replication_local_address和loose-group_replication_local_address。


[root@qht134 backup]# cat /etc/my.cnf

[client]

port = 3306

socket = /u01/mysql/mysql.sock

[mysql]

no-auto-rehash

[mysqld]

socket = /u01/mysql/mysql.sock

character_set_server= utf8

init_connect= ‘SET NAMES utf8’

basedir= /usr/local/mysql

datadir= /u01/mysql

socket = /u01/mysql/mysql.sock

log-error= /u01/log/mysql/mysql_3306.err

pid-file= /u01/mysql/mysqld.pid

lower_case_table_names = 1

sql_mode= STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

secure-file-priv = /u01/backup

server-id=10004

log_bin = /u01/mysql/mysql_bin

#skip-grant-tables

#innodb_flush_log_at_trx_commit=1

#sync_binlog=1

#expire_logs_days=10

#max_binlog_size=1073741824

#autocommit=off

#long_query_time=15

#slow_query_log=on

log_slave_updates = ON

relay_log_info_repository = TABLE

master_info_repository = TABLE

transaction_write_set_extraction = XXHASH64

binlog_format = ROW

binlog_checksum = NONE

enforce_gtid_consistency = ON

gtid_mode = ON

loose-group_replication_group_name="aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"

loose-group_replication_start_on_boot=off

loose-group_replication_local_address= "172.17.61.134:33060"

loose-group_replication_group_seeds= "172.17.61.131:33060,172.17.61.132:33060,172.17.61.133:33060,172.17.61.134:33060"

loose-group_replication_bootstrap_group= off
1
 重启数据库
1


[root@qht134 mysql]# service mysql start

Starting MySQL…                                           [  OK  ] 
1
4.修改原有节点的memeber信息:
在qht131,qht132,qht133以分别执行:


mysql>  set global group_replication_group_seeds=‘172.17.61.131:33060,172.17.61.132:33060,172.17.61.133:33060,172.17.61.134:33060’;

Query OK, 0 rows affected (0.02 sec)
1
5.在新节点上建立复制用户


mysql> set sql_log_bin=0;

Query OK, 0 rows affected (0.00 sec)

mysql>  create user mgruser@’%’ identified by ‘mgruser’;

ERROR 1396 (HY000): Operation CREATE USER failed for ‘mgruser’@’%'
1


mysql> set sql_log_bin=1;

Query OK, 0 rows affected (0.00 sec)
1
对了,复制用户的信息都已经从mysqldump中恢复了过来,所以就不用重新建立了。
如果新节点不是备份恢复过来的,则需要重新建立复制用户。
6.安装复制插件以及启动新的复制节点
  mysql> install plugin group_replication soname ‘group_replication.so’;  #先show plugins;检查一下有没有安装好复制插件,如已安装好的话则跳过此步骤


mysql> change master to

    -> master_user=‘mgruser’,

    -> master_password=‘mgruser’

    -> for channel ‘group_replication_recovery’;

Query OK, 0 rows affected, 2 warnings (0.04 sec)

mysql> start group_replication;

Query OK, 0 rows affected (3.40 sec)
1
7.查询点节状态:


mysql> select * from performance_schema.replication_group_members ;

±--------------------------±-------------------------------------±------------±------------±-------------+

| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST | MEMBER_PORT | MEMBER_STATE |

±--------------------------±-------------------------------------±------------±------------±-------------+

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e89b | qht131      |        3306 | ONLINE       |

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e89c | qht134      |        3306 | ONLINE       |

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e90b | qht132      |        3306 | ONLINE       |

| group_replication_applier | bb0dea82-58ed-11e8-94e5-000c29e8e91b | qht133      |        3306 | ONLINE       |

±--------------------------±-------------------------------------±------------±------------±-------------+

4 rows in set (0.04 sec)
1
发现qht134已成功加入了复制群组。


mysql> select * from test_mgr;

±—+

| c1 |

±—+

|  1 |

|  2 |

|  3 |

±—+

3 rows in set (0.00 sec)
1
数据也同步到了最新的状态。
8.后续操作
为了下次qht131,qht132,qht133重启后的gr配置仍然有效,需要修改my.cnf的配置:
oose-group_replication_group_seeds= "172.17.61.131:33060,172.17.61.132:33060,172.17.61.133:33060,172.17.61.134:33060"
1
这样保证在重启数据库后,GR的配置是最新的。

“Mysql怎么增加节点”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯