The Blockscout VC Sidecar service monitors database changes in Supabase and automatically updates Docker container configurations and restarts services when necessary. This ensures that your Blockscout services are always running with the latest configuration. Intention is to make sure that changes made in Cloud Console are reflected in the running containers.
To configure the service, use a YAML file with the following structure:
supabaseRealtimeUrl: "wss://your-project.supabase.co/realtime/v1/websocket"
supabaseAnonKey: "your-anon-key"
pathToDockerCompose: "./config/docker-compose.yaml"
frontendServiceName: "frontend"
frontendContainerName: "frontend"
backendServiceName: "backend"
backendContainerName: "backend"
statsServiceName: "stats"
statsContainerName: "stats"
table: "silos"
chainId: 10
The service can be deployed using Docker Compose. Below is an example configuration:
services:
sidecar:
command:
- sh
- -c
- /app/app sidecar --config /app/config/local.yaml
container_name: sidecar
image: ghcr.io/aurora-is-near/blockscout-vc:latest
restart: unless-stopped
volumes:
- ./config:/app/config
- /var/run/docker.sock:/var/run/docker.sock
- ./docker-compose.yaml:/app/config/docker-compose.yaml
- Configuration files should be mounted in the
/app/config
directory
Start the service:
docker compose up -d
Restart the service:
docker compose up -d --force-recreate
Stop the service:
docker compose down
View logs:
docker logs -f blockscout-vc-sidecar
- Monitors Supabase database changes in real-time
- Automatically updates Docker Compose environment variables
- Restarts affected services when configuration changes
- Handles multiple service updates efficiently
- Prevents duplicate container restarts
- Validates configuration changes before applying
- Go 1.21 or later
- Docker
- Docker Compose
- Clone the repository:
git clone https://github.com/blockscout/blockscout-vc-sidecar.git
- Build the binary:
go build -o blockscout-vc-sidecar
- Run with configuration:
./blockscout-vc-sidecar --config config/local.yaml
blockscout-vc/
├── cmd/
│ └── root.go
│ └── sidecar.go
├── internal/
│ ├── client/ # WebSocket client implementation
│ ├── config/ # Configuration handling
│ ├── docker/ # Docker operations
│ ├── handlers/ # Event handlers
│ ├── heartbeat/ # Heartbeat logic
│ └── subscription/ # Supabase subscription logic
│ └── worker/ # Worker implementation
├── config/
│ └── local.yaml # Configuration file
└── main.go
Parameter | Description | Required |
---|---|---|
supabaseRealtimeUrl |
Supabase Realtime WebSocket URL | Yes |
supabaseAnonKey |
Supabase Anonymous Key | Yes |
pathToDockerCompose |
Path to the Docker Compose file | Yes |
frontendServiceName |
Name of the frontend service | Yes |
frontendContainerName |
Name of the frontend container | Yes |
backendServiceName |
Name of the backend service | Yes |
backendContainerName |
Name of the backend container | Yes |
statsServiceName |
Name of the stats service | Yes |
statsContainerName |
Name of the stats container | Yes |
table |
Name of the table to listen to | Yes |
chainId |
Chain ID to listen to | Yes |
Enable debug logging by setting the environment variable:
export LOG_LEVEL=debug
Releases are managed via GitHub with canonical versioning (e.g., 0.1.2
). Ensure the versioning follows semantic versioning guidelines.
To release a new version:
- Create a release on GitHub, specifying the appropriate tag (following semantic versioning guidelines).
- This will trigger the build and push workflows to create a new Docker image and store it in the GitHub registry.