This topic describes how to deploy OceanBase Migration Service (OMS) Community Edition on multiple nodes in a single region by using the deployment tool.
Background information
You can deploy OMS Community Edition on a single node first and then scale out to multiple nodes.
If you choose to deploy OMS Community Edition with the
config.yamlconfiguration file, note that the settings are slightly different from those for the single-node deployment mode. For more information, see the "Template and example of a configuration file" section of this topic.To deploy OMS Community Edition on multiple nodes, you must apply for a virtual IP address (VIP) and use it as the mount point for the console of OMS Community Edition. In addition, you must configure the mapping rules for Ports 8088 and 8089 in the VIP-based network strategy.
You can use the VIP to access the console of OMS Community Edition even if a node of OMS Community Edition fails.
Prerequisites
The installation environment meets the system and network requirements. For more information, see System and network requirements.
You have created a MetaDB cluster for OMS Community Edition.
The server to deploy OMS Community Edition can connect to all other servers.
All servers involved in the multi-node deployment can connect to each other and you can obtain root permissions on a node by using its username and password.
You have obtained the installation package of OMS Community Edition, which is generally a
tar.gzfile whose name starts withoms. You can download the installation package from OceanBase Download Center.You have downloaded the installation package of OMS Community Edition and loaded it to the local image repository of the Docker container on each server node.
docker load -i <Installation package of OMS Community Edition>You have prepared a directory for mounting the container of OMS Community Edition. In the mount directory, OMS Community Edition will create the
/home/admin/logs,/home/ds/store, and/home/ds/rundirectories for storing the component information and logs generated during the running of OMS Community Edition.(Optional) You have prepared a time-series database for storing performance monitoring data and DDL/DML statistics of OMS Community Edition.
Terms
You need to replace variable names in some commands and prompts. A variable name is enclosed with angle brackets (<>).
Mount directory of the container of OMS Community Edition: the directory to which the container of OMS Community Edition is mounted.
IP address of the server: the IP address of the host that executes the script.
OMS_IMAGE: the unique identifier of the loaded image. After you load the installation package of OMS Community Edition by using Docker, run the
docker imagescommand to obtain the [IMAGE ID] or [REPOSITORY:TAG] of the loaded image. The obtained value is the unique identifier of the loaded image. Here is an example:$sudo docker images REPOSITORY TAG IMAGE ID work.oceanbase-dev.com/obartifact-store/oms feature_4.0.0-ce 2786e8a6eccdIn this example,
<OMS_IMAGE>can bework.oceanbase-dev.com/obartifact-store/oms:feature_4.0.0-ceor2786e8a6eccd. Replace the value of<OMS_IMAGE>in related commands with the preceding value.Directory of the
config.yamlfile: If you want to deploy OMS Community Edition based on an existingconfig.yamlconfiguration file, this directory is the one where the configuration file is located.
Multi-node deployment architecture
The following figure shows the multi-node deployment architecture, in which Store is the log pulling component and Incr-Sync is the incremental synchronization component. When a single point of failure (SPOF) occurs on Node A of OMS Community Edition, the Store and Incr-Sync components running on this node are guarded by the high availability (HA) service and dynamically switch to Node B or Node C of OMS Community Edition.
Notice
By default, the HA feature is disabled. To ensure high availability for the Store and Incr-Sync components, manually enable this feature in the console of OMS Community Edition. For more information, see Modify HA configurations.

