I've been experimenting with Kamal for deploying an Elixir application. The application was previously deployed on Fly.io and relies on the Erlang VM'

Elixir clustering on a Kamal+Hetzner deployment

submited by
Style Pass
2024-10-28 17:30:02

I've been experimenting with Kamal for deploying an Elixir application. The application was previously deployed on Fly.io and relies on the Erlang VM's clustering capabilities, so I had to get this working on the Hetzner deployment I'd spun up using Kamal.

It took me a bit of effort to get the clustering setup working, so here are my notes on what I did to get it working. It's also not a perfect setup at the moment, so if you have any suggestions do let me know!

I set up the Hetzner Cloud clustering strategy for libcluster using libcluster_hcloud. This uses the Hetzner API to find VMs to cluster with, filtered using label selectors so make sure you have the label you set in the config also set up on your VMs.

At this point, if you redeploy the app you should see in the logs that libcluster finds the VMs but isn't able to connect to them.

The problem is that libcluster tries to find :"my_app@10.0.1.1" but we haven't named our node as such. So let's do that. In rel/env.sh.eex I added:

Leave a Comment