A port is a communication endpoint. If the URL is the address or a building, the port is a particular door.
Only one application can use a port at a time.
Syntax: URL:PORT
For example: 127.0.0.1:8000
Here 127.0.0.1 is the URL and 8000 is the port.
By default a docker container does not publish any ports to the host machine. So the services running inside the container will not be accessible from the host machine. So we need to expose the ports to the host machine.
- docker run:
We use the-p
flag followed by thehostport:containerport
format while running the container.
Example:docker run <CONTAINER_NAME> -p 8000:8080 bash
- docker-compose:
We specify the port under theports
key in the docker-compose.yaml fileports: - "8000:8080"
By default all files created inside a container are stored on a writable container layer. The data doesn’t persist when that container no longer exists, meaning the data inside the container gets deleted if the container stops.
- docker run:
We use the-v
flag followed by the<PATH IN THE HOST MACHINE>:<PATH INSIDE THE CONTAINER>
format while running the container.
Example:docker run -it -v /home/workshop/Downloads:/home/usr/Downloads alpine sh
- docker-compose:
We specify the volume under thevolumes
key in the docker-compose.yaml fileNamed volumes are created and managed by docker. For instance, if we want our data in a MySQL container to be persistent. We need define a named volume in the top-level volumes key.volumes: - "/home/workshop/Downloads:/home/usr/Downloads"
version: "3.7" services: db: image: mysql:8.0 restart: always container_name: database environment: MYSQL_SERVER: db MYSQL_DATABASE: mydb MYSQL_ROOT_PASSWORD: root MYSQL_PASSWORD: 1234 ports: - '3306:3306' volumes: - my-db:/var/lib/mysql volumes: my-db
- Bridge: (Isolation) This is the default network type. This allows the containers on the same bridge network to communicate. Containers within the network can talk to each other. Demo:
Start two alpine containers like:
docker run -dit --name alpine1 alpine ash
docker run -dit --name alpine2 alpine ash
Show all the bridge networks like:
docker network inspect bridge
Now you can exec into one of the alpine containers and ping the other one based on its IP.
- Host: (With Host)
Here the container’s network stack is not isolated from the host, meaning the host network can be accessible from the container. We use the
--network=host
parameter while running the docker container to use host network.
- None: (No network access)
The containers created using the
--network=none
. Here the container will not have any network access whatsoever.
By default, a container has no resource constraints and can use as much of a given resource as the host’s kernel scheduler allows. This will be a problem because one container may use a lot of system resources and starve other processes and containers.
Docker allows us to control the amount of CPU and memory a container will use.
-
docker run:
We use the
-m
flag followed by a positive integer suffixed byb
,k
,m
,g
for byte, kilobyte, megabyte and gigabyte respectively.
Example:docker run -it -m=100m <CONTAINER NAME> sh
We use the
--cpus=<value>
where the value is CPU value. For instance if the host machine has 2 CPUs we can set the value as 1.5 so that container only uses 1.5 CPU.
Example:docker run -it -cpus='1.5' <CONTAINER NAME> sh
-
docker-compose:
We specify the CPU and memory limits under thedeploy
key like so:version: "3.7" services: service-name: image: alpine deploy: resources: limits: cpus: '0.50' memory: 50M