Updated on 2024-04-17 GMT+08:00

Migrating RocketMQ Services

Scenario

RocketMQ service migration involves the following scenarios:

  • Migrating RocketMQ from other vendors to DMS for RocketMQ.
  • Migrating self-built RocketMQ to DMS for RocketMQ.
  • Migrating one RocketMQ instance to another RocketMQ instance in the cloud.

To migrate metadata, you can use either of the following methods as required:

  • Method 1: Run the mqadmin command to export the source instance metadata and then create a migration task in DMS for RocketMQ.
  • Method 2: Export the source topics and consumer groups and then import them to DMS for RocketMQ using scripts. (Use this method when metadata cannot be exported using the mqadmin command.)

Prerequisites

  1. Configure the network environment.

    A RocketMQ instance can be accessed within a VPC or over a public network. For public network access, the producer and consumer must have public access permissions, and the following security group rules must be configured.

    Table 1 Security group rules

    Direction

    Protocol

    Port

    Source

    Description

    Inbound

    TCP

    8200

    0.0.0.0/0

    The port is used for public access to metadata nodes.

    Inbound

    TCP

    10100-10199

    0.0.0.0/0

    The port is used for accessing service nodes.

  2. Buy a RocketMQ instance.

    For details, see Buying a RocketMQ Instance.

  3. A Linux host is available, JDK v1.8.111 or later has been installed on the host, and related environment variables have been configured.

Procedure (Using the mqadmin Command to Export the Metadata of the Source Instance)

  1. Migrate metadata to the RocketMQ instance.

    1. Obtain the RocketMQ metadata from another cloud or self-hosted RocketMQ.
      1. Log in to the host and download the RocketMQ software package.
        wget https://archive.apache.org/dist/rocketmq/4.9.8/rocketmq-all-4.9.8-bin-release.zip
      2. Decompress the software package.
        unzip rocketmq-all-4.9.8-bin-release.zip
      3. (Optional) If ACL is enabled for the RocketMQ instance, authentication is required when you run the mqadmin command.
        Switch to the directory where the decompressed software package is stored and add the following content to the conf/tools.yml file:
        accessKey:*******
        secretKey:*******

        accessKey and secretKey are the username and secret key set on the Users page of the console.

      4. Go to the directory where the decompressed software package is stored and run the following command to query the cluster name:
        sh ./bin/mqadmin clusterList -n {nameserver address and port number}

        For example, if the nameserver address and port number are 192.168.0.65:8100, run the following command:

        sh ./bin/mqadmin clusterList -n 192.168.0.65:8100
      5. Run the following command to export metadata:
        • If SSL is disabled, run the following command:
          sh ./bin/mqadmin exportMetadata -n {nameserver address and port number} -c {RocketMQ cluster name} -f {Path for storing the exported metadata file}

          For example, if the nameserver address and port number are 192.168.0.65:8100, the RocketMQ cluster name is DmsCluster, and the path for storing exported metadata files is /tmp/rocketmq/export, run the following command:

          sh ./bin/mqadmin exportMetadata -n 192.168.0.65:8100 -c DmsCluster -f /tmp/rocketmq/export
        • If SSL is enabled, run the following command:
          JAVA_OPT=-Dtls.enable=true sh ./bin/mqadmin exportMetadata -n {nameserver address and port number} -c {RocketMQ cluster name} -f {path for storing the exported metadata file}

          For example, if the nameserver address and port number are 192.168.0.65:8100, the RocketMQ cluster name is DmsCluster, and the path for storing exported metadata files is /tmp/rocketmq/export, run the following command:

          JAVA_OPT=-Dtls.enable=true sh ./bin/mqadmin exportMetadata -n 192.168.0.65:8100 -c DmsCluster -f /tmp/rocketmq/export
    2. Migrate metadata on the console.
      1. Log in to the DMS for RocketMQ console.
      2. Click a RocketMQ instance to go to the instance details page.
      3. In the navigation pane, choose Metadata Migration.
      4. Click Create Migration Task.
      5. Configure the migration task by referring to Table 2.
        Table 2 Migration task parameters

        Parameter

        Description

        Task Name

        Unique name of the migration task.

        Overwrite

        • If this option is enabled, configurations in the metadata file with the same name as the uploaded file will be modified.

          Assume that Topic01 on the source instance has three read queues, and Topic01 on the DMS instance has two read queues. If Overwrite is enabled, Topic01 on the DMS instance will have three read queues after migration.

        • If this option is disabled, migration of the metadata file with the same name as the uploaded file will fail.

          Assume that the source instance has Topic01 and Topic02, and the DMS instance has Topic01 and Topic03. If Overwrite is disabled, migration of the source Topic01 will fail.

        Metadata

        Upload the RocketMQ metadata obtained from another cloud or self-hosted RocketMQ.

      6. Click OK.

        After the migration is complete, view Task Status in the migration task list.

        • If Task Status is Complete, all metadata has been successfully migrated.
        • If Task Status is Failed, some or all metadata fails to be migrated. Click the migration task name to go to the migration task details page. In the Migration Result area, view the name of the topic or consumer group that fails to be migrated and the failure cause.

  2. Migrate the production service to the RocketMQ instance.

    Change the metadata connection address on the production client to the metadata connection address of the RocketMQ instance and then restart the production service. New messages will be sent to the RocketMQ instance.

  3. Migrate the consumption service to the RocketMQ instance.

    After all messages in the consumer group are consumed, change the metadata connection address of the consumer client to the metadata connection address of the RocketMQ instance. New messages will be consumed from the RocketMQ instance.

  4. If there are multiple source RocketMQ instances, migrate services from them one by one.

