A Shinyapp running with a Flask service backend and a Postrgesql database, all launched by Dockerfile's.
Ejecutar desde la máquina local:
export MACHINE_DRIVER=amazonec2
export AWS_ACCESS_KEY_ID=
export AWS_SECRET_ACCESS_KEY=
export AWS_DEFAULT_REGION=us-west-2
for N in $(seq 1 2); do
docker-machine create awsn$N
docker-machine ssh awsn$N sudo usermod -aG docker ubuntu
done
Dado que éste no es un caso de Producción oficial, por practicidad ejecutamos la siguiente instrucción:
aws ec2 authorize-security-group-ingress --group-name docker-machine --protocol -1 --cidr 0.0.0.0/0
IMPORTANTE: ¡Situarse en el nodo que será Líder!
docker-machine ssh awsn1
git clone https://github.com/adfmb/sfp_app.git
Cambiar el _env por .env
sudo curl -L \
https://github.com/docker/compose/releases/download/1.10.0/docker-compose-$(uname -s)-$(uname -m) \
-o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker swarm init
El output debe ser algo parecido a lo siguiente:
docker swarm join \
--token <poner-token> \
<poner-ip>
Lo anterior lo copiaremos y pegaremos en los demás nodos (uno en nuestro caso) que formarán parte del clúster.
Ahora en otra ventana desde la máquina local, nos conectamos a la otra máquina:
docker-machine ssh awsn2
En la máquina 2 (con su respectivo token e ip):
docker swarm join \
--token <poner-token> \
<poner-ip>
Ahora de regreso en la máquina Líder:
docker node ls
docker service create --name dpa-registry --publish 5000:5000 registry:2
docker-compose build api
docker tag sfpapp_api localhost:5000/sfpapp_api:v0.1
docker push localhost:5000/sfpapp_api
docker-compose build backend
docker tag sfpapp_backend localhost:5000/sfpapp_backend:v0.1
docker push localhost:5000/sfpapp_backend
docker-compose build bd
docker tag sfpapp_bd localhost:5000/sfpapp_bd:v0.1
docker push localhost:5000/sfpapp_bd
curl localhost:5000/v2/_catalog
docker network create --driver overlay dpap1
docker network ls
docker stack deploy -c swarm-docker-compose.yml dpap1