GreatSQL社区

搜索

[已解决] MYSQL 5.7 搭建MGR 后使用MySQL SHELL接管的一些疑问

776 5 2024-5-16 09:17
MySQL的版本是5.7.26
MySQL SHELL的版本是MySQL Shell 8.0.37
在单机上做多个实例的方式做的测试

测试最终目的:希望从mysql 5.7.26 搭建mgr集群,然后滚动升级MGR到mysql 8的mgr集群


大致过程如下:
1、先用手工方式创建了3个节点MGR(3306,3307,3308),此时这里用的 同步用户是repl@'%' 密码是repl ,版本都是mysql 5.7.26
2、用MYSQL SHELL接管这3个节点,这时候发现接管MGR的时候,多了一个mysql_innodb_cluster_metadata数据库,接管集群的时候发现,他有提示说用test用户去接管。
当时的日志没留下来。


3、经过多次折腾加MGR,删MGR,会发现创建了'mysql_innodb_cluster_10330X的用户
  1. MySQL  localhost:3306  JS > dba.createCluster('MGR');
  2. WARNING: Support for AdminAPI operations in MySQL version 5.7 is deprecated and will be removed in a future release of MySQL Shell
  3. A new InnoDB Cluster will be created on instance '192.168.101.77:3306'.

  4. You are connected to an instance that belongs to an unmanaged replication group.
  5. Do you want to setup an InnoDB Cluster based on this replication group? [Y/n]: yes
  6. Creating InnoDB Cluster 'MGR' on '192.168.101.77:3306'...

  7. Adding Seed Instance...
  8. Adding Instance '192.168.101.77:3307'...
  9. Adding Instance '192.168.101.77:3308'...
  10. Adding Instance '192.168.101.77:3306'...
  11. Resetting distributed recovery credentials across the cluster...
  12. NOTE: User 'mysql_innodb_cluster_103307'@'%' already existed at instance '192.168.101.77:3306'. It will be deleted and created again with a new password.
  13. NOTE: User 'mysql_innodb_cluster_103308'@'%' already existed at instance '192.168.101.77:3306'. It will be deleted and created again with a new password.
  14. NOTE: User 'mysql_innodb_cluster_103306'@'%' already existed at instance '192.168.101.77:3306'. It will be deleted and created again with a new password.
  15. WARNING: Instance '192.168.101.77:3307' cannot persist configuration since MySQL version 5.7.26 does not support the SET PERSIST command (MySQL version >= 8.0.11 required). Please use the dba.configureLocalInstance() command locally to persist the changes.
  16. WARNING: Instance '192.168.101.77:3308' cannot persist configuration since MySQL version 5.7.26 does not support the SET PERSIST command (MySQL version >= 8.0.11 required). Please use the dba.configureLocalInstance() command locally to persist the changes.
  17. WARNING: Instance '192.168.101.77:3306' cannot persist configuration since MySQL version 5.7.26 does not support the SET PERSIST command (MySQL version >= 8.0.11 required). Please use the dba.configureLocalInstance() command locally to persist the changes.
  18. Cluster successfully created based on existing replication group.

  19. <Cluster:MGR>
复制代码



问题如下:
1、为什么我用的是repl的用户去同步mgr的3个节点,使用mysql shell接管的时候会创建mysql_innodb_cluster_10330X 用户呢?
2、查询replication_connection_configuration的时候为啥发现用户是test? 这个是不是bug?
  1. mysql> select * from performance_schema.replication_connection_configuration\G;
  2. *************************** 1. row ***************************
  3.                  CHANNEL_NAME: group_replication_applier
  4.                          HOST: <NULL>
  5.                          PORT: 0
  6.                          USER: test
  7.             NETWORK_INTERFACE:
  8.                 AUTO_POSITION: 1
  9.                   SSL_ALLOWED: NO
  10.                   SSL_CA_FILE:
  11.                   SSL_CA_PATH:
  12.               SSL_CERTIFICATE:
  13.                    SSL_CIPHER:
  14.                       SSL_KEY:
  15. SSL_VERIFY_SERVER_CERTIFICATE: NO
  16.                  SSL_CRL_FILE:
  17.                  SSL_CRL_PATH:
  18.     CONNECTION_RETRY_INTERVAL: 60
  19.        CONNECTION_RETRY_COUNT: 86400
  20.            HEARTBEAT_INTERVAL: 30.000
  21.                   TLS_VERSION:
  22. 1 row in set (0.00 sec)

  23. ERROR:
  24. No query specified
复制代码

全部回复(5)
KAiTO 2024-5-16 10:19:01
1、为什么我用的是repl的用户去同步mgr的3个节点,使用mysql shell接管的时候会创建mysql_innodb_cluster_10330X 用户呢?
------
这是MySQL  Shell 接管时候自动创建的
文档解释:
  1. As part of using Group Replication, InnoDB Cluster creates internal recovery users which enable connections between the servers in the cluster. These users are internal to the cluster, and the user name of the generated users follows a naming scheme of mysql_innodb_cluster_server_id@%, where server_id is unique to the instance. In versions earlier than 8.0.17 the user name of the generated users followed a naming scheme of mysql_innodb_cluster_r[10_numbers].
复制代码
link:MySQL :: MySQL Shell 8.0 :: 7.3 User Accounts for InnoDB Cluster

2、查询
replication_connection_configuration的时候为啥发现用户是test? 这个是不是bug?
------
看了你的大致过程,看到其中这样一句话“接管集群的时候发现,他有提示说用test用户去接管。当时的日志没留下来。”这就是为什么显示test用户的原因


