-
Notifications
You must be signed in to change notification settings - Fork 4
How to Docker
Answer
docker-machine create --driver virtualbox Char
Explanation
docker-machine create | Docker Documentation:
Create a machine. Requires the
--driver
flag to indicate which provider (VirtualBox, DigitalOcean, AWS, etc.) the machine should be created on, and an argument to indicate the name of the created machine.
Here is an example of using the
--virtualbox
driver to create a machine called dev.$ docker-machine create --driver virtualbox dev
How to check result?
docker-machine ls
Explanation
docker-machine
:
ls
— List machines.
Answer
docker-machine ip Char
Explanation
docker-machine ip | Docker Documentation:
Get the IP address of one or more machines.
$ docker-machine ip dev 192.168.99.104 $ docker-machine ip dev dev2 192.168.99.104 192.168.99.105
03. Define the variables needed by your virtual machine Char
in the general env of your terminal, so that you can run the docker ps
command without errors. You have to fix all four environment variables with one command, and you are not allowed to use your shell’s builtin to set these variables by hand.
Answer
eval $(docker-machine env Char)
Explanation
docker-machine env Char
command output:
export DOCKER_TLS_VERIFY="1" export DOCKER_HOST="tcp://192.168.99.100:2376" export DOCKER_CERT_PATH="/Users/vbrazhni/.docker/machine/machines/Char" export DOCKER_MACHINE_NAME="Char" # Run this command to configure your shell: # eval $(docker-machine env Char)
How to check result?
docker-machine ls
command output:
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS Char * virtualbox Running tcp://192.168.99.100:2376 v18.05.0-ce
Now the ACTIVE
column of Char
has *
instead of -
.
Answer
docker pull hello-world
Explanation
Docker Hub is the place where open Docker images are stored. When we ran our first image by typing
docker run --rm -p 8787:8787 rocker/verse
the software first checked if this image is available on your computer and since it wasn’t it downloaded the image from Docker Hub. So getting an image from Docker Hub works sort of automatically. If you just want to pull the image but not run it, you can also do
docker pull rocker/verse
How to check result?
docker image ls
Explanation
docker image
:
ls
— List images.
05. Launch the hello-world
container, and make sure that it prints its welcome message, then leaves it.
Answer
docker run hello-world
06. Launch an nginx
container, available on Docker Hub, as a background task. It should be named overlord
, be able to restart on its own, and have its 80 port attached to the 5000 port of Char
. You can check that your container functions properly by visiting http://<ip-de-char>:5000
on your web browser.
Answer
docker run -d -p 5000:80 --name overlord --restart=always nginx
Explanation
docker run --help
:
-d
,--detach
— Run container in background and print container ID.
--name string
— Assign a name to the container.
-p
,--publish list
— Publish a container's port(s) to the host.
-p
is a ports mapping<HOST PORT>:<CONTAINER PORT>
.
docker run | Docker Documentation:
Use Docker’s
--restart
to specify a container’s restart policy. A restart policy controls whether the Docker daemon restarts a container after exit. Docker supports the following restart policies:
Policy Result no
Do not automatically restart the container when it exits. This is the default. on-failure[:max-retries]
Restart only if the container exits with a non-zero exit status. Optionally, limit the number of restart retries the Docker daemon attempts. unless-stopped
Restart the container unless it is explicitly stopped or Docker itself is stopped or restarted. always
Always restart the container regardless of the exit status. When you specify always, the Docker daemon will try to restart the container indefinitely. The container will also always start on daemon startup, regardless of the current state of the container.
07. Get the internal IP address of the overlord container without starting its shell and in one command.
Answer
docker inspect -f '{{.NetworkSettings.IPAddress}}' overlord
Explanation
How to retrieve Docker container's internal IP address:
It is also possible to trip the default docker inspect docker command's output to get the IP address value only:
# docker inspect -f '{{ .NetworkSettings.IPAddress }}' e350390fd549 172.17.0.2
docker inspect --help
:
-f
,--format string
— Format the output using the given Go template.
08. Launch a shell from an alpine
container, and make sure that you can interact directly with the container via your terminal, and that the container deletes itself once the shell’s execution is done.
docker run -it --rm alpine /bin/sh
Explanation
docker run --help
:
-i
,--interactive
— Keep STDIN open even if not attached.
-t
,--tty
— Allocate a pseudo-TTY.
--rm
— Automatically remove the container when it exits.
Starting a Shell in the Docker Alpine Container:
Usually, an Alpine Linux image doesn't contain
bash
, Instead you can use/bin/ash
,/bin/sh
,ash
or onlysh
.
9. From the shell of a debian container, install via the container’s package manager everything you need to compile C source code and push it onto a git repo (of course, make sure before that the package manager and the packages already in the container are updated). For this exercise, you should only specify the commands to be run directly in the container.
Answer
apt-get update
apt-get upgrade -y
apt-get install -y build-essential git
Explanation
Start Debian container:
docker run -ti --rm debian
build-essential contains a list of packages which are essential for building Ubuntu packages including gcc compiler, make and other required tools.
Download for Linux and Unix | Git:
For the latest stable version for your release of Debian/Ubuntu
# apt-get install git
Answer
docker volume create --name hatchery
Explanation
docker volume create | Docker Documentation:
--name
— Specify volume name.
How to check result?
docker volume ls
Explanation
docker volume
:
ls
— List volumes.
Answer
docker volume ls
Explanation
docker volume
:
ls
— List volumes.
12. Launch a mysql
container as a background task. It should be able to restart on its own in case of error, and the root password of the database should be Kerrigan
. You will also make sure that the database is stored in the hatchery
volume, that the container directly creates a database named zerglings
, and that the container itself is named spawning-pool
.
Answer
docker run -d --name spawning-pool --restart=on-failure:10 -e MYSQL_ROOT_PASSWORD=Kerrigan -e MYSQL_DATABASE=zerglings -v hatchery:/var/lib/mysql mysql --default-authentication-plugin=mysql_native_password
Explanation
docker run --help
:
-e
,--env list
— Set environment variables.
Docker MySQL Persistence (Tech Tip #83):
/var/lib/mysql
is the default directory where MySQL container writes its files.
MYSQL_ROOT_PASSWORD
This variable is mandatory and specifies the password that will be set for the MySQL root superuser account.
MYSQL_DATABASE
This variable is optional and allows you to specify the name of a database to be created on image startup. If a user/password was supplied (see below) then that user will be granted superuser access (corresponding to GRANT ALL) to this database.
Wordpress latest does not works with mysql latest container:
MySQL 8 changed the password authentication method. You're looking for the mysql_native_password plugin https://dev.mysql.com/doc/refman/8.0/en/native-pluggable-authentication.html
Or you could use mysql 5.7
Alternative answer
docker run -d --name spawning-pool --restart=on-failure:10 -e MYSQL_ROOT_PASSWORD=Kerrigan -e MYSQL_DATABASE=zerglings -v hatchery:/var/lib/mysql mysql:5.7
If you want to try alternative answer (after checking main answer) you need to recreate volume hatchery
. In another way you can get errors.
13. Print the environment variables of the spawning-pool
container in one command, to be sure that you have configured your container properly.
Answer
docker inspect -f '{{.Config.Env}}' spawning-pool
14. Launch a wordpress
container as a background task, just for fun. The container should be named lair
, its 80 port should be bound to the 8080 port of the virtual machine, and it should be able to use the spawning-pool
container as a database service. You can try to access lair
on your machine via a web browser, with the IP address of the virtual machine as a URL. Congratulations, you just deployed a functional Wordpress website in two commands!
Answer
docker run -d --name lair -p 8080:80 --link spawning-pool:mysql wordpress
Explanation
Legacy container links | Docker Documentation:
Links allow containers to discover each other and securely transfer information about one container to another container. When you set up a link, you create a conduit between a source container and a recipient container. The recipient can then access select data about the source. To create a link, you use the
--link
flag.
15. Launch a phpmyadmin
container as a background task. It should be named roach-warden
, its 80 port should be bound to the 8081 port of the virtual machine and it should be able to explore the database stored in the spawning-pool
container.
Answer
docker run --name roach-warden -d --link spawning-pool:db -p 8081:80 phpmyadmin/phpmyadmin
Explanation
Docker Tutorial : PhpMyAdmin and MySQL Server:
Phpmyadmin must point to MySQL Server. So that we must link both containers by adding the option :
--link name-of-container:name-of-imag
.$ docker run --name myadmin -d --link mysql:db -p 8080:80 phpmyadmin/phpmyadmin
Answer
docker logs -f spawning-pool
Explanation
How do I view real time logging of Docker containers?:
To view the logs of a Docker container in real time, use the following command:
docker logs -f <CONTAINER>
The
-f
or--follow
option will show live log output.
Answer
docker ps
Answer
docker restart overlord
Explanation
docker
:
restart
— Restart one or more containers.
19. Launch a container name Abathur
. It will be a Python
container, 2-slim version, its /root folder will be bound to a HOME folder on your host, and its 3000 port will be bound to the 3000 port of your virtual machine. You will personalize this container so that you can use the Flask
micro-framework in its latest version. You will make sure that an html page displaying "Hello World" with <h1>
tags can be served by Flask
. You will test that your container is properly set up by accessing, via curl or a web browser, the IP address of your virtual machine on the 3000 port. You will also list all the necessary commands in your repository.
Answer
docker run --name Abathur -v ~/:/root -p 3000:3000 -dit python:2-slim
docker exec Abathur pip install Flask
echo 'from flask import Flask\napp = Flask(__name__)\[email protected]("/")\ndef hello_world():\n\treturn "<h1>Hello, World!</h1>"' > ~/app.py
docker exec -e FLASK_APP=/root/app.py Abathur flask run --host=0.0.0.0 --port 3000
Explanation
docker exec | Docker Documentation:
The
docker exec
command runs a new command in a running container.
--env
,-e
— Set environment variables.
Quickstart — Flask 1.0.2 documentation:
A minimal Flask application looks something like this:
from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello, World!'
To run the application you can either use the flask command or python’s
-m
switch with Flask. Before you can do that you need to tell your terminal the application to work with by exporting theFLASK_APP
environment variable:$ export FLASK_APP=hello.py $ flask run * Running on http://127.0.0.1:5000/
How to check result?
curl $(docker-machine ip Char):3000
Explanation
man curl
:
curl
is a tool to transfer data from or to a server, using one of the supported protocols (DICT, FILE, FTP, FTPS, GOPHER, HTTP, HTTPS, IMAP, IMAPS, LDAP, LDAPS, POP3, POP3S, RTMP, RTSP, SCP, SFTP, SMB, SMBS, SMTP, SMTPS, TELNET and TFTP). The command is designed to work without user interaction.
Answer
docker swarm init --advertise-addr $(docker-machine ip Char)
Explanation
Create a swarm | Docker Documentation:
Run the following command to create a new swarm:
docker swarm init --advertise-addr <MANAGER-IP>
21. Create another virtual machine with docker-machine
using the virtualbox
driver, and name it Aiur
.
Answer
docker-machine create --driver virtualbox Aiur
22. Turn Aiur
into a slave of the local swarm in which Char
is leader (the command to take control of Aiur
is not requested).
Answer
docker-machine ssh Aiur "docker swarm join --token $(docker swarm join-token worker -q) $(docker-machine ip Char):2377"
Explanation
docker-machine ssh | Docker Documentation:
Log into or run a command on a machine using SSH.
To login, just run
docker-machine ssh machinename
.
Join nodes to a swarm | Docker Documentation:
To retrieve the join command including the join token for worker nodes, run the following command on a manager node:
$ docker swarm join-token worker To add a worker to this swarm, run the following command: docker swarm join \ --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx14ie39trti4wxv-8vxv8rssmk743ojnwacrr2e7c \ 192.168.99.100:2377
Run the command from the output on the worker to join the swarm:
$ docker swarm join \ --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx14ie39trti4wxv-8vxv8rssmk743ojnwacrr2e7c \ 192.168.99.100:2377 This node joined a swarm as a worker.
docker swarm join-token | Docker Documentation:
--quiet
,-q
— Only display token.
Answer
docker network create -d overlay overmind
Explanation
-d
,--driver string
— Driver to manage the Network (default "bridge").
How to check answer?
docker network ls
Explanation
docker network
:
ls
— List networks.
24. Launch a rabbitmq
SERVICE that will be named orbital-command
. You should define a specific user and password for the RabbitMQ service, they can be whatever you want. This service will be on the overmind
network.
Answer
docker service create -d --network overmind --name orbital-command -e RABBITMQ_DEFAULT_USER=root -e RABBITMQ_DEFAULT_PASS=root rabbitmq
Explanation
library/rabbitmq | Docker Hub:
If you wish to change the default username and password of
guest
/guest
, you can do so with theRABBITMQ_DEFAULT_USER
andRABBITMQ_DEFAULT_PASS
environmental variables:$ docker run -d --hostname my-rabbit --name some-rabbit -e RABBITMQ_DEFAULT_USER=user -e RABBITMQ_DEFAULT_PASS=password rabbitmq:3-management
docker service create --help
:
-d
,--detach
— Exit immediately instead of waiting for the service to converge (default true).
If I didn't use -d
flag, I get the following output:
Since --detach=false was not specified, tasks will be created in the background. In a future release, --detach=false will become the default.
Answer
docker service ls
Explanation
docker service
:
ls
— List services.
26. Launch a 42school/engineering-bay
service in two replicas and make sure that the service works properly (see the documentation provided at hub.docker.com). This service will be named engineering-bay
and will be on the overmind
network.
Answer
docker service create -d --network overmind --name engineering-bay --replicas 2 -e OC_USERNAME=root -e OC_PASSWD=root 42school/engineering-bay
Explanation
You must have an
orbital-command
running on your host or swarm, accessible with the same name into your network.To connect to this
orbital-command
, you must set a
OC_USERNAME
: Username used to access toorbital-command
OC_PASSWD
: Password used to access toorbital-command
Answer
docker service logs -f $(docker service ps engineering-bay -f "name=engineering-bay.1" -q)
Explanation
docker service ps | Docker Documentation:
The name filter matches on task names.
$ docker service ps -f "name=redis.1" redis
28. ... Damn it, a group of zergs is attacking orbital-command
, and shutting down the engineering-bay
service won’t help at all... You must send a troup of Marines to eliminate the intruders. Launch a 42school/marine-squad
in two replicas, and make sure that the service works properly (see the documentation provided at hub.docker.com). This service will be named... marines
and will be on the overmind
network.
Answer
docker service create -d --network overmind --name marines --replicas 2 -e OC_USERNAME=root -e OC_PASSWD=root 42school/marine-squad
Explanation
You must have an
orbital-command
running on your host or swarm, accessible with the same name into your network.To connect to this
orbital-command
, you must set a
OC_USERNAME
: Username used to access toorbital-command
OC_PASSWD
: Password used to access toorbital-command
Answer
docker service ps marines
Explanation
docker service
:
ps
— List the tasks of one or more services.
30. Increase the number of copies of the marines
service up to twenty, because there’s never enough Marines to eliminate Zergs. (Remember to take a look at the tasks and logs of the service, you’ll see, it’s fun.)
Answer
docker service scale -d marines=20
Explanation
docker service
:
scale
— Scale one or multiple replicated services.
docker service scale | Docker Documentation:
docker service scale SERVICE=REPLICAS [SERVICE=REPLICAS...]
--detach
,-d
— Exit immediately instead of waiting for the service to converge.
How to check logs?
docker service logs -f $(docker service ps marines -f "name=marines.11" -q)
Answer
docker service rm $(docker service ls -q)
Explanation
docker service
:
rm
— Remove one or more services.
Answer
docker rm -f $(docker ps -a -q)
Explanation
docker
:
rm
— Remove one or more containers.
docker rm --help
:
-f
,--force
— Force the removal of a running container (uses SIGKILL).
Answer
docker rmi $(docker images -a -q)
Explanation
docker
:
rmi
— Remove one or more images.
Answer
docker-machine rm -y Aiur
Explanation
docker-machine
:
rm
— Remove a machine.
docker-machine rm --help
:
-y
— Assumes automatic yes to proceed with remove, without prompting further user confirmation.