Skip to content

Commit

Permalink
v0.1 docker deploy docs
Browse files Browse the repository at this point in the history
Signed-off-by: Paul Balaji <[email protected]>
  • Loading branch information
paulbalaji committed Jan 15, 2024
1 parent 9e15500 commit 86cdb78
Showing 1 changed file with 248 additions and 12 deletions.
260 changes: 248 additions & 12 deletions docs/guides/deploy-hyperlane-local-agents.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import DeployContractsPartial from "/docs/partials/deploy-hyperlane/_deploy-cont
import SendTestMessagesPartial from "/docs/partials/deploy-hyperlane/_send-test-messages.mdx";
import DeployWarpRoutePartial from "/docs/partials/deploy-hyperlane/_deploy-warp-route.mdx";

import Tabs from "@theme/Tabs";
import TabItem from "@theme/TabItem";

# Deploy Hyperlane with Local Agents

:::tip
Expand Down Expand Up @@ -39,35 +42,268 @@ There are six steps in this guide:

## 3. Run a validator

Follow the [Validators guide](/docs/operate/validators/run-validators) to run a validator for the Mailbox on your local chain. This validator will provide the security for messages sent _from_ your chain to remote chains.
Validators provide the security for messages sent _from_ your chain to remote chains.

### Setup directories

