π³ Docker Compose β
This tutorial is going to show you how to deploy the wordle chain using Docker Compose.
You can learn more about Docker Compose here.
TIP
This tutorial explores Rollkit, currently in Alpha. If you encounter bugs, please report them via a GitHub issue ticket or reach out in our Telegram group.
π» Pre-requisites β
Make sure you have your wordle chain ready by completing the Build your chain tutorial.
π οΈ Dependencies β
π» Docker Compose β
You can install docker compose here.
Once installed, you can verify the installation by running:
docker compose version
Docker Compose version v2.23.0-desktop.1
π οΈ Setting up your environment β
In addition to our chain, we need to run a DA and Sequencer node.
We will use the local-da and local-sequencer for this tutorial and run it with our chain.
To save time, we can use their respective Dockerfiles:
This will allow us to focus on how we can run the wordle chain with Docker Compose.
π³ Dockerfile β
First, we need to create a Dockerfile for our wordle chain. Create a new file called Dockerfile
in the root of the wordle
directory and add the following code:
# Stage 1: Install ignite CLI and rollkit
FROM golang as base
# Install dependencies
RUN apt update && \
apt-get install -y \
build-essential \
ca-certificates \
curl
# Install rollkit
RUN curl -sSL https://rollkit.dev/install.sh | sh -s v0.14.1
# Install ignite
RUN curl https://get.ignite.com/[email protected]! | bash
# Set the working directory
WORKDIR /app
# cache dependencies.
COPY ./go.mod .
COPY ./go.sum .
RUN go mod download
# Copy all files from the current directory to the container
COPY . .
# Remove the rollkit.toml and entrypoint files if they exist. This is to avoid cross OS issues.
RUN rm entrypoint rollkit.toml
# Build the chain
RUN ignite chain build && ignite rollkit init
# Initialize the rollkit.toml file
RUN rollkit toml init
# Run rollkit command to initialize the entrypoint executable
RUN rollkit
# Stage 2: Set up the runtime environment
FROM debian:bookworm-slim
# Install jq
RUN apt update && \
apt-get install -y \
jq
# Set the working directory
WORKDIR /root
# Copy over the rollkit binary from the build stage
COPY --from=base /go/bin/rollkit /usr/bin
# Copy the entrypoint and rollkit.toml files from the build stage
COPY --from=base /app/entrypoint ./entrypoint
COPY --from=base /app/rollkit.toml ./rollkit.toml
# Copy the $HOME/.wordle directory from the build stage.
# This directory contains all your chain config.
COPY --from=base /root/.wordle /root/.wordle
# Ensure the entrypoint script is executable
RUN chmod +x ./entrypoint
# Keep the container running after it has been started
# CMD tail -f /dev/null
ENTRYPOINT [ "rollkit" ]
CMD [ "start", "--rollkit.aggregator", "--rollkit.sequencer_rollup_id", "wordle"]
This Dockerfile sets up the environment to build the chain and run the wordle node. It then sets up the runtime environment to run the chain. This allows you as the developer to modify any files, and then simply rebuild the Docker image to run the new chain.
Build the docker image by running the following command:
docker build -t wordle .
You can then see the built image by running:
docker images
You should see the following output:
REPOSITORY TAG IMAGE ID CREATED SIZE
wordle latest 5d3533c1ea1c 8 seconds ago 443MB
π³ Docker Compose file β
Next we need to create our compose.yaml
file for docker compose to use.
In the root of the wordle
directory, create a new file called compose.yaml
and add the following code:
services:
# Define the wordle chain service
wordle:
# Set the name of the docker container for ease of use
container_name: wordle
# Use the image we just built
image: wordle
# Used for networking between the two services
network_mode: host
# The command config is used for launching the chain once the Docker container is running
command:
[
"start",
"--rollkit.aggregator",
"--rollkit.da_address",
"http://0.0.0.0:7980",
"--rollkit.sequencer_address",
"0.0.0.0:50051",
"--rollkit.sequencer_rollup_id",
"wordle",
]
# Ensures the local-da service is up and running before starting the chain
depends_on:
- local-da
- local-sequencer
# Define the local DA service
local-da:
# Use the published image from rollkit
image:
ghcr.io/rollkit/local-da:v0.3.1
# Set the name of the docker container for ease of use
container_name: local-da
# Publish the ports to connect
ports:
- "7980:7980"
# Define the local sequencer service
local-sequencer:
# Use the published image from rollkit
image:
ghcr.io/rollkit/go-sequencing:v0.4.1
# Set the name of the docker container for ease of use
container_name: local-sequencer
# Start the sequencer with the listen all flag and the rollup id set to wordle
command: ["-listen-all", "-rollup-id=wordle"]
# Publish the ports to connect
ports:
- "50051:50051"
We now have all we need to run the wordle chain and connect to a local DA node.
π Run Wordle chain β
Run your wordle chain by running the following command:
docker compose up
You'll see logs of your chain being output.
Congratulations! You have successfully run the wordle chain with Docker Compose.
π Interacting with the chain β
Since we are using docker images, we can interact with the chain by entering the docker container.
You can see the docker containers running with the wordle chain and the local DA node by running the following command:
docker ps
You should see output like the following:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
86f9bfa5b6d2 wordle "rollkit start --rolβ¦" 7 minutes ago Up 3 seconds wordle
67a2c3058e01 local-sequencer "local-sequencer -liβ¦" 11 minutes ago Up 3 seconds 0.0.0.0:50051->50051/tcp local-sequencer
dae3359665f8 local-da "local-da -listen-all" 2 hours ago Up 3 seconds 0.0.0.0:7980->7980/tcp local-da
We can see the wordle chain running in container wordle
and the local DA network running in container local-da
.
Since our chain is running in a docker container, we want to enter the docker container to interact with it via the Rollkit CLI. We can do this by running:
docker exec -it wordle sh
Now that you are in the docker container, you can interact with the chain using the Rollkit CLI and the example commands you used in the Wordle tutorial.
Once you are done interacting with your chain, you can exit out of your docker container with:
exit
Then you can shut down your chain environment by running CRTL+C
in your terminal.
π Next steps β
Congratulations again! You now know how to run your chain with docker compose and interact with it using the Rollkit CLI in the docker container.