3、附带一个叶老师写的文章
【新提醒】手动构建的GreatSQL MGR集群(含仲裁节点)如何用shell接管 - GreatSQL - GreatSQL社区 - Powered by Discuz!(万里开源技术社区)
起飞小宇 2024-5-16 10:33:20
KAiTO 发表于 2024-5-16 10:19
1、为什么我用的是repl的用户去同步mgr的3个节点,使用mysql shell接管的时候会创建mysql_innodb_cluster_1 ...

搭建好MGR后,使用MYSQL SHELL接管,用户是:mysql_innodb_cluster_10330X ,那为什么replication_connection_configuration 里面还是显示test呢?
yejr 2024-5-16 12:37:19
起飞小宇 发表于 2024-5-16 10:33
搭建好MGR后,使用MYSQL SHELL接管,用户是:mysql_innodb_cluster_10330X ,那为什么replication_connec ...

test是MySQL Shell连接使用的账户
mysql_innodb_cluster_10330X是MGR各节点间通信使用的账户
起飞小宇 2024-5-16 12:46:46
yejr 发表于 2024-5-16 12:37
test是MySQL Shell连接使用的账户
mysql_innodb_cluster_10330X是MGR各节点间通信使用的账户 ...

但是我并没有创建test账号
  1. mysql> select user,host from mysql.user\G;
  2. *************************** 1. row ***************************
  3. user: mysql_innodb_cluster_103306
  4. host: %
  5. *************************** 2. row ***************************
  6. user: mysql_innodb_cluster_103307
  7. host: %
  8. *************************** 3. row ***************************
  9. user: mysql_innodb_cluster_103308
  10. host: %
  11. *************************** 4. row ***************************
  12. user: mysql_innodb_cluster_103309
  13. host: %
  14. *************************** 5. row ***************************
  15. user: repl
  16. host: %
  17. *************************** 6. row ***************************
  18. user: mysql.session
  19. host: localhost
  20. *************************** 7. row ***************************
  21. user: mysql.sys
  22. host: localhost
  23. *************************** 8. row ***************************
  24. user: root
  25. host: localhost
  26. 8 rows in set (0.00 sec)

  27. ERROR:
  28. No query specified
复制代码
yejr 2024-5-22 08:59:59
起飞小宇 发表于 2024-5-16 12:46
但是我并没有创建test账号

估计是你某个误操作导致的,正常 group_replication_applier 线程的 USER 应该是空的,例如

  1. greatsql> select * from performance_schema.replication_connection_configuration\G
  2. *************************** 1. row ***************************
  3.                    CHANNEL_NAME: group_replication_applier
  4.                            HOST: <NULL>
  5.                            PORT: 0
  6.                            USER:
  7.               NETWORK_INTERFACE:
  8.                   AUTO_POSITION: 1
  9.                     SSL_ALLOWED: NO
  10.                     SSL_CA_FILE:
  11.                     SSL_CA_PATH:
  12.                 SSL_CERTIFICATE:
  13.                      SSL_CIPHER:
  14.                         SSL_KEY:
  15.   SSL_VERIFY_SERVER_CERTIFICATE: NO
  16.                    SSL_CRL_FILE:
  17.                    SSL_CRL_PATH:
  18.       CONNECTION_RETRY_INTERVAL: 60
  19.          CONNECTION_RETRY_COUNT: 86400
  20.              HEARTBEAT_INTERVAL: 30.000
  21.                     TLS_VERSION:
  22.                 PUBLIC_KEY_PATH:
  23.                  GET_PUBLIC_KEY: NO
  24.               NETWORK_NAMESPACE:
  25.           COMPRESSION_ALGORITHM: uncompressed
  26.          ZSTD_COMPRESSION_LEVEL: 3
  27.                TLS_CIPHERSUITES: NULL
  28. SOURCE_CONNECTION_AUTO_FAILOVER: 0
  29.                       GTID_ONLY: 1
  30. *************************** 2. row ***************************
  31.                    CHANNEL_NAME: group_replication_recovery
  32.                            HOST: <NULL>
  33.                            PORT: 0
  34.                            USER: mysql_innodb_cluster_1233306
  35.               NETWORK_INTERFACE:
  36.                   AUTO_POSITION: 1
  37.                     SSL_ALLOWED: YES
  38.                     SSL_CA_FILE:
  39.                     SSL_CA_PATH:
  40.                 SSL_CERTIFICATE:
  41.                      SSL_CIPHER:
  42.                         SSL_KEY:
  43.   SSL_VERIFY_SERVER_CERTIFICATE: NO
  44.                    SSL_CRL_FILE:
  45.                    SSL_CRL_PATH:
  46.       CONNECTION_RETRY_INTERVAL: 60
  47.          CONNECTION_RETRY_COUNT: 1
  48.              HEARTBEAT_INTERVAL: 30.000
  49.                     TLS_VERSION: TLSv1.2,TLSv1.3
  50.                 PUBLIC_KEY_PATH:
  51.                  GET_PUBLIC_KEY: NO
  52.               NETWORK_NAMESPACE:
  53.           COMPRESSION_ALGORITHM: uncompressed
  54.          ZSTD_COMPRESSION_LEVEL: 3
  55.                TLS_CIPHERSUITES: NULL
  56. SOURCE_CONNECTION_AUTO_FAILOVER: 0
  57.                       GTID_ONLY: 1
  58. 2 rows in set (0.00 sec)
复制代码


构建 MGR 的过程可参考 https://greatsql.cn/docs/8.0.32- ... r%E9%9B%86%E7%BE%A4
起飞小宇

9

主题

0

博客

42

贡献

注册会员

Rank: 2

积分
72

助人为乐(铜)

合作电话:010-64087828

社区邮箱:greatsql@greatdb.com

社区公众号
社区小助手
QQ群
GMT+8, 2025-1-18 15:43 , Processed in 0.025258 second(s), 19 queries , Redis On.
快速回复 返回顶部 返回列表