Simple Docker container to start your own IKEv2 VPN server using Let's Encrypt certificate with auto renewal
- Create empty folder on your server for passwords file (e.g. /secrets)
- Create text file in this folder aith any name (.) (e.g. /secrets/ipsec.secrets)
- Add following line for each VPN user:
username : EAP "password"
- Save and close the file.
- Copy file docker-compose.yml to any folder
- Edit docker-compose.yml:
- Line 15: change first /secrets to the created folder with passwords file. Do not change right side (/secrets:ro). (e.g.
- /foo/bar/secrets:/secrets:ro
) - Line 20: change vpn.example.com to your domain name (it should be already configured to point at your server's IP address).
- Line 21: change [email protected] to your mail for Let's Encrypt purposes.
- Line 15: change first /secrets to the created folder with passwords file. Do not change right side (/secrets:ro). (e.g.
- Save and close docker-compose.yml.
- Install Docker and Docker Compose if not installed.
- Check that ports 500, 4500, and 80 are opened.
- cd to the folder where docker-compose.yml is located.
- Start container using Docker Compose command up. It may depend on your Docker Compose installation. (e.g.
sudo docker compose up
,sudo docker-compose up
). - Check logs that Let's Encrypt certificate is successfully obtained. And there is no errors.
- Try to connect to your VPN.
- If everything is fine, press Ctrl+C to stop container.
- Start container in detached mode as backgroud service using flag
-d
:sudo docker compose up -d
- Now server is running on backgroud and automatically restarted.
Let's Encrypt certificates should be renewed every 90 days. Cron task checks for expiration every 12 hours as recommended by Let's Encrypt. Renewal logs should be in the file /last_cert_renew.log
-
VPN_NETWORK (required)
Network with a prefix for VPN clients.
-
ETH_DEVICE (required)
Network device name for iptables configuration.
-
VPN_DOMAIN (required)
Domain name for certificate obtaining.
-
EMAIL (not required)
Email for certificate registration. Will be used by "Let's encrypt" for expiration notifications.
-
VPN_DNS (not required)
DNS servers for VPN clients divided by comma. If not set then DNS servers will not be specified.
-
CERTBOT_PARAMS (not required)
Additional command line parameters for certbot (https://eff-certbot.readthedocs.io/en/stable/using.html)
-
CHARON_DEBUG_PARAMS (not required)
Debug log levels for charon (https://docs.strongswan.org/docs/latest/config/logging.html)
-
IKE_PROPOSALS (required)
IKE Cipher Suites list divided by comma. (https://docs.strongswan.org/docs/latest/config/proposals.html)
-
ESP_PROPOSALS (required)
ESP Cipher Suites list divided by comma. (https://docs.strongswan.org/docs/latest/config/proposals.html)