First, set the `CONFIG_FILES` environment variable to the path of the agent config generated in the [deploy contracts](#2-deploy-contracts) step. For example:

```bash
export CONFIG_FILES=/full/path/to/configs/agent-config-{timestamp}.json
```

Next, create a local directory for your validator to write its signatures to. Remember the path, as you will need this when configuring your validator.

```sh
# Pick an informative name specific to the chain you're validating
export VALIDATOR_SIGNATURES_DIR=/tmp/hyperlane-validator-signatures-<your_chain_name>

# Create the directory
mkdir -p $VALIDATOR_SIGNATURES_DIR
```

:::warning

You will not be able to mount anything in `/tmp` when running the agent via Docker on Mac. To counter this, create a local `tmp` directory to mount instead.

```sh
# Create a local tmp directory that can be accessed by docker
mkdir tmp

# Pick an informative name specific to the chain you're validating
export VALIDATOR_SIGNATURES_DIR=tmp/hyperlane-validator-signatures-<your_chain_name>

# Create the directory
mkdir -p $VALIDATOR_SIGNATURES_DIR
```

:::

### Configure

You should have already set up your validator keys in [step 1](#1-set-up-keys), so you can skip that part of the guide.
There are numerous parameters that validators can be configured with. For this guide, we are concerned with just a handful:

| Parameter | Description |
| ------------------------- | ------------------------------------------------------------------- |
| `--db` | Path for writing persistent data to disk. |
| `--originChainName` | Name of the chain being validated (e.g. `ethereum`). |
| `--checkpointSyncer.type` | Set to `localStorage` for this guide. |
| `--checkpointSyncer.path` | Path to local directory where validator signatures will be written. |
| `--validator.key` | Your validator's hexadecimal private key. |

:::info

Make sure your validator matches the address provided when setting up your MultisigIsmConfig. Otherwise, the Multisig ISM you deployed in the previous step will not be able to verify messages sent from your chain.
Make sure the validator key corresponds to the address provided when setting up your MultisigIsmConfig. Otherwise, the Multisig ISM you deployed in the previous step will not be able to verify messages sent from your chain.

:::

Set the `CONFIG_FILES` environment variable to the path of the agent config generated in the [deploy contracts](#2-deploy-contracts) step. For example:
```bash
export CONFIG_FILES=/path/to/configs/agent-config-{timestamp}.json
<Tabs groupId="docker">
<TabItem value="docker" label="Using Docker">

**Update agent config**

Unless you are running on Linux, you will also need to update the agent configuration for your network. This is because Docker does not support the [`host` network mode](https://docs.docker.com/network/drivers/host/) on Mac, Windows or Windows Server.

To do this, navigate to the agent-configuration at `$CONFIG_FILES` and replace all instances of "localhost" or "127.0.0.1" in to `host.docker.internal`. For example:

```json
...
"localnet1": {
...
"rpcUrls": [
{
// "http": "http://localhost:8545"
// "http": "http://127.0.0.1:8545"
"http": "http://host.docker.internal:8545"
}
],
...
},
...
```

**Mounting directories**

Running with Docker adds an extra layer of complexity because config files need to be accessible from within the Docker container, and validator signatures need to be accessible from outside of the container. This can be solved by mounting directories on your file system into the container.

In the arguments below, we:

1. Set the `$CONFIG_FILES` environment variable to a fixed path within the container.
1. Mount the agent config file to this fixed path and making it readonly.
1. Mount the persistent data directory at a fixed path within the container.
1. Mount the validator signatures directory to a fixed path within the container.

```sh
...
-e CONFIG_FILES=/config/agent-config.json \
--mount type=bind,source=$CONFIG_FILES,target=/config/agent-config.json,readonly \
--mount type=bind,source="$(pwd)"/hyperlane_db_validator_<your_chain_name>,target=/hyperlane_db \
--mount type=bind,source="$(pwd)"/$VALIDATOR_SIGNATURES_DIR,target=/tmp/validator-signatures \
...
```

If you are using Docker, you will need to mount the file into the container.
Hardcoding these paths deduplucates the configuration, making it easier to pass the right arguments when running the container. See the example below, where that's left is for you to configure the chain name and validator key.

```sh
...
./validator \
--db /hyperlane_db \
--originChainName <your_chain_name> \
--checkpointSyncer.type localStorage \
--checkpointSyncer.path /tmp/validator-signatures \
--validator.key <your_validator_key>
...
```

</TabItem>
<TabItem value="from-source" label="Building from source">
****
</TabItem>
</Tabs>

### Run

<Tabs groupId="docker">
<TabItem value="docker" label="Using Docker">
Now that you understand more about configuring validator arguments, pull the latest docker image:

```sh
docker pull gcr.io/abacus-labs-dev/hyperlane-agent:main
```

Finally, run the container:

```sh
docker run \
-it \
-e CONFIG_FILES=/config/agent-config.json \
--mount type=bind,source=$CONFIG_FILES,target=/config/agent-config.json,readonly \
--mount type=bind,source="$(pwd)"/hyperlane_db_validator_<your_chain_name>,target=/hyperlane_db \
--mount type=bind,source="$(pwd)"/$VALIDATOR_SIGNATURES_DIR,target=/tmp/validator-signatures \
gcr.io/abacus-labs-dev/hyperlane-agent:main \
./validator \
--db /hyperlane_db \
--originChainName <your_chain_name> \
--checkpointSyncer.type localStorage \
--checkpointSyncer.path /tmp/validator-signatures \
--validator.key <your_validator_key>
```

</TabItem>

<TabItem value="from-source" label="Building from source">

```sh
cargo run --bin validator -- \
--db ./hyperlane_db_validator_<your_chain_name> \
--originChainName <your_chain_name> \
--checkpointSyncer.type localStorage \
--checkpointSyncer.path $VALIDATOR_SIGNATURES_DIR \
--validator.key <your_validator_key>
```

</TabItem>
</Tabs>

For further information, check out the [Validators guide](/docs/operate/validators/run-validators).

## 4. Run a relayer

Follow the [Relayer guide](/docs/operate/relayer/run-relayer) to run a relayer delivering interchain messages sent between the local and remote chains. You should have already set up your relayer keys in [step 1](#1-set-up-keys), so you can skip that part of the guide.
Relayers deliver interchain messages sent between the local and remote chains.

Remember to set the `--relayChains` argument or `HYP_RELAYCHAINS` environment variable appropriately.
You should already have set the `CONFIG_FILES` environment variable to the path of the agent config generated in the [deploy contracts](#2-deploy-contracts) step. If not, do so now.

Set the `CONFIG_FILES` environment variable to the path of the agent config generated in the [deploy contracts](#2-deploy-contracts) step. For example:
```bash
export CONFIG_FILES=/path/to/configs/agent-config-{timestamp}.json
export CONFIG_FILES=/full/path/to/configs/agent-config-{timestamp}.json
```

### Configure

There are numerous parameters that validators can be configured with. For this guide, we are concerned with just a handful:

| Parameter | Description |
| ------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ |
| `--db` | Path for writing persistent data to disk. |
| `--relayChains` | Comma separates names of the origin chain and destination chains to relay messages between. E.g. `ethereum,polygon,avalanche`. |
| `--allowLocalCheckpointSyncers` | Allows the relayer to look for validator signatures on the local filesystem. |
| `--defaultSigner.key` | A hexadecimal private key used to sign transactions for all chains. |

<Tabs groupId="docker">
<TabItem value="docker" label="Using Docker">

**Mounting directories**

For the relayer, we provide almost the same arguments to Docker as the validator:

1. Set the `$CONFIG_FILES` environment variable to a fixed path within the container.
1. Mount the agent config file to this fixed path and making it **readonly**.
1. Mount the persistent data directory at a fixed path within the container.
1. Mount the validator signatures directory to a fixed path within the container and making it **readonly**.

```sh
...
-e CONFIG_FILES=/config/agent-config.json \
--mount type=bind,source=$CONFIG_FILES,target=/config/agent-config.json,readonly \
--mount type=bind,source="$(pwd)"/hyperlane_db_relayer,target=/hyperlane_db \
--mount type=bind,source="$(pwd)"/$VALIDATOR_SIGNATURES_DIR,target=/tmp/validator-signatures,readonly \
...
```

Hardcoding these paths deduplucates the configuration, making it easier to pass the right arguments when running the container.

</TabItem>
<TabItem value="from-source" label="Building from source">
</TabItem>
</Tabs>

### Run

<Tabs groupId="docker">
<TabItem value="docker" label="Using Docker">
:::note

If you haven't already pulled the Docker image when setting up your validator, do this now by running:

```sh
docker pull gcr.io/abacus-labs-dev/hyperlane-agent:main
```

:::

Finally, run the relayer:

```sh
docker run \
-it \
-e CONFIG_FILES=/config/agent-config.json \
--mount type=bind,source=$CONFIG_FILES,target=/config/agent-config.json,readonly \
--mount type=bind,source="$(pwd)"/hyperlane_db_relayer,target=/hyperlane_db \
--mount type=bind,source="$(pwd)"/$VALIDATOR_SIGNATURES_DIR,target=/tmp/validator-signatures,readonly \
gcr.io/abacus-labs-dev/hyperlane-agent:main \
./relayer \
--db /hyperlane_db \
--relayChains <your_chain_name>,<remote_chain_name> \
--allowLocalCheckpointSyncers true \
--defaultSigner.key <your_validator_key>

```

If you are using Docker, you will need to mount the file into the container.
</TabItem>
<TabItem value="from-source" label="Building from source">

```sh
cargo run --bin relayer -- \
--db ./hyperlane_db_relayer \
--relayChains <your_chain_name>,<remote_chain_name> \
--allowLocalCheckpointSyncers true \
--defaultSigner.key <your_validator_key> \
--metrics-port 9091
```

</TabItem>
</Tabs>

For further information, check out the [Relayer guide](/docs/operate/relayer/run-relayer).

## 5. Send test messages

Expand Down

0 comments on commit 86cdb78

Please sign in to comment.