-
Notifications
You must be signed in to change notification settings - Fork 4
/
create-swarm.sh
executable file
·61 lines (54 loc) · 2.63 KB
/
create-swarm.sh
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
#!/bin/bash
source ./box.sh
source ./variables.sh
box "Setting security network groups" "red" "blue"
#### Set up Security Group in AWS
aws ec2 create-security-group --group-name ${sg_name} --description "A Security Group for Docker Networking"
# Permit SSH, required for Docker Machine
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 22 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 2376 --cidr ${my_ip}/${mask}
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 2377 --cidr ${my_ip}/${mask}
#aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 5000 --cidr ${my_ip}/${mask}
# Permit Serf ports for discovery
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 7946 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol udp --port 7946 --cidr 0.0.0.0/0
# Permit VXLAN
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 4789 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol udp --port 4789 --cidr 0.0.0.0/0
# Allow service access
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 80 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 8080 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 5001 --cidr 0.0.0.0/0
aws ec2 authorize-security-group-ingress --group-name ${sg_name} --protocol tcp --port 5000 --cidr 0.0.0.0/0
box "Starting Docker Machine creation" "green" "blue"
for node in $(seq 1 $leaders);
do
box "Node leader $node" "light_purple" "red"
docker-machine create \
--driver amazonec2 \
--amazonec2-region ${region} \
--amazonec2-security-group ${sg_name} \
leader$node &
done
wait
ip=$(docker-machine ssh leader1 ifconfig eth0 | grep "inet addr" | cut -d ':' -f 2 | cut -d ' ' -f 1)
for node in $(seq 1 $workers);
do
box "Node worker $node" "light_purple" "red"
docker-machine create \
--driver amazonec2 \
--amazonec2-region ${region} \
--amazonec2-security-group ${sg_name} \
worker$node &
done
wait
eval "$(docker-machine env leader1)"
box "Init Swarm cluster" "light_purple" "blue"
docker swarm init --listen-addr $ip --advertise-addr $ip
workertok=$(docker swarm join-token -q worker)
for node in $(seq 1 $workers);
do
eval "$(docker-machine env worker$node)"
docker swarm join --token $workertok $ip:2377
done
eval $(docker-machine env leader1)