若要將實例新增至 ReplicaSet,請完成下列步驟
- 
使用 ReplicaSet.addInstance(instance)ReplicaSet。您將instance指定為類似 URI 的連線字串。您指定的用戶必須具有必要的權限,並且在 ReplicaSet 中的所有實例上都必須相同。如需詳細資訊,請參閱第 9.2 節,「設定 InnoDB ReplicaSet 實例」。例如,若要新增位於 rs-2、連接埠號碼3306和用戶rsadmin的實例,請發出mysql-js> rs.addInstance('rsadmin@rs-2:3306') Adding instance to the replicaset... * Performing validation checks This instance reports its own address as rsadmin@rs-2 rsadmin@rs-2: Instance configuration is suitable. * Checking async replication topology... * Checking transaction state of the instance... NOTE: The target instance 'rsadmin@rs-2' has not been pre-provisioned (GTID set is empty). The Shell is unable to decide whether replication can completely recover its state. The safest and most convenient way to provision a new instance is through automatic clone provisioning, which will completely overwrite the state of 'rsadmin@rs-2' with a physical snapshot from an existing replicaset member. To use this method by default, set the 'recoveryMethod' option to 'clone'. WARNING: It should be safe to rely on replication to incrementally recover the state of the new instance if you are sure all updates ever processed in the replicaset were done with GTIDs enabled, there are no purged transactions and the new instance contains the same GTID set as the replicaset, or a subset of it. To use this method by default, set the 'recoveryMethod' option to 'incremental'. Please select a recovery method [C]lone/[I]ncremental recovery/[A]bort (default Clone):
- 
在此情況下,我們並未指定復原方法,因此操作會建議您如何最好地繼續。在本範例中,我們選擇 Clone選項,因為我們在加入 ReplicaSet 的實例上沒有任何現有交易。因此,沒有從加入實例刪除資料的風險。如需詳細資訊,請參閱第 9.5.1 節,「佈建 InnoDB ReplicaSet 的實例」。Please select a recovery method [C]lone/[I]ncremental recovery/[A]bort (default Clone): C * Updating topology Waiting for clone process of the new member to complete. Press ^C to abort the operation. * Waiting for clone to finish... NOTE: rsadmin@rs-2 is being cloned from rsadmin@rs-1 ** Stage DROP DATA: Completed ** Clone Transfer FILE COPY ############################################################ 100% Completed PAGE COPY ############################################################ 100% Completed REDO COPY ############################################################ 100% Completed ** Stage RECOVERY: \ NOTE: rsadmin@rs-2 is shutting down... * Waiting for server restart... ready * rsadmin@rs-2 has restarted, waiting for clone to finish... * Clone process has finished: 59.63 MB transferred in about 1 second (~1.00 B/s) ** Configuring rsadmin@rs-2 to replicate from rsadmin@rs-1 ** Waiting for new instance to synchronize with PRIMARY... The instance 'rsadmin@rs-2' was added to the replicaset and is replicating from rsadmin@rs-1.
- 
假設該實例對 InnoDB ReplicaSet 使用有效,則復原會繼續。在此情況下,新加入的實例會使用 MySQL Clone 從主要實例複製所有尚未套用的交易,然後它會以線上實例的形式加入 ReplicaSet。若要驗證,請使用 rs.status()mysql-js> rs.status() { "replicaSet": { "name": "example", "primary": "rs-1:3306", "status": "AVAILABLE", "statusText": "All instances available.", "topology": { "rs-1:3306": { "address": "rs-1:3306", "instanceRole": "PRIMARY", "mode": "R/W", "status": "ONLINE" }, "rs-2:3306": { "address": "rs-2:3306", "instanceRole": "SECONDARY", "mode": "R/O", "replication": { "applierStatus": "APPLIED_ALL", "applierThreadState": "Replica has read all relay log; waiting for more updates", "receiverStatus": "ON", "receiverThreadState": "Waiting for source to send event", "replicationLag": null }, "status": "ONLINE" } }, "type": "ASYNC" } }此輸出顯示名為 example的 ReplicaSet 現在包含兩個 MySQL 實例,且主要實例為rs-1。目前,在rs-2有一個次要實例,它是主要實例的複本。ReplicaSet 為線上,表示主要實例和次要實例處於同步狀態。此時,ReplicaSet 已準備好處理交易。
- 若要覆寫互動式 MySQL Shell 模式,請選擇最適合的復原方法。使用 - recoveryMethod選項設定實例如何復原加入 ReplicaSet 所需的資料。如需詳細資訊,請參閱第 7.4.6 節,「搭配 InnoDB 叢集使用 MySQL Clone」。