Procedure (Metadata Cannot Be Exported Using the mqadmin Command)

  1. Log in to the console of another vendor and export the lists of source topics and consumer groups.
  2. Create the topics.txt and groups.txt files and add the source topic list and consumer group list to the files respectively. Each line contains a topic or consumer group name. For example:

    topic-01
    topic-02
    ...
    topic-n

    Note: The groups.txt file cannot contain blank lines (for example, a newline character at the end of a consumer group name). Otherwise, consumer groups with empty names will be created when the lists are imported to the RocketMQ instance.

  3. Log in to the host and download the RocketMQ software package.

    wget https://archive.apache.org/dist/rocketmq/4.9.8/rocketmq-all-4.9.8-bin-release.zip

  4. Decompress the software package.

    unzip rocketmq-all-4.9.8-bin-release.zip

  5. (Optional) If ACL is enabled for the RocketMQ instance, authentication is required when you run the mqadmin command.

    Switch to the directory where the decompressed software package is stored and add the following content to the conf/tools.yml file:
    accessKey:*******
    secretKey:*******

    accessKey and secretKey are the username and secret key set on the Users page of the console.

  6. Go to the bin directory of the decompressed software package and upload topics.txt and groups.txt to this directory.
  7. Run the following script to import the source topics and consumer groups to DMS for RocketMQ:

    #!/bin/bash
    
    # Read groups from groups.txt file
    groups=()
    while read -r group; do
      groups+=("$group")
    done < "groups.txt"
    
    # Read topics from topic.txt file
    topics=()
    while read -r topic; do
      topics+=("$topic")
    done < "topics.txt"
    
    # Add topics
    for topic in "${topics[@]}"; do
      echo "Adding topic: $topic"
      sh mqadmin updateTopic -n <namesrvIp:8100> -c DmsCluster -t "$topic"
    done
    
    # Add consumer groups
    for group in "${groups[@]}"; do
      echo "Adding consumer group: $group"
      sh mqadmin updateSubGroup -n <namesrvIp:8100> -c DmsCluster -g "$group"
    done

    namesrvIp:8100 indicates the address of the RocketMQ instance.

  8. Log in to DMS for RocketMQ console. Go to the Topics and Consumer Groups pages and check whether the topics and consumer groups are successfully imported.
  9. Migrate the production service to the RocketMQ instance.

    Change the metadata connection address on the production client to the metadata connection address of the RocketMQ instance and then restart the production service. New messages will be sent to the RocketMQ instance.

  10. Migrate the consumption service to the RocketMQ instance.

    After all messages in the consumer group are consumed, change the metadata connection address of the consumer client to the metadata connection address of the RocketMQ instance. New messages will be consumed from the RocketMQ instance.

  11. If there are multiple source RocketMQ instances, migrate services from them one by one.