Install Docker and Learn Basic Container Manipulation in CentOS and RHEL 8/7 – Part 1

In this 4-article series, we will discuss Docker, which is an open-source lightweight virtualization tool that runs at top of Operating System level, allowing users to create, run and deploy applications, encapsulated into small containers.

This type of Linux containers are proven to be fast, portable, and secure. The processes that run in a Docker container are always isolated from the main host, preventing outside tampering.

Part 1: Install Docker and Learn Basic Container Manipulation in CentOS and RHEL 8/7

This tutorial provides a starting point on how to install Docker, create and run Docker containers on CentOS/RHEL 8/7, but barely scratches the surface of Docker.

Step 1: Install and Configure Docker

1. Earlier versions of Docker were called docker or docker-engine, if you have these installed, you must uninstall them before installing a newer docker-ce version.

# yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \

2. To install the latest version of the Docker Engine you need to set up the Docker repository and install the yum-utils package to enable Docker stable repository on the system.

# yum install -y yum-utils
# yum-config-manager \
    --add-repo \

3. Now install the newer docker-ce version from the Docker repository and containerd manually, because due to some issues, Red Hat blocked the installation of > 1.2.0-3.el7, which is a dependency of docker-ce.

# yum install
# yum install docker-ce docker-ce-cli

4. After, Docker package has been installed, start the daemon, check its status and enable it system-wide using the below commands:

# systemctl start docker 
# systemctl status docker
# systemctl enable docker
Check Docker Status
Check Docker Status

5. Finally, run a container test image to verify if Docker works properly, by issuing the following command:

# docker run hello-world

If you can see the below message, then everything is in the right place.

Sample Output
Verify Docker Installation
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.
 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:

For more examples and ideas, visit:

6. Now, you can run a few basic Docker commands to get some info about Docker:

For system-wide information on Docker
# docker info
Check Docker Info
Check Docker Info
For Docker version
# docker version
Check Docker Version
Check Docker Version

7. To get a list of all available Docker commands type docker on your console.

# docker
List Docker Commands
List Docker Commands

Step 2: Download a Docker Image

8. In order to start and run a Docker container, first, an image must be downloaded from Docker Hub on your host. Docker Hub offers a lot of free images from its repositories.

To search for a Docker image, Ubuntu, for instance, issue the following command:

# docker search ubuntu
Docker Search Ubuntu Images
Docker Search Ubuntu Images

9. After you decided on what image you want to run based on your needs, download it locally by running the below command (in this case an Ubuntu image is downloaded and used):

# docker pull ubuntu
Download Docker Ubuntu Image
Download Docker Ubuntu Image

10. To list all the available Docker images on your host issue the following command:

# docker images
List Docker Images
List Docker Images

11. If you don’t need a Docker image anymore and you want to remove it from the host issue the following command:

# docker rmi ubuntu
Remove Docker Image
Remove Docker Image

Step 3: Run a Docker Container

When you execute a command against an image you basically obtain a container. After the command that is executing into the container ends, the container stops (you get a non-running or exited container). If you run another command into the same image again a new container is created and so on.

All the containers created will remain on the host filesystem until you choose to delete them by using the docker rm command.

12. In order to create and run a container, you need to run command into a downloaded image, in this case, Ubuntu, so a basic command would be to display the distribution version file inside the container using cat command, as in the following example:

# docker run ubuntu cat /etc/issue
Run Docker Containers
Run Docker Containers

The above command is divided as follows:

# docker run [local image] [command to run into container]

13. To run one of the containers again with the command that was executed to create it, first, you must get the container ID (or the name automatically generated by Docker) by issuing the below command, which displays a list of the running and stopped (non-running) containers:

# docker ps -l 
List Running Docker Containers
List Running Docker Containers

14. Once the container ID has been obtained, you can start the container again with the command that was used to create it, by issuing the following command:

# docker start 923a720da57f

Here, the string 923a720da57f represents the container ID.

Start Docker Containers
Start Docker Containers

15. In case the container is running state, you can get its ID by issuing docker ps command. To stop the running container issue docker stop command by specifying the container ID or auto-generated name.

# docker stop 923a720da57f
# docker stop cool_lalande
# docker ps
Stop Docker Containers
Stop Docker Containers

16. A more elegant alternative so you don’t have to remember the container ID would be to allocate a unique name for every container you create by using the --name option on the command line, as in the following example:

# docker run --name ubuntu20.04 ubuntu cat /etc/issue
Add Name to Docker Container
Add Name to Docker Container

17. Then, using the name that you allocated for the container, you can manipulate container (start, stop, remove, top, stats) further just by addressing its name, as in the below examples:

# docker start ubuntu20.04
# docker stats ubuntu20.04
# docker top ubuntu20.04 

Be aware that some of the above commands might display no output if the process of command that was used to create the container finishes. When the process that runs inside the container finishes, the container stops.

