JT
December 18 2024
Updated December 18 2024

Docker container: what is it and how to manage it?

Linux

Docker is a great platform that has collected a lot of tools and libraries that allow you to create isolated spaces with applications/services. They are automatically deployed, allowing you without knowledge of the application operation, to use an out-of-the-box solution!

These spaces are also called Docker containers, due to their ability to isolate from the host, except for a common core and increased efficiency - they have become used to deploy services and other solutions. In this article let's learn all about them, as well as practical examples of their use!

How does a container work?

A Docker container is actually a limited process in the operating system to which a separate file system, network stack and PID have been attached. All of these components were virtually created within a single kernel and then added to the container process. The link diagram shows the components and the container process in purple, and the host objects in blue:

Schema
Screenshot №1 — Schema

With this scheme of interaction achieves a certain level of network and file isolation, except for the kernel, which is often exploited by hackers. Therefore, it is recommended to limit the area of interaction with the host machine as much as possible for such environments. For example, it is better to use virtual volumes for storing configs and other data. Because if you attach the host volume to the container, the virtual root will have the same rights to the files as the host!

How to start and manage Docker containers?

Let's look at some basic examples of using and working with a container. Let's imagine that we have a ToR for deploying a Web application or any other service, but through Docker. For this purpose, we can use both a ready-made image or a cast of the system, which will deploy in our container, and write a Docker File ourselves. In this article we will consider the first case, the second case you can find in our detailed guide. Let's pre-install all dependencies and necessary components with the command:

apt update && apt install docker.io docker-compose -y
Installation
Screenshot №2 — Installation

After that, let's run the container with the docker run container command, where we also specify its basic parameters for operation:

docker run -d -p 8080:80 --name my_container -v data:/app/data nginx
Docker run
Screenshot №3 — Docker run

After running the utility to create the container with the virtual environment port 80 forwarded to the host machine, as well as creating a virtual data volume to store the container data, the initialisation process was started. The image was not found on the device, so it was downloaded from the repository and deployed. To view the container, let's write the command:

docker ps
Docker process
Screenshot №4 — Docker process

There are two additional running containers on the device, here you can see their main characteristics and state at the moment. To execute the process docker connect to container or enter the container, we will write the command:

docker exec -it my_container /bin/bash
Bash
Screenshot №5 — Bash

Where docker exec is a utility and subcommand, -it is an option to interactively link our terminal and the process in the container, my_container is the name of the container, and /bin/bash is our running shell. Logically, we open a new process, the output of which is displayed in our terminal, so we work through it. To exit, we use the keyboard shortcut Ctrl+D or the exit command.

To terminate the running container, write the command:

docker stop my_container

And if you need to close all of them at once, write the one below. It will allow you to execute a function within itself, which will only return a list of IDs of all containers:

docker stop $(docker ps -q)

They are now in a stopped state, so they can be started back up with the docker run command.

Note that data is not saved on the machine after restart, except for the declared storage locations -v data:/app/data. To have data saved without storage, after restart (docker save), use the docker container commit <container> <image> command!

You can remove them with the command below for a single container:

docker container remove my_container

And for all existing containers at once:

docker container remove $(docker container ls -a -q)
Remove container
Screenshot №6 — Remove container

It will also allow you to run the function to enumerate them first, and then remove all those returned to the command. Also in the process you can view your container logs using the same docker logs <name_of_container> command. These are redirected from this virtual environment to a file whose output can be filtered. For example to find the necessary lines with authentication to the container:

docker logs | grep 'SSH'

As a result of executing these commands you should get a list of parameters of the requested objects. If you don't have sufficient resources than you can perform actions on powerful cloud servers. Serverspace provides isolated VPS / VDS servers for common and virtualize usage.

Create Server
Screenshot №7 — Create Server

Let's consider one of the latest features of Docker containers - docker container stats. To monitor the performance and viability of an existing application and service, Docker has a built-in solution:

docker container stats <container_name>
Docker statistic
Screenshot №8 — Docker statistic

From this we can estimate what is the disk occupancy, load in the virtual environment, so that we can add the necessary capacity or debug at the time. We have covered all the necessary basics of virtual environment management, this knowledge will allow you to manage your services and solutions more efficiently!

Vote:
5 out of 5
Аverage rating : 5
Rated by: 1
33145 North Miami, FL 2520 Coral Way apt 2-135
+1 302 425-97-76
700 300
ITGLOBAL.COM CORP
700 300

You might also like...

We use cookies to make your experience on the Serverspace better. By continuing to browse our website, you agree to our
Use of Cookies and Privacy Policy.