Docker sandbox
Introduction
Dockerfile
FROM => a base image to use while building image
ADD => copy from local to container
RUN => execute commands to generate the image, this does not run when container starts
CMD ["/usr/bin/nmap", "-s", "172.17.0.0/24"] => default command to run at container startup, if not specified, container starts and stops immediately
Docker cli
docker build . -t myawesomeimage:v1
docker run myawesomeimage:v1
pull imagemyawesomeimage:v1
, and run containerdocker run -d nginx
run a container in backgrounddocker run -it ubuntu:latest /bin/bash
open an interactive shell within the containerctrl-p, ctrl-q
does not kill the container started withit
flagdocker inspect container_name
json output of all properties of the containerdocker inspect <container id> --format='{{.NetworkSettings.IPAddress}}'
filter json output from inspect command to get a specific propertydocker --help
docker start
start a stopped containerdocker ps -a
show all containers, running, stopped, faileddocker rmi
delete/untag imagesdocker rm
remove containers
bash is PID 1 in linux
Networking
each container needs an IP!
docker networking is created via drivers
![[docker-nw.png]]
Drivers
Docker bridge is really a bridge that you should visualize as a physical device like like a network switch. This bridge is connected to the actual physical network. Uses NAT. Plug this in to the network switch, we have the virtual Ethernet interfaces veth
. veth
connects to container network interface.
overlay
software defined n/w, used in docker swarm
bridge
default
Usually docker uses 172.17.0.0/16
, which falls within the private IP range.
~ docker network ls
NETWORK ID NAME DRIVER SCOPE
af439a7244c6 bridge bridge local
4b054ec242a6 host host local
076b498369ab none null local
~ docker network inspect af439a7244c6 --format='{{json .IPAM.Config}}'
[{"Subnet":"172.17.0.0/16","Gateway":"172.17.0.1"}]
nmap
- scan a network, https://github.com/instrumentisto/nmap-docker-image, https://nmap.org/
nmap
can also be used to inspect the docker network, and available containers.
~ docker run --rm -it instrumentisto/nmap -sn 172.17.0.0/24
Starting Nmap 7.94 ( https://nmap.org ) at 2023-12-09 20:08 UTC
Nmap scan report for 172.17.0.1
Host is up (0.000058s latency).
MAC Address: 02:42:59:2C:33:19 (Unknown)
Nmap scan report for 172.17.0.2
Host is up (0.000018s latency).
MAC Address: 02:42:AC:11:00:02 (Unknown)
Nmap scan report for 172.17.0.3
Host is up (0.000046s latency).
MAC Address: 02:42:AC:11:00:03 (Unknown)
Nmap scan report for f1b89c1009ab (172.17.0.4)
Host is up.
Nmap done: 256 IP addresses (4 hosts up) scanned in 2.08 second
host
mcvlan
assign a mac address to a container
none
no networking defined!
Ports
Publish ports by using the -p
flag with docker run
Each container gets an IP from the network it is attached to.
issue, publishing ports as -p 8080:8080
opens them to the world, prefer to use -p 127.0.0.1:8080:8080
Hosts within the same L2 segment (for example, hosts connected to the same network switch) can reach ports published to localhost. For more information, see moby/moby#45610
DNS
Container’s hostname defaults to it’s ID in docker, but can be overridden with --hostname
.
Containers inherit the DNS settings of the host.
Containers in custom network, use docker embedded DNS server, and forward external DNS queries to DNS as defined on host.
Containers DON’T inherit entries defined in /etc/hosts
, use --add-host
flag in docker run
to specify container specific host entries.
DNS servers can be specified on per container basis using the --dns, --dns-search, --dns-opt
flags with docker run
Storage
bind-mount mechanism
Podman
Alternative to docker
Sync time
podman machine ssh 'sudo hwclock -s'
podman machine ssh 'sudo systemctl restart chronyd.service'
https://github.com/containers/podman/issues/11541