Step 4: Run an Interactive Session into a Container

18. In order to interactively connect into a container shell session, and run commands as you do on any other Linux session, issue the following command:

# docker run -it ubuntu bash
Start Docker Container Interactive Shell
Start Docker Container Interactive Shell

The above command is divided as follows:

  1. -i is used to start an interactive session.
  2. -t allocates a TTY and attaches stdin and stdout.
  3. ubuntu is the image that we used to create the container.
  4. bash (or /bin/bash) is the command that we are running inside the Ubuntu container.

19. To quit and return to host from the running container session you must type exit command. The exit command terminates all the container processes and stops it.

# exit

20. If you’re interactively logged on container terminal prompt and you need to keep the container in running state but exit from the interactive session, you can quit the console and return to host terminal by pressing Ctrl+p and Ctrl+q keys.

Keep Docker Shell Session Active
Keep Docker Shell Session Active

21. To reconnect to the running container you need the container ID or name. Issue docker ps command to get the ID or name and, then, run docker attach command by specifying container ID or name, as illustrated in the image above:

# docker attach <container id>

22. To stop a running container from the host session issue the following command:

# docker kill <container id>

That’s all for basic container manipulation. In the next tutorial, we will discuss how to save, delete, and run a web server into a Docker container.

Hey TecMint readers,

Exciting news! Every month, our top blog commenters will have the chance to win fantastic rewards, like free Linux eBooks such as RHCE, RHCSA, LFCS, Learn Linux, and Awk, each worth $20!

Learn more about the contest and stand a chance to win by sharing your thoughts below!

Matei Cezar
I'am a computer addicted guy, a fan of open source and linux based system software, have about 4 years experience with Linux distributions desktop, servers and bash scripting.

Each tutorial at TecMint is created by a team of experienced Linux system administrators so that it meets our high-quality standards.

Join the TecMint Weekly Newsletter (More Than 156,129 Linux Enthusiasts Have Subscribed)
Was this article helpful? Please add a comment or buy me a coffee to show your appreciation.


Leave a Reply
    • @Jagadeesh,

      I think you behind a firewall, and you need to configure proxy to make it work.

      Please add the proxy settings in /etc/default/docker file, and restarted the service. Then try to run the hello-world image and do further tasks.

  1. [root@localhost ~]# lsblk
    sda 8:0 0 20G 0 disk
    ├─sda1 8:1 0 300M 0 part /boot
    ├─sda2 8:2 0 2G 0 part [SWAP]
    └─sda3 8:3 0 17.7G 0 part /
    sr0 11:0 1 1024M 0 rom
    loop0 7:0 0 100G 0 loop
    └─docker-8:3-34878977-pool 253:0 0 100G 0 dm
    loop1 7:1 0 2G 0 loop
    └─docker-8:3-34878977-pool 253:0 0 100G 0 dm
    [root@localhost ~]#

  2. Hello Sir,

    I installed docker container default it was created with a size of 100G now how to remove by using cmd.

    See the attachment I’m giving below sir…

  3. Hi,

    I need to run multiple web sites on a single server. Each website will have different version of php. Please let me know whether a docker container will be available for such requirement or I have to create such containers on my own.

    If I need to create containers with different version of php, please guide me for the same as I am starting on docker today only. thanks in advance.

    • This can be easily be accomplished with Vhosts. If you really want containers then you need to create a container for each application or version of php and expose it to outside.

  4. Hi – A genuine question please. I use Proxmox for LXC containers which works great..what does Docker offer over proxmox ?

    • Basically, I would say that the main difference is that LXC containers behave as a virtual machine mainly, opposed to Docker which runs an ephemeral single process. But that’s only just a simple difference. You should google it for more detailed info.

  5. Thanks for the article..
    I completed a 6 month contract for a large publisher involving the evaluation of various triple stores. I created a dockerfile for each triple store allowing us to quickly install the systems when required on various servers. I also created a system to monitor and graph the memory use of any number docker containers. They are a number of stumbling blocks that takes some experience to understand.

    • Alex, If you have the details on how you accomplished these docker tasks, can you please share on my gmail e-mail ID bangaru.adabala I was trying to create some docker images with personal scripts and other stuff to be able to quickly deploy and / or restore instances.

      Thanks in advance.

  6. You could use Docker on any machine, it doesn’t matter if you are running LAMP stack on it. As a recommendation try to run Docker on a fresh server or a test server, never play on production machines for the sake of security and resources.


Got Something to Say? Join the Discussion...

Thank you for taking the time to share your thoughts with us. We appreciate your decision to leave a comment and value your contribution to the discussion. It's important to note that we moderate all comments in accordance with our comment policy to ensure a respectful and constructive conversation.

Rest assured that your email address will remain private and will not be published or shared with anyone. We prioritize the privacy and security of our users.