この記事では、mysql に関する関連知識を提供します。主にクローンに関連する問題について説明します。MySQL 8.0.17 では、ローカルまたはリモートの MySQL サーバーから実行できる Clone プラグインが導入されています。この例が皆さんのお役に立てば幸いです。
#推奨学習:[mysqld] plugin-load-add=mysql_clone.so方法 2: 実行時にプラグインをロードし、INSTALL PLUGIN を使用してプラグインをインストールし、mysql.plugin システム テーブルに登録します:
install plugin clone soname 'mysql_clone.so';インストール後、information_schema で表示できます。 plugins テーブルまたは show plugins を通じて。 ローカル データのクローンを作成するローカル クローン データは、MySQL データ ディレクトリを同じサーバーにクローンするか、ノードを別のディレクトリにクローンすることです。サポートされる構文は次のとおりです。上記のステートメントに対応するユーザーは BACKUP_ADMIN 権限を持っている必要があり、ユーザーが作成したファイルまたはテーブルスペースはデータ ディレクトリに存在する必要があり、同時にクローンの宛先は絶対パスを指定する必要があります。 directory は存在する必要がありますが、clone_dir は存在してはいけません。 デモ: ローカル データのクローン作成1) ユーザーの作成
CLONE LOCAL DATA DIRECTORY [=] '/path/to/clone_dir'
mysql> select version(); +-----------+ | version() | +-----------+ | 8.0.25 | +-----------+ 1 row in set (0.00 sec) mysql> create user clone_admin identified by 'Cl0neTest'; Query OK, 0 rows affected (0.02 sec) mysql> grant backup_admin on *.* to clone_admin; Query OK, 0 rows affected (0.10 sec)3) クローン操作
[root@node1 ~]# mkdir /mysql/clone/ [root@node1 ~]# chown -R mysql:mysql /mysql/clone/4) クローンされたファイルを表示します
mysql> clone local data directory='/mysql/clone/clone_data'; Query OK, 0 rows affected (17.09 sec)5) 確認し、クローンされたディレクトリを使用してデータベースを起動します
[root@node1 ~]# ll /mysql/clone/clone_data/ total 6348816 drwxr-x---. 2 mysql mysql 89 Nov 28 11:26 #clone -rw-r-----. 1 mysql mysql 9231 Nov 28 11:26 ib_buffer_pool -rw-r-----. 1 mysql mysql 4294967296 Nov 28 11:26 ibdata1 -rw-r-----. 1 mysql mysql 1073741824 Nov 28 11:26 ib_logfile0 -rw-r-----. 1 mysql mysql 1073741824 Nov 28 11:26 ib_logfile1 drwxr-x---. 2 mysql mysql 6 Nov 28 11:26 mysql -rw-r-----. 1 mysql mysql 25165824 Nov 28 11:26 mysql.ibd drwxr-x---. 2 mysql mysql 4096 Nov 28 11:26 sakila drwxr-x---. 2 mysql mysql 28 Nov 28 11:26 sys -rw-r-----. 1 mysql mysql 16777216 Nov 28 11:26 undo_001 -rw-r-----. 1 mysql mysql 16777216 Nov 28 11:26 undo_002リモート データのクローンを作成しますリモート MySQL サーバー インスタンス (ドナー) をクローン作成しますクローン作成操作を実行する MySQL インスタンス (受信者) に送信されます。リモート データのクローン作成でサポートされている構文は次のとおりです:
[root@node1 ~]# service mysql.server stop Shutting down MySQL.... SUCCESS! [root@node1 ~]# mysqld_safe --datadir=/mysql/clone/clone_data/ --lower-case-table-names=1 --user=mysql 2021-11-28T03:47:11.012900Z mysqld_safe Logging to '/mysql/clone/clone_data/node1.com.cn.err'. 2021-11-28T03:47:11.036181Z mysqld_safe Starting mysqld daemon with databases from /mysql/clone/clone_data
user はユーザー名です。ドナー MySQL サーバー インスタンスの名前、
默认将数据克隆到recipient端的数据目录,并使用donor的数据进行覆盖,然后进行自动重启recipient端的MySQL服务器实例
1)登录到donor MySQL服务器实例,创建用户并安装插件(若安装可忽略)
mysql> create user 'donor_clone_user' identified by 'donor_clone_user'; Query OK, 0 rows affected (0.02 sec) mysql> grant backup_admin on *.* to donor_clone_user; Query OK, 0 rows affected (0.01 sec)
2)登录到recipient MySQL服务器实例,创建账户并安装插件,并设置clone_valid_donor_list
mysql> create user recipient_clone_user identified by 'recipient_clone_user'; Query OK, 0 rows affected (0.04 sec) mysql> grant clone_admin,backup_admin on *.* to recipient_clone_user; Query OK, 0 rows affected (0.01 sec) mysql> install plugin clone soname 'mysql_clone.so'; Query OK, 0 rows affected (0.01 sec) mysql> set global clone_valid_donor_list='192.168.56.53:3306'; Query OK, 0 rows affected (0.00 sec)
3)登录到recipient MySQL服务器实例,使用 recipient_clone_user用户或root用户执行克隆操作,操作完成后会自动重启
mysql> clone instance from 'donor_clone_user'@'192.168.56.81':3306 identified by 'donor_clone_user'; Query OK, 0 rows affected (51.08 sec)
注:将donor的数据克隆到recipient端默认会覆盖其数据文件,也可以指定一个目录进行克隆,如下:
mysql> clone instance from 'donor_clone_user'@'192.168.56.81':3306 identified by 'donor_clone_user' data directory='/mysql/clone/clone_data'; Query OK, 0 rows affected (51.17 sec)
使用新目录启动MySQL服务器实例:
[root@node2 clone]# mysqld --lower-case-table-names=1 --datadir=/mysql/clone/clone_data/ --user=mysql &
推荐学习:mysql视频教程
以上がCloneプラグインのMySQL詳細分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。