---
title: Replicate data from InfluxDB OSS
description: Replicate data from select InfluxDB OSS buckets to remote buckets in InfluxDB Cloud, InfluxDB OSS, or InfluxDB Enterprise instances.
url: https://docs.influxdata.com/influxdb/v2/write-data/replication/replicate-data/
estimated_tokens: 5963
product: InfluxDB OSS v2
version: v2
---

# Replicate data from InfluxDB OSS

This page documents an earlier version of InfluxDB OSS. [InfluxDB 3 Core](/influxdb3/core/) is the latest stable version.

#### API token hashing is enabled by default in InfluxDB OSS 2.9.0

Stronger token security: tokens are stored as hashes on disk, so a copy of the database file doesn’t expose usable tokens. Existing tokens are hashed on first startup and the original strings can’t be recovered afterward — **capture any plaintext tokens you still need before you upgrade**.

For more information, see [Token hashing](/influxdb/v2/admin/tokens/#token-hashing).

Use InfluxDB replication streams (InfluxDB Edge Data Replication) to replicate the incoming data of select buckets to one or more buckets on a remote InfluxDB OSS, InfluxDB Cloud, or InfluxDB Enterprise v1 instance.

Replicate data from InfluxDB OSS to InfluxDB Cloud, InfluxDB OSS, or InfluxDB Enterprise v1.

-   [Configure a replication stream](#configure-a-replication-stream)
    
-   [Replicate downsampled or processed data](#replicate-downsampled-or-processed-data)
    
-   [View replication service metrics](#view-influxdb-oss-replication-service-metrics)
    

## Configure a replication stream

Use the [`influx` CLI](/influxdb/v2/tools/influx-cli/) or the [InfluxDB 2.9 API](/influxdb/v2/reference/api/) to configure a replication stream.

To replicate data to InfluxDB OSS or InfluxDB Enterprise v1, adjust the remote connection values accordingly.

<!-- Tabbed content: Select one of the following options -->

**CLI:**

### Step 1: Create or find a remote connection

-   [Create a remote connection](#create-a-remote-connection-cli)
-   [Use an existing remote connection](#use-an-existing-remote-connection-cli)

#### Create a remote connection (CLI)

In your local InfluxDB OSS instance, use the `influx remote create` command and provide the following arguments for the remote instance:

-   Remote connection name
-   Remote InfluxDB instance URL
-   Remote InfluxDB API token *(API token must have write access to the target bucket)*
-   Remote InfluxDB organization ID

```sh
influx remote create \
 --name example-remote-name \
 --remote-url https://cloud2.influxdata.com \
 --remote-api-token mYsuP3r5Ecr37t0k3n \
 --remote-org-id 00xoXXoxXX00
```

#### Use an existing remote connection (CLI)

Alternatively, you can use an existing connection that you have already configured. To retrieve existing connections, run `influx remote list`.

### Step 2: Create a replication stream (CLI)

In your local InfluxDB OSS instance, use the `influx replication create` command and provide the following arguments:

-   Replication stream name
-   Remote connection ID (created in the previous step)
-   Local bucket ID to replicate writes from
-   Remote bucket name or ID to replicate writes to. If replicating to **InfluxDB Enterprise v1**, use the `db-name/rp-name` bucket name syntax.

```sh
influx replication create \
 --name REPLICATION_STREAM_NAME \
 --remote-id REPLICATION_REMOTE_ID \
 --local-bucket-id INFLUX_BUCKET_ID \
 --remote-bucket REMOTE_INFLUX_BUCKET_NAME
```

After you create the replication stream, InfluxDB OSS

replicates all writes to the specified local bucket to the remote

InfluxDB bucket. Use the `influx replication list` command to view information such as the current queue size, max queue size, and latest status code.

**API:**

### Step 1: Create or find a remote connection (API)

-   [Create a remote connection](#create-a-remote-connection-api)
-   [Use an existing remote connection](#use-an-existing-remote-connection-api)

#### Create a remote connection (API)

To create a remote connection to replicate data to, send a `POST` request to your local InfluxDB OSS `/api/v2/remotes` endpoint:

[POST localhost:8086/api/v2/remotes](/influxdb/v2/api/remote-connections/)

Include the following parameters in your request:

-   **Request method:** `POST`
-   **Headers:**
    -   **Authorization:** `Token` scheme with your local InfluxDB OSS [API token](/influxdb/v2/admin/tokens/)
    -   **Content-type:** `application/json`

-   **Request body:** JSON object with the following fields:  
    \* Required
    -   \* **allowInsecureTLS:** All insecure TLS connections
    -   **description:** Remote description
    -   \* **name:** Remote connection name
    -   \* **orgID:** local InfluxDB OSS organization ID
    -   \* **remoteAPIToken:** Remote InfluxDB API token *(API token must have write access to the target bucket)*
    -   \* **remoteOrgID:** Remote InfluxDB organization ID
    -   \* **remoteURL:** Remote InfluxDB instance URL

```sh
curl --request POST http://localhost:8086/api/v2/remotes \
  --header 'Authorization: Token INFLUX_OSS_TOKEN' \
  --data '{
    "allowInsecureTLS": false,
    "description": "Example remote description",
    "name": "Example remote name",
    "orgID": "INFLUX_OSS_ORG_ID",
    "remoteAPIToken": "REMOTE_INFLUX_TOKEN",
    "remoteOrgID": "REMOTE_INFLUX_ORG_ID",
    "remoteURL": "https://cloud2.influxdata.com"
  }'
```

#### Use an existing remote connection (API)

Alternatively, you can use an existing connection that you have already configured. To retrieve existing connections, use the `/api/v2/remotes` endpoint with the `GET` request method:

[GET localhost:8086/api/v2/remotes](/influxdb/v2/api/remote-connections/)

Include the following parameters in your request:

-   **Headers:**
    -   **Authorization:** `Token` scheme with your local InfluxDB OSS [API token](/influxdb/v2/admin/tokens/)
-   **Query parameters:**
    -   **orgID:** Local InfluxDB OSS organization ID

```sh
curl --request GET \
  http://localhost:8086/api/v2/remotes?orgID=INFLUX_OSS_ORG_ID \
  --header 'Authorization: Token INFLUX_OSS_TOKEN' \
```

### Step 2: Create a replication stream (API)

Send a `POST` request to your local InfluxDB OSS `/api/v2/replications` endpoint to create a replication stream.

[POST localhost:8086/api/v2/remotes](/influxdb/v2/api/remote-connections/)

Include the following parameters in your request:

-   **Headers:**
    -   **Authorization:** `Token` scheme with your local InfluxDB OSS [API token](/influxdb/v2/admin/tokens/)
    -   **Content-type:** `application/json`

-   **Request body:** JSON object with the following fields: \* Required
    -   **dropNonRetryableData:** Drop data when a non-retryable error is encountered.
    -   \* **localBucketID:** Local InfluxDB OSS bucket ID to replicate writes from.
    -   \* **maxAgeSeconds:** Maximum age of data in seconds before it is dropped (default is `604800`, must be greater than or equal to `0`).
    -   \* **maxQueueSizeBytes:** Maximum replication queue size in bytes (default is `67108860`, must be greater than or equal to `33554430`).
    -   \* **name:** Replication stream name.
    -   \* **orgID:** Local InfluxDB OSS organization ID.
    -   \* **remoteBucketID:** Remote bucket ID to replicate writes to.
    -   \* **remoteBucketName:** Remote bucket name to replicate writes to. If replicating to **InfluxDB Enterprise v1**, use the `db-name/rp-name` bucket name syntax.

`remoteBucketID` and `remoteBucketName` are mutually exclusive. If replicating to **InfluxDB Enterprise v1**, use `remoteBucketName` with the `db-name/rp-name` bucket name syntax.

```sh
curl --request POST http://localhost:8086/api/v2/replications \
  --header 'Authorization: Token INFLUX_OSS_TOKEN' \
  --data '{
    "dropNonRetryableData": false,
    "localBucketID": "INFLUX_OSS_BUCKET_ID",
    "maxAgeSeconds": 604800,
    "maxQueueSizeBytes": 67108860,
    "name": "Example replication stream name",
    "orgID": "INFLUX_OSS_ORG_ID",
    "remoteBucketName": "REMOTE_INFLUX_BUCKET_NAME",
    "remoteID": "REMOTE_ID",
  }'
```

After you create a replication stream, InfluxDB OSS

replicates all writes from the specified local bucket to the remote

InfluxDB bucket. To get information such as the current queue size, max queue size, and latest status code for each replication stream, send a `GET` request to your local InfluxDB OSS `/api/v2/replications` endpoint:

[GET localhost:8086/api/v2/replications](/influxdb/v2/api/replications/)

Include the following parameters in your request:

-   **Headers:**
    -   **Authorization:** `Token` scheme with your local InfluxDB OSS [API token](/influxdb/v2/admin/tokens/)
-   **Query parameters:**
    -   **orgID:** Local InfluxDB OSS organization ID

```sh
curl --request GET \
  http://localhost:8086/api/v2/replications?orgID=INFLUX_OSS_ORG_ID \
  --header 'Authorization: Token INFLUX_OSS_TOKEN' \
```

<!-- End tabbed content -->

#### Important things to note

-   Only write operations are replicated. Other data operations (like deletes or restores) are not replicated.
-   In InfluxDB OSS, large write request bodies are written entirely. When replicated, write requests are sent to the remote bucket in batches. The maximum batch size is 500 kB (typically between 250 to 500 lines of line protocol). This may result in scenarios where some batches succeed and others fail.

## Replicate downsampled or processed data

In some cases, you may not want to write raw, high-precision data to a remote InfluxDB instance. To replicate only downsampled or processed data:

1. Create a bucket in your InfluxDB OSS instance to store downsampled or processed data in.
    
2. Create an InfluxDB task that downsamples or processes data and stores it in the new bucket. For example:
    
    ```js
    import "influxdata/influxdb/tasks"
    import "types"
    
    // omit this line if adding task via the UI
    option task = {name: "Downsample raw data", every: 10m}
    
    data = () => from(bucket: "example-bucket")
        |> range(start: tasks.lastSuccess(orTime: -task.every))
    
    numeric = data()
        |> filter(fn: (r) => types.isType(v: r._value, type: "float") or types.isType(v: r._value, type: "int") or types.isType(v: r._value, type: "uint"))
        |> aggregateWindow(every: task.every, fn: mean)
    
    nonNumeric = data()
        |> filter(fn: (r) => types.isType(v: r._value, type: "string") or types.isType(v: r._value, type: "bool"))
        |> aggregateWindow(every: task.every, fn: last)
    
    union(tables: [numeric, nonNumeric])
        |> to(bucket: "example-downsampled-bucket")
    ```
    
3. [Create a replication stream](#configure-a-replication-stream) to replicate data from the downsampled bucket to the remote InfluxDB instance.
    

## View InfluxDB OSS replication service metrics

In addition to replication stream information that you can access using the [CLI](?t=CLI#configure-a-replication-stream) or [API](?t=API#configure-a-replication-stream), you can view replication service-level metrics for your InfluxDB OSS instance, such as `/api/v2/write` error details, the number and duration of calls to the service, and the total number of points queued.

To view replication service-level metrics send a `GET` request to your local InfluxDB OSS `/metrics` endpoint.

For more information, see [InfluxDB OSS metrics](/influxdb/v2/reference/internals/metrics/).

#### Related

-   [influx remote](/influxdb/v2/reference/cli/influx/remote/)
-   [influx replication](/influxdb/v2/reference/cli/influx/replication/)

[write](/influxdb/v2/tags/write/) [replication](/influxdb/v2/tags/replication/)
