Replicate from HBase to Bigtable

The Cloud Bigtable HBase replication library is a component of the open-source Cloud Bigtable HBase client for Java. The replication library lets you asynchronously replicate data from an HBase cluster to a Bigtable instance using the HBase replication service. To review the README and source code, visit the GitHub repository.

Use cases

  • Online migration to Bigtable - You can use the Bigtable HBase replication library, in conjunction with an offline migration of your existing HBase data, to migrate from HBase to Bigtable with almost no downtime.
  • Data recovery - Prepare for the unexpected by replicating your HBase data to an offsite Bigtable instance.
  • Centralizing datasets - Use the library to replicate data from HBase clusters in multiple locations to a single Bigtable instance that automatically handles replication among its clusters.
  • Extending your HBase footprint - Replicate to a Bigtable instance that has clusters in locations beyond your current HBase locations.

Overview

The Bigtable HBase replication library extends the base HBase replication service. Data that is written to an HBase cluster is replicated asynchronously to a Bigtable instance in the same way that standard HBase replication copies data to another HBase cluster. The library uses the write-ahead log (WAL) of the source HBase cluster to push the mutations to the Bigtable instance.

You can replicate an entire HBase cluster to Bigtable or replicate only specific tables or column families. In other words, HBase replication is enabled at the cluster, table, or column family level.

Replication from HBase to Bigtable is eventually consistent.

image

Migrate to Bigtable

The Bigtable HBase replication library lets you migrate to Bigtable without pausing your application.

At a high level, the steps for online migration from HBase to Bigtable are as follows. See the README for more details.

  1. Before you begin, follow the setup and configuration steps.
  2. Enable replication on your HBase cluster.
  3. Add a Bigtable replication endpoint as a peer.
  4. Disable the Bigtable peer. This causes writes to HBase from that point onward to buffer on the HBase cluster.
  5. Once the buffering has started to capture new writes, follow the offline migration guide to migrate a snapshot of your existing HBase data.
  6. When the offline migration is complete, re-enable the Bigtable peer to let the buffer drain and replay writes on Bigtable.
  7. After the buffer is drained, restart your application to send requests to Bigtable.

Set up and configure the replication library

Before you can use the Bigtable HBase replication, you need to complete the tasks in this section.

Configure authentication

To ensure that the replication library has permission to write to Bigtable, follow the steps at Create a service account. Assign the role roles/bigtable.user to the newly created service account.

Next, add the following to your hbase-site.xml file across the entire HBase cluster.

<property>
    <name>google.bigtable.auth.json.keyfile</name>
    <value>JSON_FILE_PATH</value>
    <description>
        Service account JSON file to connect to Cloud Bigtable
    </description>
</property>

Replace JSON_FILE_PATH with the path to the JSON file that you downloaded.

For additional properties that you can set, see HBaseToCloudBigtableReplicationConfiguration.

Create a destination instance and tables

Before you can replicate from HBase to Bigtable, create a Bigtable instance. A Bigtable instance can have one cluster or multiple clusters that operate in a multi-primary fashion. Requests from the HBase replication service are routed to the closest cluster in the Bigtable instance, then replicated to the other clusters in the instance.

Your Bigtable destination table needs to have the same name and same column families as your HBase table. For step-by-step instructions on using the Bigtable Schema Translation tool to create a table with the same schema as your HBase table, see Create destination tables. Even though you are replicating, rather than importing your data, the steps are the same.

Set the config properties

Add the following to your hbase-site.xml across the entire HBase cluster.

<property>
    <name>google.bigtable.project.id</name>
    <value>PROJECT_ID</value>
    <description>
      Bigtable project ID
    </description>
</property>
<property>
    <name>google.bigtable.instance.id</name>
    <value>INSTANCE_ID</value>
    <description>
       Bigtable instance ID
    </description>
</property>
<property>
    <name>google.bigtable.app_profile.id</name>
    <value>APP_PROFILE_ID</value>
    <description>
       Bigtable app profile ID
    </description>
</property>

Replace the following:

  • PROJECT_ID: The Google Cloud project that your Bigtable instance is in.
  • INSTANCE_ID: The ID of the Bigtable instance that you are replicating your data to.
  • APP_PROFILE_ID: The ID of the app profile to use to connect to Bigtable.

Install the replication library

To use the Bigtable HBase replication library, you need to install it on every server in the HBase cluster. Use the replication library version that corresponds to your HBase version (1.x or 2.x).

Download the JAR

To get the replication library, run the following in the HBase shell.

wget BIGTABLE_HBASE_REPLICATION_URL

Replace BIGTABLE_HBASE_REPLICATION_URL with the URL of the latest JAR with dependencies available in the replication library's Maven repository. The file name is similar to https://repo1.maven.org/maven2/com/google/cloud/bigtable/bigtable-hbase-1.x-replication/1.0.0/bigtable-hbase-1.x-replication-1.0.0-jar-with-dependencies.jar.

To find the URL or to manually download the JAR, do the following.

  1. Go to the replication library repository for the version of HBase that you are using.
  2. Click the most recent version number, such as 1.0.0.
  3. Identify the jar-with-dependencies file (usually at the top).
  4. Either right-click and copy the URL, or click to download the file.

Install the JAR

On every HBase server, including the master and region servers, copy the file that you just downloaded to a folder in the HBase classpath. For example, you might copy the file to /usr/lib/hbase/lib/.

Add a Bigtable peer

To replicate from HBase to Bigtable, you need to add a Bigtable endpoint as a replication peer.

  1. Restart the HBase servers to ensure that the replication library is loaded.
  2. Run the following in the HBase shell.
add_peer PEER_ID_NUMBER, ENDPOINT_CLASSNAME =>
'com.google.cloud.bigtable.hbaseHBASE_VERSION_NUMBER_x.replication.HbaseToCloudBigtableReplicationEndpoint`

Replace the following:

  • PEER_ID_NUMBER: An integer ID for the Bigtable replication peer. To enable HBase replication of only select tables, use an add_peer optional parameter.

  • HBASE_VERSION_NUMBER: The number of the HBase version that you are using. Use 1 for HBase 1.x and 2 for HBase 2.x. (HBase 3.x is not supported.)

What's next