|
1 | 1 | #!/usr/bin/env bash
|
2 | 2 |
|
| 3 | +SWARM_VERSION="${SWARM_VERSION:-}" |
| 4 | +FAST_BUILD="${FAST_BUILD:-}" |
3 | 5 |
|
| 6 | +## fix coverity issue |
4 | 7 | sudo apt-get install -y -q ca-certificates
|
5 |
| - |
6 |
| -export HOST_PORT=2375 |
7 | 8 | echo -n | openssl s_client -connect scan.coverity.com:443 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' | sudo tee -a /etc/ssl/certs/ca-certificates.crt
|
| 9 | +## |
8 | 10 |
|
9 |
| - |
10 |
| -if [ "$FAST_BUILD" == true ]; then |
| 11 | +if [ "$FAST_BUILD" == "true" ]; then |
11 | 12 | echo "Fast build, skipping docker installations."
|
12 | 13 | exit 0
|
13 | 14 | fi
|
14 | 15 |
|
15 | 16 | set -exu
|
16 | 17 |
|
| 18 | +sudo ip a ls |
| 19 | +sudo ip r ls |
| 20 | +sudo ss -antpl |
| 21 | + |
| 22 | +export HOST_PORT="2375" |
| 23 | +export SWARM_PORT="2377" |
| 24 | +export HOST_IP="$(ip a show dev eth0 | grep "inet\b" | awk '{print $2}' | cut -d/ -f1)" |
| 25 | +# because of swarm use docker-engine directly |
| 26 | +export PRE_DOCKER_HOST="$DOCKER_HOST" |
| 27 | +export DOCKER_HOST="tcp://127.0.0.1:${HOST_PORT}" |
| 28 | + |
| 29 | + |
17 | 30 | docker info
|
18 | 31 | docker version
|
19 | 32 |
|
@@ -89,3 +102,69 @@ registry.email=${registry_email}
|
89 | 102 | registry.url=https://index.docker.io/v1/
|
90 | 103 |
|
91 | 104 | EOF
|
| 105 | + |
| 106 | +if [[ -n $SWARM_VERSION ]]; then |
| 107 | +# export SWARM_PORT="${PRE_DOCKER_HOST##*:}" |
| 108 | + |
| 109 | + docker pull swarm |
| 110 | + |
| 111 | +# # kv store https://docs.docker.com/v1.11/engine/userguide/networking/get-started-overlay/ |
| 112 | +# docker run -d \ |
| 113 | +# -p "8500:8500" \ |
| 114 | +# -h "consul" \ |
| 115 | +# --name=consul \ |
| 116 | +# progrium/consul -server -bootstrap |
| 117 | +# |
| 118 | +# sleep 5 |
| 119 | + |
| 120 | +# SWARM_TOKEN=$(docker run swarm c) |
| 121 | + |
| 122 | +# docker run \ |
| 123 | +# -d \ |
| 124 | +# --name=swarm_manager \ |
| 125 | +# -p ${SWARM_PORT}:2375 \ |
| 126 | +# "swarm:${SWARM_VERSION}" \ |
| 127 | +# manage token://${SWARM_TOKEN} |
| 128 | + |
| 129 | + docker run \ |
| 130 | + -d \ |
| 131 | + -p ${SWARM_PORT}:2375 \ |
| 132 | + --name=swarm_manager \ |
| 133 | + swarm manage --engine-refresh-min-interval "3s" --engine-refresh-max-interval "6s" "nodes://${HOST_IP}:${HOST_PORT}" |
| 134 | +# swarm manage --engine-refresh-min-interval "3s" --engine-refresh-max-interval "6s" "consul://${HOST_IP}:8500" |
| 135 | + |
| 136 | + # join engine to swarm |
| 137 | + docker run \ |
| 138 | + -d \ |
| 139 | + "--name=swarm_join" \ |
| 140 | + "swarm:${SWARM_VERSION}" \ |
| 141 | + join --advertise="${HOST_IP}:${HOST_PORT}" --delay="0s" --heartbeat "5s" "nodes://${HOST_IP}:${HOST_PORT}" |
| 142 | +# join --advertise="${HOST_IP}:${HOST_PORT}" --delay="0s" --heartbeat "5s" "token://${SWARM_TOKEN}" |
| 143 | + |
| 144 | + docker run --rm \ |
| 145 | + "swarm:${SWARM_VERSION}" list "nodes://${HOST_IP}:${HOST_PORT}" |
| 146 | + |
| 147 | + docker ps -a |
| 148 | + sudo ss -antpl |
| 149 | + |
| 150 | + sleep 30 |
| 151 | + |
| 152 | + docker logs swarm_join |
| 153 | + docker logs swarm_manager |
| 154 | +# docker logs consul |
| 155 | + |
| 156 | + # switch to swarm connection |
| 157 | + DOCKER_HOST="$PRE_DOCKER_HOST" |
| 158 | + |
| 159 | + docker version |
| 160 | + docker info |
| 161 | + |
| 162 | + NODES=$(docker info | grep "Nodes:" | awk '{ print $2 }') |
| 163 | + if [[ $NODES -eq "0" ]]; then |
| 164 | + echo "Swarm didn't connect" |
| 165 | + exit 1 |
| 166 | + fi |
| 167 | + |
| 168 | + # test via swarm |
| 169 | + docker pull busybox |
| 170 | +fi |
0 commit comments