From ea6924456bda5670106760ffbbcbec6367d4903d Mon Sep 17 00:00:00 2001 From: Marcel Ribeiro-Dantas Date: Tue, 12 Jul 2022 23:32:17 +0200 Subject: Fix document category for Docker Docker is a tool, not a language. --- docker.html.markdown | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index 1dad267a..1df49cc3 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -1,5 +1,6 @@ --- -language: docker +category: tool +tool: docker filename: docker.bat contributors: - ["Ruslan López", "http://javapro.org/"] -- cgit v1.2.3 From 5a9b474a635a1b0b12908f8673b6f4e1e67d0812 Mon Sep 17 00:00:00 2001 From: Akshita Dixit <436_bt19@iiitkalyani.ac.in> Date: Sun, 13 Nov 2022 14:24:24 +0530 Subject: [Docs]: Docker documentation revamp --- docker.html.markdown | 259 ++++++++++++++++++++++++--------------------------- 1 file changed, 120 insertions(+), 139 deletions(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index 1df49cc3..d65947fe 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -5,144 +5,125 @@ filename: docker.bat contributors: - ["Ruslan López", "http://javapro.org/"] - ["Michael Chen", "https://github.com/ML-Chen"] + - ["Akshita Dixit", "https://github.com/akshitadixit"] --- -```bat -:: download, install and run hello-world image -docker run hello-world - -:: if this is the first time you should be able to see the message -:: Unable to find image 'hello-world:latest' locally -:: latest: Pulling from library/hello-world -:: 1b930d010525: Pull complete -:: Digest: sha256:4fe721ccc2e8dc7362278a29dc660d833570ec2682f4e4194f4ee23e415e1064 -:: Status: Downloaded newer image for hello-world:latest -:: -:: Hello from Docker! -:: This message shows that your installation appears to be working correctly. -:: -:: To generate this message, Docker took the following steps: -:: 1. The Docker client contacted the Docker daemon. -:: 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. -:: (amd64) -:: 3. The Docker daemon created a new container from that image which runs the -:: executable that produces the output you are currently reading. -:: 4. The Docker daemon streamed that output to the Docker client, which sent it -:: to your terminal. -:: -:: To try something more ambitious, you can run an Ubuntu container with: -:: $ docker run -it ubuntu bash -:: -:: Share images, automate workflows, and more with a free Docker ID: -:: https://hub.docker.com/ -:: -:: For more examples and ideas, visit: -:: https://docs.docker.com/get-started/ - -:: now let's see currently running images -docker ps -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES - -:: let's see the images we have ran previously -docker ps -a - -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES -:: 4a76281f9c53 hello-world "/hello" 2 minutes ago Exited (0) 2 minutes ago -:: happy_poincare -:: the name part is generated automatically so it probably will be different for you - -:: let's remove our previously generated image -docker rm happy_poincare - -:: let's test if it was really deleted -docker ps -a -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES - -:: specify a custom name for the container -docker run --name test_container hello-world -:: Hello from Docker! -:: This message shows that your installation appears to be working correctly. -:: -:: To generate this message, Docker took the following steps: -:: 1. The Docker client contacted the Docker daemon. -:: 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. -:: (amd64) -:: 3. The Docker daemon created a new container from that image which runs the -:: executable that produces the output you are currently reading. -:: 4. The Docker daemon streamed that output to the Docker client, which sent it -:: to your terminal. -:: -:: To try something more ambitious, you can run an Ubuntu container with: -:: $ docker run -it ubuntu bash -:: -:: Share images, automate workflows, and more with a free Docker ID: -:: https://hub.docker.com/ -:: -:: For more examples and ideas, visit: -:: https://docs.docker.com/get-started/ - -docker ps -a -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES -:: d345fe1a4f41 hello-world "/hello" About a minute ago Exited (0) About a minute ago -:: test_container -:: as you can see the name is now what we have specified - -:: retrieve logs from a named container -docker logs test_container -:: Hello from Docker! -:: This message shows that your installation appears to be working correctly. -:: -:: To generate this message, Docker took the following steps: -:: 1. The Docker client contacted the Docker daemon. -:: 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. -:: (amd64) -:: 3. The Docker daemon created a new container from that image which runs the -:: executable that produces the output you are currently reading. -:: 4. The Docker daemon streamed that output to the Docker client, which sent it -:: to your terminal. -:: -:: To try something more ambitious, you can run an Ubuntu container with: -:: $ docker run -it ubuntu bash -:: -:: Share images, automate workflows, and more with a free Docker ID: -:: https://hub.docker.com/ -:: -:: For more examples and ideas, visit: -:: https://docs.docker.com/get-started/ - -docker rm test_container - -docker run ubuntu -:: Unable to find image 'ubuntu:latest' locally -:: latest: Pulling from library/ubuntu -:: 2746a4a261c9: Pull complete -:: 4c1d20cdee96: Pull complete 0d3160e1d0de: Pull complete c8e37668deea: Pull complete Digest: sha256:250cc6f3f3ffc5cdaa9d8f4946ac79821aafb4d3afc93928f0de9336eba21aa4 -:: Status: Downloaded newer image for ubuntu:latest - -docker ps -a -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES -:: c19e9e5b000a ubuntu "/bin/bash" 5 seconds ago Exited (0) 4 seconds ago -:: relaxed_nobel - -:: running a container in an interactive mode -docker run -it ubuntu -:: root@e2cac48323d2:/# uname -:: Linux -:: root@e2cac48323d2:/# exit -:: exit - -docker rm relaxed_nobel - -docker ps -a -:: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS -:: NAMES -:: e2cac48323d2 ubuntu "/bin/bash" 2 minutes ago Exited (0) About a minute ago -:: nifty_goldwasser - -docker rm nifty_goldwasser -``` +Docker is a tool that helps you build, test, ship and run applications seamlessly across various machines. It replicates the environment our software needs on any machine. You can get Docker for your machine from https://docs.docker.com/get-docker/ + +It has grown in popularity over the last decade due to being lightweight and fast as compared to virtual-machines that are bulky and slow. Unlike VMs, docker does not need a full blown OS of its own to be loaded to start and does not compete for resources other than what the application it is running will use. VMs on the other hand are pretty resource intensive on our processors, disks and memory hence running multiple VMs for various applications becomes a challenge in a limited capacity architecture. +
+┌────────────────────────┐ ┌───────────────────────┐                ┌────────────────────────┐ ┌───────────────────────┐
+│      ┌───────────┐     │ │      ┌───────────┐    │                │      ┌───────────┐     │ │      ┌───────────┐    │
+│      │   App     │     │ │      │   App     │    │                │      │   App     │     │ │      │   App     │    │
+│      └───────────┘     │ │      └───────────┘    │                │      └───────────┘     │ │      └───────────┘    │
+│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │                │  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
+│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │                │  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
+│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │                │  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
+│  ┌───────────────────┐ │ │  ┌──────────────────┐ │                │        Container1      │ │       Container2      │
+│  │         OS        │ │ │  │         OS       │ │                └────────────────────────┘ └───────────────────────┘
+│  └───────────────────┘ │ │  └──────────────────┘ │                ┌──────────────────────────────────────────────────┐
+│           VM1          │ │           VM2         │                │                       Docker                     │
+└────────────────────────┘ └───────────────────────┘                └──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐                ┌──────────────────────────────────────────────────┐
+│                     Hypervisor                   │                │                        OS                        │
+└──────────────────────────────────────────────────┘                └──────────────────────────────────────────────────┘
+┌───────────────────────────────────────────────────┐               ┌──────────────────────────────────────────────────┐
+│             Hardware Infrastructure               │               │             Hardware Infrastructure              │
+└───────────────────────────────────────────────────┘               └──────────────────────────────────────────────────┘
+            (VM based architecture)                                                 (Docker based architecture)
+
+ +Couple of terms we will encounter frequently are Docker Images and Docker Containers. Images are packages or templates of containers all stored in the [Docker Hub](https://hub.docker.com/). Containers are standalone, executable instances of these images which include code, runtime, system tools, system libraries and settings - everything required to get the software up and running. Coming to Docker, it follows a client-server architecture wherein the CLI client communicates with the server component, which here is, the Docker Engine using RESTful API to issue commands. + +## The Docker CLI +```bash +# after installing Docker from https://docs.docker.com/get-docker/ +# To list available commands, either run `docker` with no parameters or execute `docker help` +$docker + +>>> docker [OPTIONS] COMMAND [ARG...] + docker [ --help | -v | --version ] + + A self-sufficient runtime for containers. + + Options: + --config string Location of client config files (default "/root/.docker") + -c, --context string Name of the context to use to connect to the daemon (overrides DOCKER_HOST env var and default context set with "docker context use") + -D, --debug Enable debug mode + --help Print usage + -H, --host value Daemon socket(s) to connect to (default []) + -l, --log-level string Set the logging level ("debug"|"info"|"warn"|"error"|"fatal") (default "info") + --tls Use TLS; implied by --tlsverify + --tlscacert string Trust certs signed only by this CA (default "/root/.docker/ca.pem") + --tlscert string Path to TLS certificate file (default "/root/.docker/cert.pem") + --tlskey string Path to TLS key file (default "/root/.docker/key.pem") + --tlsverify Use TLS and verify the remote + -v, --version Print version information and quit + + Commands: + attach Attach to a running container + # […] + +$docker run hello-world +# `docker run ` is used to run a container, it will pull the images from Docker Hub if they don't alrady exist on your system +# Here the docker client connects to the daemon which in turn pulls the "hello-world" image from the Docker Hub. The daemon then creates a +# new container from the image which runs the executable that produces the output streamed back to the client that we see on our terminals. + +$docker run -d ubuntu sleep 60s +# The -d (or --detach) flag is when we want to run a container in the background and return back to the terminal. +# Here we detach an ubuntu container from the terminal, the output should be the id and the command exits. If we check running containers, +# we should still see ours there: +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 133261b4894a ubuntu "sleep 60s" 3 seconds ago Up 2 seconds vigorous_gould + +$docker run -p 3000:8000 +# The -p (or --publish) flag is used to expose port 8000 inside the container to port 3000 outside the container +# This is because the app inside the container runs in isolation, hence the port 8000 where the app runs is private to the container. + +$docker run -i or $docker run -it +# Docker runs our containers in a non-interactive mode i.e. they do not accept inputs or work dynamically while running. +# The -i flag keeps input open to the container, and the -t flag creates a pseudo-terminal that the shell can attach to (can be combined as -it) + +$docker ps -a +# The `docker ps` command only shows running containers by default. To see all containers, use the -a (or --all) flag +# Running the above command should output something similar in the terminal: +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 82f84bf6912b hello-world "/hello" 9 minutes ago Exited (0) 9 minutes ago eloquent_sammet + + +$docker start hello-world or $docker stop hello-world +# The stop command simply stops one or more containers, the start command starts the conatainer(s) up again! +# `docker start -a ubuntu` will attach our detached container back to the terminal i.e. runs in the foreground + +$docker create alpine +# `docker create` creates a new container for us with the image specified (here, alpine), the container does not auto-start unlike `docker run` +# This command is used to set up a container configuration and then `docker start` to shoot it up when required. Note that the status is "Created": +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 4c71c727c73d alpine "/bin/sh" 29 seconds ago Created naughty_ritchie + +$docker rm 82f84 +# Removes one or more containers using their container ID. +# P.S.: we can use only the first few characters of the entire ID to identify containers + +$docker images +# Displays all images and their information, created here means the latest image tag updated on Docker Hub: +# REPOSITORY TAG IMAGE ID CREATED SIZE +# ubuntu latest a8780b506fa4 9 days ago 77.8MB +# alpine latest 9c6f07244728 3 months ago 5.54MB +# hello-world latest feb5d9fea6a5 13 months ago 13.3kB + +$docker rmi +# Removes one or more images from your system which do not have their instances (or containers as we know them) running. +# If the image has an attached container, either delete the container first or use the -f (or --force) flag to forcefully delete both the container and image. + +$docker pull busybox +# The pull command downloads the specified image on our system from Docker Hub. + +$docker exec -it 7b272 bash +# This command is used to run a command in the running container's default directory +# Here 7b272 was our ubuntu container and the above command would help us interact with the container by opening a bash session + +$docker compose + +# More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ +``` \ No newline at end of file -- cgit v1.2.3 From 7b10b3e9a6f177ccaa99b926fe15bd821a94e18e Mon Sep 17 00:00:00 2001 From: Marcel Ribeiro Dantas Date: Sun, 13 Nov 2022 12:45:49 -0300 Subject: Keep lines under 80 chars whenever possible --- docker.html.markdown | 147 +++++++++++++++++++++++++++++++++++---------------- 1 file changed, 102 insertions(+), 45 deletions(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index d65947fe..d64c9b1c 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -6,39 +6,79 @@ contributors: - ["Ruslan López", "http://javapro.org/"] - ["Michael Chen", "https://github.com/ML-Chen"] - ["Akshita Dixit", "https://github.com/akshitadixit"] + - ["Marcel Ribeiro-Dantas", "https://github.com/mribeirodantas"] --- -Docker is a tool that helps you build, test, ship and run applications seamlessly across various machines. It replicates the environment our software needs on any machine. You can get Docker for your machine from https://docs.docker.com/get-docker/ +Docker is a tool that helps you build, test, ship and run applications +seamlessly across various machines. It replicates the environment our software +needs on any machine. You can get Docker for your machine from +https://docs.docker.com/get-docker/ + +It has grown in popularity over the last decade due to being lightweight and +fast as compared to virtual-machines that are bulky and slow. Unlike VMs, docker +does not need a full blown OS of its own to be loaded to start and does not +compete for resources other than what the application it is running will use. +VMs on the other hand are pretty resource intensive on our processors, disks and +memory hence running multiple VMs for various applications becomes a challenge +in a limited capacity architecture. -It has grown in popularity over the last decade due to being lightweight and fast as compared to virtual-machines that are bulky and slow. Unlike VMs, docker does not need a full blown OS of its own to be loaded to start and does not compete for resources other than what the application it is running will use. VMs on the other hand are pretty resource intensive on our processors, disks and memory hence running multiple VMs for various applications becomes a challenge in a limited capacity architecture.
-┌────────────────────────┐ ┌───────────────────────┐                ┌────────────────────────┐ ┌───────────────────────┐
-│      ┌───────────┐     │ │      ┌───────────┐    │                │      ┌───────────┐     │ │      ┌───────────┐    │
-│      │   App     │     │ │      │   App     │    │                │      │   App     │     │ │      │   App     │    │
-│      └───────────┘     │ │      └───────────┘    │                │      └───────────┘     │ │      └───────────┘    │
-│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │                │  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
-│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │                │  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
-│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │                │  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
-│  ┌───────────────────┐ │ │  ┌──────────────────┐ │                │        Container1      │ │       Container2      │
-│  │         OS        │ │ │  │         OS       │ │                └────────────────────────┘ └───────────────────────┘
-│  └───────────────────┘ │ │  └──────────────────┘ │                ┌──────────────────────────────────────────────────┐
-│           VM1          │ │           VM2         │                │                       Docker                     │
-└────────────────────────┘ └───────────────────────┘                └──────────────────────────────────────────────────┘
-┌──────────────────────────────────────────────────┐                ┌──────────────────────────────────────────────────┐
-│                     Hypervisor                   │                │                        OS                        │
-└──────────────────────────────────────────────────┘                └──────────────────────────────────────────────────┘
-┌───────────────────────────────────────────────────┐               ┌──────────────────────────────────────────────────┐
-│             Hardware Infrastructure               │               │             Hardware Infrastructure              │
-└───────────────────────────────────────────────────┘               └──────────────────────────────────────────────────┘
-            (VM based architecture)                                                 (Docker based architecture)
+┌────────────────────────┐ ┌───────────────────────┐
+│      ┌───────────┐     │ │      ┌───────────┐    │
+│      │   App     │     │ │      │   App     │    │
+│      └───────────┘     │ │      └───────────┘    │
+│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
+│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
+│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
+│  ┌───────────────────┐ │ │  ┌──────────────────┐ │
+│  │         OS        │ │ │  │         OS       │ │
+│  └───────────────────┘ │ │  └──────────────────┘ │
+│           VM1          │ │           VM2         │
+└────────────────────────┘ └───────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                     Hypervisor                   │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│             Hardware Infrastructure              │
+└──────────────────────────────────────────────────┘
+              (VM based architecture)
+
+┌────────────────────────┐ ┌───────────────────────┐
+│      ┌───────────┐     │ │      ┌───────────┐    │
+│      │   App     │     │ │      │   App     │    │
+│      └───────────┘     │ │      └───────────┘    │
+│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
+│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
+│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
+│        Container1      │ │       Container2      │
+└────────────────────────┘ └───────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                       Docker                     │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                        OS                        │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│             Hardware Infrastructure              │
+└──────────────────────────────────────────────────┘
+            (Docker based architecture)
+
 
-Couple of terms we will encounter frequently are Docker Images and Docker Containers. Images are packages or templates of containers all stored in the [Docker Hub](https://hub.docker.com/). Containers are standalone, executable instances of these images which include code, runtime, system tools, system libraries and settings - everything required to get the software up and running. Coming to Docker, it follows a client-server architecture wherein the CLI client communicates with the server component, which here is, the Docker Engine using RESTful API to issue commands. +Couple of terms we will encounter frequently are Docker Images and Docker +Containers. Images are packages or templates of containers all stored in the +[Docker Hub](https://hub.docker.com/). Containers are standalone, executable +instances of these images which include code, runtime, system tools, system +libraries and settings - everything required to get the software up and running. +Coming to Docker, it follows a client-server architecture wherein the CLI client +communicates with the server component, which here is, the Docker Engine using +RESTful API to issue commands. ## The Docker CLI ```bash # after installing Docker from https://docs.docker.com/get-docker/ -# To list available commands, either run `docker` with no parameters or execute `docker help` +# To list available commands, either run `docker` with no parameters or execute +# `docker help` $docker >>> docker [OPTIONS] COMMAND [ARG...] @@ -65,65 +105,82 @@ $docker # […] $docker run hello-world -# `docker run ` is used to run a container, it will pull the images from Docker Hub if they don't alrady exist on your system -# Here the docker client connects to the daemon which in turn pulls the "hello-world" image from the Docker Hub. The daemon then creates a -# new container from the image which runs the executable that produces the output streamed back to the client that we see on our terminals. +# `docker run ` is used to run a container, it will pull the +# images from Docker Hub if they don't alrady exist on your system. Here the +# docker client connects to the daemon which in turn pulls the "hello-world" +# image from the Docker Hub. The daemon then creates a new container from the +# image which runs the executable that produces the output streamed back to the +# client that we see on our terminals. $docker run -d ubuntu sleep 60s -# The -d (or --detach) flag is when we want to run a container in the background and return back to the terminal. -# Here we detach an ubuntu container from the terminal, the output should be the id and the command exits. If we check running containers, -# we should still see ours there: +# The -d (or --detach) flag is when we want to run a container in the background +# and return back to the terminal. Here we detach an ubuntu container from the +# terminal, the output should be the id and the command exits. If we check +# running containers, we should still see ours there: # CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES # 133261b4894a ubuntu "sleep 60s" 3 seconds ago Up 2 seconds vigorous_gould $docker run -p 3000:8000 -# The -p (or --publish) flag is used to expose port 8000 inside the container to port 3000 outside the container -# This is because the app inside the container runs in isolation, hence the port 8000 where the app runs is private to the container. +# The -p (or --publish) flag is used to expose port 8000 inside the container to +# port 3000 outside the container. This is because the app inside the container +# runs in isolation, hence the port 8000 where the app runs is private to the +# container. $docker run -i or $docker run -it -# Docker runs our containers in a non-interactive mode i.e. they do not accept inputs or work dynamically while running. -# The -i flag keeps input open to the container, and the -t flag creates a pseudo-terminal that the shell can attach to (can be combined as -it) +# Docker runs our containers in a non-interactive mode i.e. they do not accept +# inputs or work dynamically while running. The -i flag keeps input open to the +# container, and the -t flag creates a pseudo-terminal that the shell can attach +# to (can be combined as -it) $docker ps -a -# The `docker ps` command only shows running containers by default. To see all containers, use the -a (or --all) flag +# The `docker ps` command only shows running containers by default. To see all +# containers, use the -a (or --all) flag # Running the above command should output something similar in the terminal: # CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES # 82f84bf6912b hello-world "/hello" 9 minutes ago Exited (0) 9 minutes ago eloquent_sammet $docker start hello-world or $docker stop hello-world -# The stop command simply stops one or more containers, the start command starts the conatainer(s) up again! -# `docker start -a ubuntu` will attach our detached container back to the terminal i.e. runs in the foreground +# The stop command simply stops one or more containers, the start command starts +# the conatainer(s) up again! `docker start -a ubuntu` will attach our detached +# container back to the terminal i.e. runs in the foreground $docker create alpine -# `docker create` creates a new container for us with the image specified (here, alpine), the container does not auto-start unlike `docker run` -# This command is used to set up a container configuration and then `docker start` to shoot it up when required. Note that the status is "Created": +# `docker create` creates a new container for us with the image specified (here, +# alpine), the container does not auto-start unlike `docker run`. This command +# is used to set up a container configuration and then `docker start` to shoot +# it up when required. Note that the status is "Created": # CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES # 4c71c727c73d alpine "/bin/sh" 29 seconds ago Created naughty_ritchie $docker rm 82f84 # Removes one or more containers using their container ID. -# P.S.: we can use only the first few characters of the entire ID to identify containers +# P.S.: we can use only the first few characters of the entire ID to identify +# containers $docker images -# Displays all images and their information, created here means the latest image tag updated on Docker Hub: +# Displays all images and their information, created here means the latest image +# tag updated on Docker Hub: # REPOSITORY TAG IMAGE ID CREATED SIZE # ubuntu latest a8780b506fa4 9 days ago 77.8MB # alpine latest 9c6f07244728 3 months ago 5.54MB # hello-world latest feb5d9fea6a5 13 months ago 13.3kB $docker rmi -# Removes one or more images from your system which do not have their instances (or containers as we know them) running. -# If the image has an attached container, either delete the container first or use the -f (or --force) flag to forcefully delete both the container and image. +# Removes one or more images from your system which do not have their instances +# (or containers as we know them) running. If the image has an attached +# container, either delete the container first or use the -f (or --force) flag +# to forcefully delete both the container and image. $docker pull busybox # The pull command downloads the specified image on our system from Docker Hub. $docker exec -it 7b272 bash -# This command is used to run a command in the running container's default directory -# Here 7b272 was our ubuntu container and the above command would help us interact with the container by opening a bash session +# This command is used to run a command in the running container's default +# directory. Here 7b272 was our ubuntu container and the above command would +# help us interact with the container by opening a bash session $docker compose # More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ -``` \ No newline at end of file +``` -- cgit v1.2.3 From f0577fb679c63be3c47d7429361002dd1331aff5 Mon Sep 17 00:00:00 2001 From: Marcel Ribeiro Dantas Date: Sun, 13 Nov 2022 12:47:37 -0300 Subject: Add host/guest OS info on VM-based architecture diagram --- docker.html.markdown | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index d64c9b1c..ca81cc45 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -31,7 +31,7 @@ in a limited capacity architecture. │ │ Libs │ │ Deps │ │ │ │ Libs │ │ Deps │ │ │ └────────┘ └────────┘ │ │ └────────┘ └───────┘ │ │ ┌───────────────────┐ │ │ ┌──────────────────┐ │ -│ │ OS │ │ │ │ OS │ │ +│ │ Guest OS │ │ │ │ Guest OS │ │ │ └───────────────────┘ │ │ └──────────────────┘ │ │ VM1 │ │ VM2 │ └────────────────────────┘ └───────────────────────┘ @@ -39,6 +39,9 @@ in a limited capacity architecture. │ Hypervisor │ └──────────────────────────────────────────────────┘ ┌──────────────────────────────────────────────────┐ +│ Host OS │ +└──────────────────────────────────────────────────┘ +┌──────────────────────────────────────────────────┐ │ Hardware Infrastructure │ └──────────────────────────────────────────────────┘ (VM based architecture) -- cgit v1.2.3 From 5630c3e05ac3d445b663ca1d1188d0b93b21fb35 Mon Sep 17 00:00:00 2001 From: Marcel Ribeiro Dantas Date: Sun, 13 Nov 2022 12:59:50 -0300 Subject: Improve wording/typos --- docker.html.markdown | 58 ++++++++++++++++++++++++++++------------------------ 1 file changed, 31 insertions(+), 27 deletions(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index ca81cc45..f69dbddb 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -69,20 +69,20 @@ in a limited capacity architecture. Couple of terms we will encounter frequently are Docker Images and Docker -Containers. Images are packages or templates of containers all stored in the -[Docker Hub](https://hub.docker.com/). Containers are standalone, executable -instances of these images which include code, runtime, system tools, system -libraries and settings - everything required to get the software up and running. -Coming to Docker, it follows a client-server architecture wherein the CLI client -communicates with the server component, which here is, the Docker Engine using -RESTful API to issue commands. +Containers. Images are packages or templates of containers all stored in a +container registry such as [Docker Hub](https://hub.docker.com/). Containers +are standalone, executable instances of these images which include code, +runtime, system tools, system libraries and settings - everything required to +get the software up and running. Coming to Docker, it follows a client-server +architecture wherein the CLI client communicates with the server component, +which here is, the Docker Engine using RESTful API to issue commands. ## The Docker CLI ```bash # after installing Docker from https://docs.docker.com/get-docker/ # To list available commands, either run `docker` with no parameters or execute # `docker help` -$docker +$ docker >>> docker [OPTIONS] COMMAND [ARG...] docker [ --help | -v | --version ] @@ -107,15 +107,15 @@ $docker attach Attach to a running container # […] -$docker run hello-world +$ docker run hello-world # `docker run ` is used to run a container, it will pull the -# images from Docker Hub if they don't alrady exist on your system. Here the +# images from Docker Hub if they don't already exist in your system. Here the # docker client connects to the daemon which in turn pulls the "hello-world" -# image from the Docker Hub. The daemon then creates a new container from the +# image from the Docker Hub. The daemon then builds a new container from the # image which runs the executable that produces the output streamed back to the # client that we see on our terminals. -$docker run -d ubuntu sleep 60s +$ docker run -d ubuntu sleep 60s # The -d (or --detach) flag is when we want to run a container in the background # and return back to the terminal. Here we detach an ubuntu container from the # terminal, the output should be the id and the command exits. If we check @@ -123,19 +123,21 @@ $docker run -d ubuntu sleep 60s # CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES # 133261b4894a ubuntu "sleep 60s" 3 seconds ago Up 2 seconds vigorous_gould -$docker run -p 3000:8000 +$ docker run -p 3000:8000 # The -p (or --publish) flag is used to expose port 8000 inside the container to # port 3000 outside the container. This is because the app inside the container # runs in isolation, hence the port 8000 where the app runs is private to the # container. -$docker run -i or $docker run -it +$ docker run -i +# or +$ docker run -it # Docker runs our containers in a non-interactive mode i.e. they do not accept # inputs or work dynamically while running. The -i flag keeps input open to the # container, and the -t flag creates a pseudo-terminal that the shell can attach # to (can be combined as -it) -$docker ps -a +$ docker ps -a # The `docker ps` command only shows running containers by default. To see all # containers, use the -a (or --all) flag # Running the above command should output something similar in the terminal: @@ -143,12 +145,14 @@ $docker ps -a # 82f84bf6912b hello-world "/hello" 9 minutes ago Exited (0) 9 minutes ago eloquent_sammet -$docker start hello-world or $docker stop hello-world -# The stop command simply stops one or more containers, the start command starts -# the conatainer(s) up again! `docker start -a ubuntu` will attach our detached -# container back to the terminal i.e. runs in the foreground +$ docker stop hello-world +# or +$ docker start hello-world +# The stop command simply stops one or more containers, and the start command +# starts the container(s) up again! `docker start -a ubuntu` will attach our +# detached container back to the terminal i.e. runs in the foreground -$docker create alpine +$ docker create alpine # `docker create` creates a new container for us with the image specified (here, # alpine), the container does not auto-start unlike `docker run`. This command # is used to set up a container configuration and then `docker start` to shoot @@ -156,12 +160,12 @@ $docker create alpine # CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES # 4c71c727c73d alpine "/bin/sh" 29 seconds ago Created naughty_ritchie -$docker rm 82f84 +$ docker rm 82f84 # Removes one or more containers using their container ID. # P.S.: we can use only the first few characters of the entire ID to identify # containers -$docker images +$ docker images # Displays all images and their information, created here means the latest image # tag updated on Docker Hub: # REPOSITORY TAG IMAGE ID CREATED SIZE @@ -169,21 +173,21 @@ $docker images # alpine latest 9c6f07244728 3 months ago 5.54MB # hello-world latest feb5d9fea6a5 13 months ago 13.3kB -$docker rmi +$ docker rmi # Removes one or more images from your system which do not have their instances # (or containers as we know them) running. If the image has an attached # container, either delete the container first or use the -f (or --force) flag # to forcefully delete both the container and image. -$docker pull busybox +$ docker pull busybox # The pull command downloads the specified image on our system from Docker Hub. -$docker exec -it 7b272 bash +$ docker exec -it 7b272 bash # This command is used to run a command in the running container's default # directory. Here 7b272 was our ubuntu container and the above command would -# help us interact with the container by opening a bash session +# help us interact with the container by opening a bash session. -$docker compose +$ docker compose # More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ ``` -- cgit v1.2.3 From aae233d7fc62a226dac89ef0a1669c3d269c8134 Mon Sep 17 00:00:00 2001 From: Akshita Dixit <436_bt19@iiitkalyani.ac.in> Date: Sun, 27 Nov 2022 14:29:54 +0530 Subject: Add requested changes --- docker.html.markdown | 74 +++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 73 insertions(+), 1 deletion(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index d65947fe..b1a20a72 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -123,7 +123,79 @@ $docker exec -it 7b272 bash # This command is used to run a command in the running container's default directory # Here 7b272 was our ubuntu container and the above command would help us interact with the container by opening a bash session -$docker compose +$docker logs +# Displays the information logged by the specified container +# root@7b27222e4bb7:/# whoami +# root +# root@7b27222e4bb7:/# pwd +# / +# root@7b27222e4bb7:/# ls +# bin boot dev etc home lib lib32 lib64 libx32 media mnt opt proc root run sbin srv sys tmp usr var +# root@7b27222e4bb7:/# exit +# exit # More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ +``` +## The Dockerfile +The Dockerfile is a blueprint of a Docker image. We can mention the artifacts from our application along with their configurations into this file in the specific syntax to let anyone create a Docker image of our application. + +### A few things to keep in mind: +* It is always strictly named `Dockerfile` without any extensions +* We have to build our custom image on top of some already available Docker base image. (there is an empty image called `scratch` which literally lets you build an image from scratch) +* All capitalised commands are part of the syntax, they are not case-sensitive but used like a convention +* Below is a sample Dockerfile but you can read in depth from the [official docs](https://docs.docker.com/engine/reference/builder/). + +```Dockerfile +FROM +# define base image + +ENV USERNAME='admin'\ + PWD='****' +# optionally define environmental variables + +RUN apt-get update +# run linux commands inside container env, does not affect host env +# This executes during the time of image creation + +COPY +# executes on the host, copies files from src (usually on the host) to target on the container + +ENTRYPOINT ["some-script.sh"] +# executes an entire script as an entrypoint + +CMD [,...] +# always part of dockerfile, introduces entry point linux command e.g. `CMD node server.js` +# This executes after image creation only when the container from the image is running. +``` +### Build your images +Use the `docker build` command after wrapping your application into a Docker image to run ( or build) it. + +```bash + +$docker build +# used to build an image from the specified Dockerfile +# instead of path we could also specify a URL +# -t tag is optional and used to name and tag your images for e.g. `$docker build -t my-image:0.1 ./home/app` +# rebuild images everytime you make changes in the dockerfile +``` + +## Push your image to DockerHub +If you want your application's Docker image to be made publically available for any Docker user, you might wanna push it to the [Docker Hub](https://hub.docker.com/) which is a registry of Docker images. Make sure you have an account with a username and password on Docker Hub. + +When pushing an image to Docker Hub, we must specify our Docker Hub username as part of the source image name. We need to create the target image with the tag name of username/image-name much like GitHub repositories. + +```bash +$docker login +# to login to Docker Hub using your username and password + +$docker tag [:] [:] +# this tags a local src-image to a public target-image +# e.g. `docker tag my-sample-app:1.0.0 akshitadixit/my-sample-app` +# if tags are not specified, they're defaulted to `latest` + +$docker push [:] +# uploads our image to Docker Hub +# e.g. `docker push akshitadixit/my-sample-app` +# this image will be accessible under your profile's repositories as `https://hub.docker.com/r/username/image-name` + ``` \ No newline at end of file -- cgit v1.2.3 From bba9f7df211d63293e2a957872d156a0a6dfcd48 Mon Sep 17 00:00:00 2001 From: Marcel Ribeiro-Dantas Date: Sat, 10 Dec 2022 12:05:34 -0300 Subject: Fixes typos in many different English articles Signed-off-by: Marcel Ribeiro-Dantas --- docker.html.markdown | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index e18db5c9..0e61151e 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -254,7 +254,7 @@ $docker build ``` ## Push your image to DockerHub -If you want your application's Docker image to be made publically available for +If you want your application's Docker image to be made publicly available for any Docker user, you might wanna push it to the [Docker Hub](https://hub.docker.com/) which is a registry of Docker images. Make sure you have an account with a username and password on Docker Hub. -- cgit v1.2.3 From 51900f18386825917c4b0c4da3319dfb0b2a9507 Mon Sep 17 00:00:00 2001 From: Abirama Krishnan Date: Thu, 14 Dec 2023 21:06:05 +0530 Subject: Update docker.html.markdown with added spaces for clarity (#4807) --- docker.html.markdown | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index 0e61151e..17f803f4 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -187,7 +187,7 @@ $ docker exec -it 7b272 bash # directory. Here 7b272 was our ubuntu container and the above command would # help us interact with the container by opening a bash session. -$docker logs +$ docker logs # Displays the information logged by the specified container # root@7b27222e4bb7:/# whoami # root @@ -245,11 +245,11 @@ image to run ( or build) it. ```bash -$docker build +$ docker build # used to build an image from the specified Dockerfile # instead of path we could also specify a URL # -t tag is optional and used to name and tag your images for e.g. -# `$docker build -t my-image:0.1 ./home/app` +# `$ docker build -t my-image:0.1 ./home/app` # rebuild images everytime you make changes in the dockerfile ``` @@ -264,15 +264,15 @@ as part of the source image name. We need to create the target image with the tag name of username/image-name much like GitHub repositories. ```bash -$docker login +$ docker login # to login to Docker Hub using your username and password -$docker tag [:] [:] +$ docker tag [:] [:] # this tags a local src-image to a public target-image # e.g. `docker tag my-sample-app:1.0.0 akshitadixit/my-sample-app` # if tags are not specified, they're defaulted to `latest` -$docker push [:] +$ docker push [:] # uploads our image to Docker Hub # e.g. `docker push akshitadixit/my-sample-app` # this image will be accessible under your profile's repositories as -- cgit v1.2.3 From 818b8eec46b11b36b5235ecbce540557afec4687 Mon Sep 17 00:00:00 2001 From: Boris Verkhovskiy Date: Thu, 4 Apr 2024 00:27:01 -0700 Subject: Convert \r\n to \n --- docker.html.markdown | 562 +++++++++++++++++++++++++-------------------------- 1 file changed, 281 insertions(+), 281 deletions(-) (limited to 'docker.html.markdown') diff --git a/docker.html.markdown b/docker.html.markdown index 17f803f4..ec6abe7e 100644 --- a/docker.html.markdown +++ b/docker.html.markdown @@ -1,281 +1,281 @@ ---- -category: tool -tool: docker -filename: docker.bat -contributors: - - ["Ruslan López", "http://javapro.org/"] - - ["Michael Chen", "https://github.com/ML-Chen"] - - ["Akshita Dixit", "https://github.com/akshitadixit"] - - ["Marcel Ribeiro-Dantas", "https://github.com/mribeirodantas"] ---- - -Docker is a tool that helps you build, test, ship and run applications -seamlessly across various machines. It replicates the environment our software -needs on any machine. You can get Docker for your machine from -https://docs.docker.com/get-docker/ - -It has grown in popularity over the last decade due to being lightweight and -fast as compared to virtual-machines that are bulky and slow. Unlike VMs, docker -does not need a full blown OS of its own to be loaded to start and does not -compete for resources other than what the application it is running will use. -VMs on the other hand are pretty resource intensive on our processors, disks and -memory hence running multiple VMs for various applications becomes a challenge -in a limited capacity architecture. - -
-┌────────────────────────┐ ┌───────────────────────┐
-│      ┌───────────┐     │ │      ┌───────────┐    │
-│      │   App     │     │ │      │   App     │    │
-│      └───────────┘     │ │      └───────────┘    │
-│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
-│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
-│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
-│  ┌───────────────────┐ │ │  ┌──────────────────┐ │
-│  │      Guest OS     │ │ │  │     Guest OS     │ │
-│  └───────────────────┘ │ │  └──────────────────┘ │
-│           VM1          │ │           VM2         │
-└────────────────────────┘ └───────────────────────┘
-┌──────────────────────────────────────────────────┐
-│                     Hypervisor                   │
-└──────────────────────────────────────────────────┘
-┌──────────────────────────────────────────────────┐
-│                      Host OS                     │
-└──────────────────────────────────────────────────┘
-┌──────────────────────────────────────────────────┐
-│             Hardware Infrastructure              │
-└──────────────────────────────────────────────────┘
-              (VM based architecture)
-
-┌────────────────────────┐ ┌───────────────────────┐
-│      ┌───────────┐     │ │      ┌───────────┐    │
-│      │   App     │     │ │      │   App     │    │
-│      └───────────┘     │ │      └───────────┘    │
-│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
-│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
-│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
-│        Container1      │ │       Container2      │
-└────────────────────────┘ └───────────────────────┘
-┌──────────────────────────────────────────────────┐
-│                       Docker                     │
-└──────────────────────────────────────────────────┘
-┌──────────────────────────────────────────────────┐
-│                        OS                        │
-└──────────────────────────────────────────────────┘
-┌──────────────────────────────────────────────────┐
-│             Hardware Infrastructure              │
-└──────────────────────────────────────────────────┘
-            (Docker based architecture)
-
-
- -Couple of terms we will encounter frequently are Docker Images and Docker -Containers. Images are packages or templates of containers all stored in a -container registry such as [Docker Hub](https://hub.docker.com/). Containers -are standalone, executable instances of these images which include code, -runtime, system tools, system libraries and settings - everything required to -get the software up and running. Coming to Docker, it follows a client-server -architecture wherein the CLI client communicates with the server component, -which here is, the Docker Engine using RESTful API to issue commands. - -## The Docker CLI -```bash -# after installing Docker from https://docs.docker.com/get-docker/ -# To list available commands, either run `docker` with no parameters or execute -# `docker help` -$ docker - ->>> docker [OPTIONS] COMMAND [ARG...] - docker [ --help | -v | --version ] - - A self-sufficient runtime for containers. - - Options: - --config string Location of client config files (default "/root/.docker") - -c, --context string Name of the context to use to connect to the daemon (overrides DOCKER_HOST env var and default context set with "docker context use") - -D, --debug Enable debug mode - --help Print usage - -H, --host value Daemon socket(s) to connect to (default []) - -l, --log-level string Set the logging level ("debug"|"info"|"warn"|"error"|"fatal") (default "info") - --tls Use TLS; implied by --tlsverify - --tlscacert string Trust certs signed only by this CA (default "/root/.docker/ca.pem") - --tlscert string Path to TLS certificate file (default "/root/.docker/cert.pem") - --tlskey string Path to TLS key file (default "/root/.docker/key.pem") - --tlsverify Use TLS and verify the remote - -v, --version Print version information and quit - - Commands: - attach Attach to a running container - # […] - -$ docker run hello-world -# `docker run ` is used to run a container, it will pull the -# images from Docker Hub if they don't already exist in your system. Here the -# docker client connects to the daemon which in turn pulls the "hello-world" -# image from the Docker Hub. The daemon then builds a new container from the -# image which runs the executable that produces the output streamed back to the -# client that we see on our terminals. - -$ docker run -d ubuntu sleep 60s -# The -d (or --detach) flag is when we want to run a container in the background -# and return back to the terminal. Here we detach an ubuntu container from the -# terminal, the output should be the id and the command exits. If we check -# running containers, we should still see ours there: -# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES -# 133261b4894a ubuntu "sleep 60s" 3 seconds ago Up 2 seconds vigorous_gould - -$ docker run -p 3000:8000 -# The -p (or --publish) flag is used to expose port 8000 inside the container to -# port 3000 outside the container. This is because the app inside the container -# runs in isolation, hence the port 8000 where the app runs is private to the -# container. - -$ docker run -i -# or -$ docker run -it -# Docker runs our containers in a non-interactive mode i.e. they do not accept -# inputs or work dynamically while running. The -i flag keeps input open to the -# container, and the -t flag creates a pseudo-terminal that the shell can attach -# to (can be combined as -it) - -$ docker ps -a -# The `docker ps` command only shows running containers by default. To see all -# containers, use the -a (or --all) flag -# Running the above command should output something similar in the terminal: -# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES -# 82f84bf6912b hello-world "/hello" 9 minutes ago Exited (0) 9 minutes ago eloquent_sammet - - -$ docker stop hello-world -# or -$ docker start hello-world -# The stop command simply stops one or more containers, and the start command -# starts the container(s) up again! `docker start -a ubuntu` will attach our -# detached container back to the terminal i.e. runs in the foreground - -$ docker create alpine -# `docker create` creates a new container for us with the image specified (here, -# alpine), the container does not auto-start unlike `docker run`. This command -# is used to set up a container configuration and then `docker start` to shoot -# it up when required. Note that the status is "Created": -# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES -# 4c71c727c73d alpine "/bin/sh" 29 seconds ago Created naughty_ritchie - -$ docker rm 82f84 -# Removes one or more containers using their container ID. -# P.S.: we can use only the first few characters of the entire ID to identify -# containers - -$ docker images -# Displays all images and their information, created here means the latest image -# tag updated on Docker Hub: -# REPOSITORY TAG IMAGE ID CREATED SIZE -# ubuntu latest a8780b506fa4 9 days ago 77.8MB -# alpine latest 9c6f07244728 3 months ago 5.54MB -# hello-world latest feb5d9fea6a5 13 months ago 13.3kB - -$ docker rmi -# Removes one or more images from your system which do not have their instances -# (or containers as we know them) running. If the image has an attached -# container, either delete the container first or use the -f (or --force) flag -# to forcefully delete both the container and image. - -$ docker pull busybox -# The pull command downloads the specified image on our system from Docker Hub. - -$ docker exec -it 7b272 bash -# This command is used to run a command in the running container's default -# directory. Here 7b272 was our ubuntu container and the above command would -# help us interact with the container by opening a bash session. - -$ docker logs -# Displays the information logged by the specified container -# root@7b27222e4bb7:/# whoami -# root -# root@7b27222e4bb7:/# pwd -# / -# root@7b27222e4bb7:/# ls -# bin boot dev etc home lib lib32 lib64 libx3 srv sys tmp usr var -# root@7b27222e4bb7:/# exit -# exit - -# More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ -``` -## The Dockerfile -The Dockerfile is a blueprint of a Docker image. We can mention the artifacts -from our application along with their configurations into this file in the -specific syntax to let anyone create a Docker image of our application. - -### A few things to keep in mind: -* It is always strictly named `Dockerfile` without any extensions -* We have to build our custom image on top of some already available Docker base -image. (there is an empty image called `scratch` which literally lets you build -an image from scratch) -* All capitalised commands are part of the syntax, they are not case-sensitive -but used like a convention -* Below is a sample Dockerfile but you can read in depth from the [official docs](https://docs.docker.com/engine/reference/builder/). - -```Dockerfile -FROM -# define base image - -ENV USERNAME='admin'\ - PWD='****' -# optionally define environmental variables - -RUN apt-get update -# run linux commands inside container env, does not affect host env -# This executes during the time of image creation - -COPY -# executes on the host, copies files from src (usually on the host) to target -# on the container - -ENTRYPOINT ["some-script.sh"] -# executes an entire script as an entrypoint - -CMD [,...] -# always part of dockerfile, introduces entry point linux command e.g. -# `CMD node server.js` -# This executes after image creation only when the container from the image -# is running. -``` -### Build your images -Use the `docker build` command after wrapping your application into a Docker -image to run ( or build) it. - -```bash - -$ docker build -# used to build an image from the specified Dockerfile -# instead of path we could also specify a URL -# -t tag is optional and used to name and tag your images for e.g. -# `$ docker build -t my-image:0.1 ./home/app` -# rebuild images everytime you make changes in the dockerfile -``` - -## Push your image to DockerHub -If you want your application's Docker image to be made publicly available for -any Docker user, you might wanna push it to the [Docker Hub](https://hub.docker.com/) which is a -registry of Docker images. Make sure you have an account with a username and -password on Docker Hub. - -When pushing an image to Docker Hub, we must specify our Docker Hub username -as part of the source image name. We need to create the target image with the -tag name of username/image-name much like GitHub repositories. - -```bash -$ docker login -# to login to Docker Hub using your username and password - -$ docker tag [:] [:] -# this tags a local src-image to a public target-image -# e.g. `docker tag my-sample-app:1.0.0 akshitadixit/my-sample-app` -# if tags are not specified, they're defaulted to `latest` - -$ docker push [:] -# uploads our image to Docker Hub -# e.g. `docker push akshitadixit/my-sample-app` -# this image will be accessible under your profile's repositories as -# `https://hub.docker.com/r/username/image-name` - -``` +--- +category: tool +tool: docker +filename: docker.bat +contributors: + - ["Ruslan López", "http://javapro.org/"] + - ["Michael Chen", "https://github.com/ML-Chen"] + - ["Akshita Dixit", "https://github.com/akshitadixit"] + - ["Marcel Ribeiro-Dantas", "https://github.com/mribeirodantas"] +--- + +Docker is a tool that helps you build, test, ship and run applications +seamlessly across various machines. It replicates the environment our software +needs on any machine. You can get Docker for your machine from +https://docs.docker.com/get-docker/ + +It has grown in popularity over the last decade due to being lightweight and +fast as compared to virtual-machines that are bulky and slow. Unlike VMs, docker +does not need a full blown OS of its own to be loaded to start and does not +compete for resources other than what the application it is running will use. +VMs on the other hand are pretty resource intensive on our processors, disks and +memory hence running multiple VMs for various applications becomes a challenge +in a limited capacity architecture. + +
+┌────────────────────────┐ ┌───────────────────────┐
+│      ┌───────────┐     │ │      ┌───────────┐    │
+│      │   App     │     │ │      │   App     │    │
+│      └───────────┘     │ │      └───────────┘    │
+│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
+│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
+│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
+│  ┌───────────────────┐ │ │  ┌──────────────────┐ │
+│  │      Guest OS     │ │ │  │     Guest OS     │ │
+│  └───────────────────┘ │ │  └──────────────────┘ │
+│           VM1          │ │           VM2         │
+└────────────────────────┘ └───────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                     Hypervisor                   │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                      Host OS                     │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│             Hardware Infrastructure              │
+└──────────────────────────────────────────────────┘
+              (VM based architecture)
+
+┌────────────────────────┐ ┌───────────────────────┐
+│      ┌───────────┐     │ │      ┌───────────┐    │
+│      │   App     │     │ │      │   App     │    │
+│      └───────────┘     │ │      └───────────┘    │
+│  ┌────────┐ ┌────────┐ │ │  ┌────────┐ ┌───────┐ │
+│  │  Libs  │ │  Deps  │ │ │  │  Libs  │ │  Deps │ │
+│  └────────┘ └────────┘ │ │  └────────┘ └───────┘ │
+│        Container1      │ │       Container2      │
+└────────────────────────┘ └───────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                       Docker                     │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│                        OS                        │
+└──────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────┐
+│             Hardware Infrastructure              │
+└──────────────────────────────────────────────────┘
+            (Docker based architecture)
+
+
+ +Couple of terms we will encounter frequently are Docker Images and Docker +Containers. Images are packages or templates of containers all stored in a +container registry such as [Docker Hub](https://hub.docker.com/). Containers +are standalone, executable instances of these images which include code, +runtime, system tools, system libraries and settings - everything required to +get the software up and running. Coming to Docker, it follows a client-server +architecture wherein the CLI client communicates with the server component, +which here is, the Docker Engine using RESTful API to issue commands. + +## The Docker CLI +```bash +# after installing Docker from https://docs.docker.com/get-docker/ +# To list available commands, either run `docker` with no parameters or execute +# `docker help` +$ docker + +>>> docker [OPTIONS] COMMAND [ARG...] + docker [ --help | -v | --version ] + + A self-sufficient runtime for containers. + + Options: + --config string Location of client config files (default "/root/.docker") + -c, --context string Name of the context to use to connect to the daemon (overrides DOCKER_HOST env var and default context set with "docker context use") + -D, --debug Enable debug mode + --help Print usage + -H, --host value Daemon socket(s) to connect to (default []) + -l, --log-level string Set the logging level ("debug"|"info"|"warn"|"error"|"fatal") (default "info") + --tls Use TLS; implied by --tlsverify + --tlscacert string Trust certs signed only by this CA (default "/root/.docker/ca.pem") + --tlscert string Path to TLS certificate file (default "/root/.docker/cert.pem") + --tlskey string Path to TLS key file (default "/root/.docker/key.pem") + --tlsverify Use TLS and verify the remote + -v, --version Print version information and quit + + Commands: + attach Attach to a running container + # […] + +$ docker run hello-world +# `docker run ` is used to run a container, it will pull the +# images from Docker Hub if they don't already exist in your system. Here the +# docker client connects to the daemon which in turn pulls the "hello-world" +# image from the Docker Hub. The daemon then builds a new container from the +# image which runs the executable that produces the output streamed back to the +# client that we see on our terminals. + +$ docker run -d ubuntu sleep 60s +# The -d (or --detach) flag is when we want to run a container in the background +# and return back to the terminal. Here we detach an ubuntu container from the +# terminal, the output should be the id and the command exits. If we check +# running containers, we should still see ours there: +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 133261b4894a ubuntu "sleep 60s" 3 seconds ago Up 2 seconds vigorous_gould + +$ docker run -p 3000:8000 +# The -p (or --publish) flag is used to expose port 8000 inside the container to +# port 3000 outside the container. This is because the app inside the container +# runs in isolation, hence the port 8000 where the app runs is private to the +# container. + +$ docker run -i +# or +$ docker run -it +# Docker runs our containers in a non-interactive mode i.e. they do not accept +# inputs or work dynamically while running. The -i flag keeps input open to the +# container, and the -t flag creates a pseudo-terminal that the shell can attach +# to (can be combined as -it) + +$ docker ps -a +# The `docker ps` command only shows running containers by default. To see all +# containers, use the -a (or --all) flag +# Running the above command should output something similar in the terminal: +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 82f84bf6912b hello-world "/hello" 9 minutes ago Exited (0) 9 minutes ago eloquent_sammet + + +$ docker stop hello-world +# or +$ docker start hello-world +# The stop command simply stops one or more containers, and the start command +# starts the container(s) up again! `docker start -a ubuntu` will attach our +# detached container back to the terminal i.e. runs in the foreground + +$ docker create alpine +# `docker create` creates a new container for us with the image specified (here, +# alpine), the container does not auto-start unlike `docker run`. This command +# is used to set up a container configuration and then `docker start` to shoot +# it up when required. Note that the status is "Created": +# CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +# 4c71c727c73d alpine "/bin/sh" 29 seconds ago Created naughty_ritchie + +$ docker rm 82f84 +# Removes one or more containers using their container ID. +# P.S.: we can use only the first few characters of the entire ID to identify +# containers + +$ docker images +# Displays all images and their information, created here means the latest image +# tag updated on Docker Hub: +# REPOSITORY TAG IMAGE ID CREATED SIZE +# ubuntu latest a8780b506fa4 9 days ago 77.8MB +# alpine latest 9c6f07244728 3 months ago 5.54MB +# hello-world latest feb5d9fea6a5 13 months ago 13.3kB + +$ docker rmi +# Removes one or more images from your system which do not have their instances +# (or containers as we know them) running. If the image has an attached +# container, either delete the container first or use the -f (or --force) flag +# to forcefully delete both the container and image. + +$ docker pull busybox +# The pull command downloads the specified image on our system from Docker Hub. + +$ docker exec -it 7b272 bash +# This command is used to run a command in the running container's default +# directory. Here 7b272 was our ubuntu container and the above command would +# help us interact with the container by opening a bash session. + +$ docker logs +# Displays the information logged by the specified container +# root@7b27222e4bb7:/# whoami +# root +# root@7b27222e4bb7:/# pwd +# / +# root@7b27222e4bb7:/# ls +# bin boot dev etc home lib lib32 lib64 libx3 srv sys tmp usr var +# root@7b27222e4bb7:/# exit +# exit + +# More commands can be found at https://docs.docker.com/engine/reference/commandline/docker/ +``` +## The Dockerfile +The Dockerfile is a blueprint of a Docker image. We can mention the artifacts +from our application along with their configurations into this file in the +specific syntax to let anyone create a Docker image of our application. + +### A few things to keep in mind: +* It is always strictly named `Dockerfile` without any extensions +* We have to build our custom image on top of some already available Docker base +image. (there is an empty image called `scratch` which literally lets you build +an image from scratch) +* All capitalised commands are part of the syntax, they are not case-sensitive +but used like a convention +* Below is a sample Dockerfile but you can read in depth from the [official docs](https://docs.docker.com/engine/reference/builder/). + +```Dockerfile +FROM +# define base image + +ENV USERNAME='admin'\ + PWD='****' +# optionally define environmental variables + +RUN apt-get update +# run linux commands inside container env, does not affect host env +# This executes during the time of image creation + +COPY +# executes on the host, copies files from src (usually on the host) to target +# on the container + +ENTRYPOINT ["some-script.sh"] +# executes an entire script as an entrypoint + +CMD [,...] +# always part of dockerfile, introduces entry point linux command e.g. +# `CMD node server.js` +# This executes after image creation only when the container from the image +# is running. +``` +### Build your images +Use the `docker build` command after wrapping your application into a Docker +image to run ( or build) it. + +```bash + +$ docker build +# used to build an image from the specified Dockerfile +# instead of path we could also specify a URL +# -t tag is optional and used to name and tag your images for e.g. +# `$ docker build -t my-image:0.1 ./home/app` +# rebuild images everytime you make changes in the dockerfile +``` + +## Push your image to DockerHub +If you want your application's Docker image to be made publicly available for +any Docker user, you might wanna push it to the [Docker Hub](https://hub.docker.com/) which is a +registry of Docker images. Make sure you have an account with a username and +password on Docker Hub. + +When pushing an image to Docker Hub, we must specify our Docker Hub username +as part of the source image name. We need to create the target image with the +tag name of username/image-name much like GitHub repositories. + +```bash +$ docker login +# to login to Docker Hub using your username and password + +$ docker tag [:] [:] +# this tags a local src-image to a public target-image +# e.g. `docker tag my-sample-app:1.0.0 akshitadixit/my-sample-app` +# if tags are not specified, they're defaulted to `latest` + +$ docker push [:] +# uploads our image to Docker Hub +# e.g. `docker push akshitadixit/my-sample-app` +# this image will be accessible under your profile's repositories as +# `https://hub.docker.com/r/username/image-name` + +``` -- cgit v1.2.3