-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
81 lines (76 loc) · 1.6 KB
/
docker-compose.yml
File metadata and controls
81 lines (76 loc) · 1.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# MeshGuard — 3-node mesh simulation (userspace WG mode)
#
# Usage:
# zig build -Doptimize=ReleaseSafe
# docker compose up --build
# docker compose exec node-b ping -c3 <node-a-mesh-ip>
# docker compose down
services:
node-a:
build: .
container_name: mg-node-a
hostname: node-a
cap_add:
- NET_ADMIN
devices:
- /dev/net/tun:/dev/net/tun
sysctls:
- net.ipv4.ip_forward=1
volumes:
- shared-keys:/shared/keys
networks:
mesh:
ipv4_address: 172.31.0.10
environment:
- MESHGUARD_CONFIG_DIR=/etc/meshguard
- SEED_DELAY=1
node-b:
build: .
container_name: mg-node-b
hostname: node-b
cap_add:
- NET_ADMIN
devices:
- /dev/net/tun:/dev/net/tun
sysctls:
- net.ipv4.ip_forward=1
volumes:
- shared-keys:/shared/keys
depends_on:
- node-a
networks:
mesh:
ipv4_address: 172.31.0.11
environment:
- MESHGUARD_CONFIG_DIR=/etc/meshguard
- SEED_PEERS=172.31.0.10:51821
- SEED_DELAY=3
node-c:
build: .
container_name: mg-node-c
hostname: node-c
cap_add:
- NET_ADMIN
devices:
- /dev/net/tun:/dev/net/tun
sysctls:
- net.ipv4.ip_forward=1
volumes:
- shared-keys:/shared/keys
depends_on:
- node-a
networks:
mesh:
ipv4_address: 172.31.0.12
environment:
- MESHGUARD_CONFIG_DIR=/etc/meshguard
- SEED_PEERS=172.31.0.10:51821
- SEED_DELAY=4
volumes:
shared-keys:
networks:
mesh:
driver: bridge
ipam:
config:
- subnet: 172.31.0.0/24