Deployment procedure without a configuration file
Log in to the server where OMS Community Edition is to be deployed.
(Optional) Deploy a time-series database.
If you need to collect and display the monitoring data of OMS Community Edition, deploy a time-series database. Otherwise, you can skip this step. For more information, see Deploy a time-series database.
Run the following command to obtain the deployment script
docker_remote_deploy.shfrom the loaded image:sudo docker run -d --name oms-config-tool <OMS_IMAGE> bash && sudo docker cp oms-config-tool:/root/docker_remote_deploy.sh . && sudo docker rm -f oms-config-toolHere is an example:
sudo docker run -d --net host --name oms-config-tool work.oceanbase-dev.com/obartifact-store/oms:feature_4.0-ce bash && sudo docker cp oms-config-tool:/root/docker_remote_deploy.sh . && sudo docker rm -f oms-config-toolUse the deployment script to start the deployment tool.
bash docker_remote_deploy.sh -o <Mount directory of the OMS Community Edition container> -i <IP address of the server> -d <OMS_IMAGE>The deployment tool of OMS Community Edition automatically verifies the CPU, memory, and disk resources. If any resource item does not meet the requirement, the deployment tool will display a message prompting that insufficient resources will affect the data migration speed.
Complete the deployment as prompted. After you set each parameter, press Enter to move on to the next parameter.
Select a deployment mode.
Select Multiple Nodes in Single Region.
Select a task.
Select No Configuration File. Deploy OMS Starting from Configuration File Generation.
Enter the configuration information of the MetaDB cluster as follows:
Enter the IP address, port, username, and password of the MetaDB cluster.
Set a prefix for names of databases in the MetaDB cluster.
For example, when the prefix is set to
oms, the databases in the MetaDB cluster are namedoms_rm,oms_cm, andoms_cm_hb.Confirm your settings.
If the settings are correct, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.If the system displays The specified database names already exist in the MetaDB. Are you sure that you want to continue?, it indicates that the database names you specified already exist in the MetaDB cluster. This may be caused by repeated deployment or upgrade of OMS Community Edition. You can enter
yand press Enter to proceed, or enternand press Enter to re-specify the settings.If you enter
yand press Enter, the message The specified database names already exist in the MetaDB. Do you want to reinitialize the MetaDB? is displayed. You can enteryand press Enter to reinitialize the MetaDB cluster.
Enter the cluster configuration information for OMS Community Edition as follows:
Set whether to define component ports and configure related parameters.
You can enter
yand press Enter to configure custom ports for components. Enter the ports of the Nginx, GHANA, CM, Supervisor, and sshd services as prompted.Specify the URL of the CM service, which is the VIP or domain name to which all CM servers in the region are mounted. The corresponding parameter in the configuration file is
cm-url.Enter the VIP or domain name as the URL of the CM service. You can enter the IP address and port number in the URL in sequence, or use a colon (:) to join the IP address and port number in the <IP address>:<port number> format.
Note
The
http://prefix in the URL is optional.Enter the IP addresses of all servers in the region. Separate them with commas (,).
Confirm whether the displayed settings of OMS Community Edition cluster are correct.
If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.
Determine whether to monitor historical data of OMS Community Edition.
If you have deployed a time-series database in Step 2, enter
yand press Enter to go to the step of configuring the time-series database and enable monitoring of historical data for OMS Community Edition.If you chose not to deploy a time-series database in Step 2, enter
nand press Enter to go to the step of determining whether to enable the audit log feature and configure Simple Log Service (SLS) parameters. In this case, OMS Community Edition does not monitor the historical data after deployment.
Configure the time-series database.
Perform the following operations:
Confirm whether you have deployed a time-series database.
Enter the value based on the actual situation. If yes, enter
yand press Enter. If no, enternand press Enter to go to the step of "determining whether to enable the audit log feature and setting SLS parameters".Set the type of the time-series database to
INFLUXDB.Notice
At present, only INFLUXDB is supported.
Enter the URL, username, and password of the time-series database as prompted.
Confirm whether the displayed settings are correct.
If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.
Determine whether to enable the audit log feature and write the audit logs to SLS.
To enable the audit log feature, enter
yand press Enter to go to the next step to specify the SLS parameters.Otherwise, enter
nand press Enter to start the deployment. In this case, OMS Community Edition does not audit the logs after deployment.Specify the SLS parameters.
Set the SLS parameters as prompted.
Confirm whether the displayed settings are correct.
If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.If the configuration file passes the check, all the settings are displayed. If the settings are correct, enter
nand press Enter to proceed. Otherwise, enteryand press Enter to modify the settings.If the configuration file fails the check, modify the settings as prompted.
Complete deployment settings on each node as follows:
Specify the directory to which OMS Community Edition is mounted on the node.
Specify a directory with a large capacity.
Confirm whether the image file of OMS Community Edition can be named
<OMS_IMAGE>.If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.Determine whether to mount an SSL certificate to the container of OMS Community Edition.
If yes, enter
y, press Enter, and specify thehttps_keyandhttps_crtdirectories as prompted. Otherwise, enternand press Enter.If the current node is a remote node, the system finds that the IP address of the deployment mode is inconsistent with the IP address of the server where the deployment tool resides, and asks you whether to remotely execute the script. This requires that the remote node support SSH connection and you have the
sudoprivilege on the remote node.If you enter
y, check whether the port of the node can be connected through an SSH connection. If SSH connection is supported, enter the username and password for logging in to the remote node as prompted.If you leave the password empty, the system will prompt that the password is an empty string and ask you whether to use trusted login. If you enter
y, enter the password of thesudouser again. If no password is required, directly press Enter.Confirm whether the path to which the
config.yamlconfiguration file will be written is correct.
If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.
If the deployment fails, you can log in to the container of OMS Community Edition and view logs in the
.logfiles prefixed withdocker_initin the/home/admin/logsdirectory. If the container of OMS Community Edition fails to be started, you cannot obtain logs.
Deployment procedure with a configuration file
Log in to the server where OMS Community Edition is to be deployed.
(Optional) Deploy a time-series database.
If you need to collect and display the monitoring data of OMS Community Edition, deploy a time-series database. Otherwise, you can skip this step. For more information, see Deploy a time-series database.
Run the following command to obtain the deployment script
docker_remote_deploy.shfrom the loaded image:sudo docker run -d --name oms-config-tool <OMS_IMAGE> bash && sudo docker cp oms-config-tool:/root/docker_remote_deploy.sh . && sudo docker rm -f oms-config-toolUse the deployment script to start the deployment tool.
bash docker_remote_deploy.sh -o <Mount directory of the OMS Community Edition container> -c <Directory of the existing config.yaml file> -i <IP address of the server> -d <OMS_IMAGE>The deployment tool of OMS Community Edition automatically verifies the CPU, memory, and disk resources. If any resource item does not meet the requirement, the deployment tool will display a message prompting that insufficient resources will affect the data migration speed.
Note
- The value of the
-coption must be the absolute path of theconfig.yamlconfiguration file. - For more information about settings of the
config.yamlfile, see the "Template and example of a configuration file" section.
- The value of the
Complete the deployment as prompted. After you set each parameter, press Enter to move on to the next parameter.
Select a deployment mode.
Select Multiple Nodes in Single Region.
Select a task.
Select Use Configuration File Uploaded with Script Option [-c].
If the system displays The specified database names already exist in the MetaDB. Are you sure that you want to continue?, it indicates that the database names you specified already exist in the MetaDB cluster in the original configuration file. This may be caused by repeated deployment or upgrade of OMS Community Edition. You can enter
yand press Enter to proceed, or enternand press Enter to re-specify the settings.If the configuration file passes the check, all the settings are displayed. If the settings are correct, enter
nand press Enter to proceed. Otherwise, enteryand press Enter to modify the settings.If the configuration file fails the check, modify the settings as prompted.
Complete deployment settings on each node as follows:
Specify the directory to which the container of OMS Community Edition is mounted on the node.
Specify a directory with a large capacity.
For a remote node, the username and password for logging in to the remote node are required. The corresponding user account must have the sudo privilege on the remote node.
Confirm whether the image file of OMS Community Edition can be named
<OMS_IMAGE>.If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.Determine whether to mount an SSL certificate to the container of OMS Community Edition.
If yes, enter
y, press Enter, and specify thehttps_keyandhttps_crtdirectories as prompted. Otherwise, enternand press Enter.If the current node is a remote node, the system finds that the IP address of the deployment mode is inconsistent with the IP address of the server where the deployment tool resides, and asks you whether to remotely execute the script. This requires that the remote node support SSH connection and you have the
sudoprivilege on the remote node.If you enter
y, check whether the port of the node can be connected through an SSH connection. If SSH connection is supported, enter the username and password for logging in to the remote node as prompted.If you leave the password empty, the system will prompt that the password is an empty string and ask you whether to use trusted login. If you enter
y, enter the password of thesudouser again. If no password is required, directly press Enter.Confirm whether the path to which the
config.yamlconfiguration file will be written is correct.If yes, enter
yand press Enter to proceed. Otherwise, enternand press Enter to modify the settings.
If the deployment fails, you can log in to the container of OMS Community Edition and view logs in the
.logfiles prefixed withdocker_initin the/home/admin/logsdirectory. If the container of OMS Community Edition fails to be started, you cannot obtain logs.
To modify the configuration after deployment, perform the following steps:
Notice
If you deploy OMS Community Edition on multiple nodes in a single region, you must manually modify the configuration of each node.
Log in to the container of OMS Community Edition.
Modify the
config.yamlfile in the/home/admin/conf/directory based on business needs.Run the
python -m omsflow.scripts.units.oms_init_manager --init-config-filecommand.Run the
supervisorctl restart oms_console oms_drc_supervisorcommand.
Template and example of a configuration file
Configuration file template
Notice
The same configuration file applies to all nodes in the multi-node deployment architecture. In the configuration file, you must specify the IP addresses of multiple nodes for the
cm_nodesparameter and set thecm_urlparameter to the VIP corresponding to Port 8088.You must replace the sample values of required parameters based on your actual deployment environment. Both the required and optional parameters are described in the following table. You can specify the optional parameters as needed.
In the
config.yamlfile, you must specify the parameters in thekey: valueformat, with a space after the colon (:).
# Information about the MetaDB cluster for OMS Community Edition
oms_meta_host: ${oms_meta_host}
oms_meta_port: ${oms_meta_port}
oms_meta_user: ${oms_meta_user}
oms_meta_password: ${oms_meta_password}
# You can define the names of the following three databases, which are created in the MetaDB cluster during the deployment of OMS Community Edition.
drc_rm_db: ${drc_rm_db}
drc_cm_db: ${drc_cm_db}
drc_cm_heartbeat_db: ${drc_cm_heartbeat_db}
# Configurations of OMS Community Edition
# To deploy OMS Community Edition on multiple nodes in a single region, you must set the cm_url parameter to a VIP or domain name to which all CM servers in the region are mounted.
cm_url: ${cm_url}
cm_location: ${cm_location}
# The cm_region parameter is not required for single-region deployment.
# cm_region: ${cm_region}
# The cm_region_cn parameter is not required for single-region deployment.
# cm_region_cn: ${cm_region_cn}
cm_is_default: true
cm_nodes:
- ${host_ip1}
- ${host_ip2}
# Configurations of the time-series database
# The default value of `tsdb_enabled`, which specifies whether to configure a time-series database, is `false`. To enable metric reporting, set the parameter to `true` and delete the comments for the parameter.
# tsdb_enabled: false
# If the `tsdb_enabled` parameter is set to `true`, delete comments for the following parameters and specify the values based on your actual configurations.
# tsdb_service: 'INFLUXDB'
# tsdb_url: '${tsdb_url}'
# tsdb_username: ${tsdb_user}
# tsdb_password: ${tsdb_password}
# Custom component ports
# Specify the port number for the GHANA service.
ghana_server_port: xxxxx
# Specify the port number for the Nginx service.
nginx_server_port: xxxxx
# Specify the port number for the CM service.
cm_server_port: xxxxx
# Specify the port number for the Supervisor service.
supervisor_server_port: xxxxx
# Specify the port number for the sshd service.
sshd_server_port: xxxxx
| Parameter | Description | Required |
|---|---|---|
| oms_meta_host | The IP address of the MetaDB cluster, which can be that of a MySQL database or a MySQL tenant of OceanBase Database Community Edition. | Yes |
| oms_meta_port | The port number of the MetaDB cluster. | Yes |
| oms_meta_user | The username used for accessing the MetaDB cluster. | Yes |
| oms_meta_password | The user password used for accessing the MetaDB cluster. | Yes |
| drc_rm_db | The name of the database for the console of OMS Community Edition. | Yes |
| drc_cm_db | The name of the database for the CM service. | Yes |
| drc_cm_heartbeat_db | The name of the heartbeat database for the CM service. | Yes |
| cm_url | The URL of the CM service of OMS Community Edition, for example, http://VIP:8088. Note To deploy OMS Community Edition on multiple nodes in a single region, you must set the cm_url parameter to a VIP or domain name to which all CM servers in the region are mounted. We recommend that you do not set it to http://127.0.0.1:8088, which cannot be used for scaling out to multiple nodes in multiple regions. The access URL of the console of OMS Community Edition is in the following format: IP address of the server where OMS Community Edition is deployed:8089, for example, http://xxx.xxx.xxx.1:8089 or https://xxx.xxx.xxx.1:8089. Port 8088 is used for program calls, and Port 8089 is used for web page access. |
Yes |
| cm_location | The code of the region. Value range: [0, 127]. You can select one number for each region. | Yes |
| cm_region | The name of the region, for example, cn-jiangsu. Notice If you use OMS Community Edition with the Alibaba Cloud Multi-Site High Availability (MSHA) service in an active-active disaster recovery scenario, use the region configured for the Alibaba Cloud service. |
No |
| cm_region_cn | The value here is the same as the value of cm_region. | No |
| cm_nodes | The IP addresses of servers on which the CM service of OMS Community Edition is deployed. In multi-node deployment mode, you must specify multiple IP addresses for the parameter. | Yes |
| cm_is_default | Specifies whether the CM service is enabled for OMS Community Edition by default. | No. Default value: true. |
| tsdb_service | The type of the time-series database. Valid values: INFLUXDB and CERESDB. |
No. Default value: INFLUXDB. |
| tsdb_enabled | Specifies whether metric reporting is enabled for monitoring. Valid values: true and false. |
No. Default value: false. |
| tsdb_url | The IP address of the server where InfluxDB is deployed. You need to modify this parameter based on the actual environment if you set the tsdb_enabled parameter to true. |
No |
| tsdb_username | The username used for accessing the time-series database. You need to modify this parameter based on the actual environment if you set the tsdb_enabled parameter to true. After you deploy a time-series database, manually create a user and specify the username and password. |
No |
| tsdb_password | The password used for accessing the time-series database. You need to modify this parameter based on the actual environment if you set the tsdb_enabled parameter to true. |
No |
| ghana_server_port | The port number of the GHANA service. If this parameter is not specified, the default port number 8090 is used. | No |
| nginx_server_port | The port number of the Nginx service. If this parameter is not specified, the default port number 8089 is used. | No |
| cm_server_port | The port number of the CM service. If this parameter is not specified, the default port number 8088 is used. | No |
| supervisor_server_port | The port number of the Supervisor service. If this parameter is not specified, the default port number 9000 is used. | No |
| sshd_server_port | The port number of the sshd service. If this parameter is not specified, the default port number 2023 is used. | No |
Sample configuration file
Replace related parameters with the actual values in the target deployment environment.
oms_meta_host: xxx.xxx.xxx.xxx
oms_meta_port: 2883
oms_meta_user: oms_meta_user
oms_meta_password: *********
drc_rm_db: oms_rm
drc_cm_db: oms_cm
drc_cm_heartbeat_db: oms_cm_heartbeat
cm_url: http://VIP:8088
cm_location: 100
cm_region: cn-anhui
cm_region_cn: cn-anhui
cm_is_default: true
cm_nodes:
- xxx.xxx.xxx.xx1
- xxx.xxx.xxx.xx2
tsdb_service: 'INFLUXDB'
tsdb_enabled: true
tsdb_url: 'xxx.xxx.xxx.xxx:8086'
tsdb_username: username
tsdb_password: ********
ghana_server_port: xxxxx
nginx_server_port: xxxxx
cm_server_port: xxxxx
supervisor_server_port: xxxxx
sshd_server_port: xxxxx