How to Install and Use Docker on Debian

How to Install and Use Docker on Debian
Hostman Team
Technical writer
Debian
14.06.2024
Reading time: 10 min

Docker's impact on the packaging, deployment, and execution of apps makes it the preferred method of containerization. Installing Docker on Debian provides multiple benefits as it streamlines the workflow, enhances security measures, and optimizes resource management. Docker helps developers build, test and deploy their apps in a single environment, free from system configurations. It offers strong security as containers are isolated from the host system, and any threats within the application do not impact the host machine.

In this article we'll delve into the basics of Docker and how to install it on Debian. Our comprehensive guide will walk you through the process of utilizing Docker on Debian. You'll discover useful tips for streamlining the containerization of your applications. Whether you're a novice or seeking to improve your expertise, this tutorial offers a thorough overview of Docker and its significance in application containerization on Debian.

Preparing Debian for Docker Installer

Before installing and utilizing Docker on Debian, you should ensure that your system meets the requirements. This includes checking the compatibility of your hardware and software with Docker, such as the operating system and kernel version, processor architecture, and free disk space. It is also essential to confirm that your system possesses adequate RAM and CPU resources to effectively run Docker and its containers.

To ensure that your system is compatible, use the command 'uname -a' in the terminal. This will provide details about your operating system and kernel version, and processor architecture. Docker specifically requires a 64-bit version of Debian with a minimum kernel version of 3.10.

For optimal performance, it is essential to have up-to-date software on your system. This includes upgrading any components used by it. Using outdated packages leads to compatibility issues and hinders the smooth functioning. In order to install Docker on Debian correctly, ensure to run the update and upgrade commands specific to your operating system.

How to Install Docker on Debian

Once you have checked the compatibility of your system and set up the dependencies, proceed with the Docker installation on Debian.

  1. Add the Docker repository to your system's sources list to access the latest updates and versions of Docker using the following command:

echo 'deb [arch=amd64] https://download.docker.com/linux/debian buster stable' | sudo tee /etc/apt/sources.list.d/docker.list
  1. However, to install Docker on Debian correctly, it is necessary to add the relevant keys to your system to prevent any potential repository errors. They serve as authentication for the packages that will be downloaded and installed.

To add the keys, use the following command:

curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -

By adding the required keys to your system, you will be able to smoothly install Docker without any problems.

  1. Update your system's package list by running the following command:

sudo apt-get update
  1. Install Docker on Debian by executing the following command:

sudo apt-get install docker-ce
  1. Verify that Docker is installed correctly by running the following command:

sudo docker run hello-world

If installed successfully, a message will confirm that Docker is running.

  1. Use the following command to check the Docker service to start on boot:

systemctl is-enabled docker

Docker automatically starts by default whenever the system boots.

  1. After configuring Docker to start on boot, verify its correct functioning. Use the  following command to check the installed version of Docker:

docker version
  1. Use the following command to view Docker's activity, running status, and any potential errors:

sudo systemctl status docker

Configuring Docker on Debian

Start configuring Docker on Debian by adding users. While Docker typically operates under the root user, it is better to establish another user for Docker for security reasons. Use the 'adduser' command to indicate a username and password:

sudo adduser --home /home/hostman --shell /bin/bash hostman

In this example:

--home /home/hostman: specifies the new user's home directory /home/hostman

--shell /bin/bash: specifies that the default shell for a new user will be /bin/bash

Once users are created, it is crucial to add them to the Docker group to provide access and permissions, using the command:

sudo usermod -aG docker hostman

You can test if you can run Docker commands without root privileges by using the command 'docker ps':

docker ps -a

This command will list all containers on your host system, including stopped ones.

If the command runs successfully, it confirms that you have successfully created and added your user to the Docker group.

If the command fails, check to see if the group exists and create it if necessary:

groupadd docker

The Docker group is almost always created automatically, so it is wise to check if the Docker group exists on Debian.

  1. Open the terminal on your Debian system by pressing the 'Ctrl + Alt + T' keys on your keyboard or by searching for 'Terminal' in the applications menu.

  2. In the terminal run the command 'cat /etc/group | grep 'docker' ' to view the list of all the groups on your system.

Using Docker on Debian

Docker on Debian allows for easily pulling images from Docker Hub, a central repository for developers to share and distribute their images. To pull an image from Docker Hub, use the 'docker pull' command, followed by the image name and the desired tag:

docker pull nginx:latest

After the image is pulled, use it to launch a container, a running instance of an image. To run a container, use the 'docker run' command, followed by the image name:

docker run -d nginx

To stop a container, use the 'docker stop' command, followed by the container ID or name:

docker stop nginx

Note! To find out the container ID, use the 'docker ps' command:

docker ps -q

This command with flag '-q' will only display IDs of all running containers.

To remove containers, use the 'docker rm' command, followed by the container ID or name:

docker rm nginx

Note: Before removing a container it must be stopped.

Note: The docker run command must specify an image reference to create the container from. The image reference is the name and version of the image. Use the image reference to create or run a container based on an image.

docker run nginx:latest

An image tag after : is the image version, in this case the latest one. Use the tag to run a container from a specific version of an image.

Creating and building custom Docker images

Docker on Debian allows for the creation of personalized images tailored to the specific requirements of an application. Dockerfile must be created with instructions for Docker to use while constructing the image. The image foundation is typically Debian, which is customized with necessary configurations and dependencies. This involves package installation, defining environment variables, and transferring files into the image.

After finishing your Dockerfile, use the following command to generate the image (run command below in the same directory where Dockerfile is located):

docker build

A new image will be created based on Dockerfile instructions. Each instruction in the Dockerfile stands for a new layer in the image to quickly restore it in case of any changes.

Ready image can be tagged with a version number or any other identifier if there are multiple versions of an application being used on different environments. Tagged image can be pushed to a Docker Hub to make it available for others.

Networking with Docker on Debian

After you install Docker, using it for networking on Debian facilitates smooth communication between containers and the host machine. Containers are able to seamlessly communicate with each other, using their designated names. Also containers may be connected to multiple networks for even more complex communication configurations.

Docker networking can expose container ports to the host machine for external access to them, making it possible for applications running within to be accessed from the outside. Use the -p flag when running a container, as it maps a port on the host machine to a port on the container:

docker run --name my-nginx -p 8080:80 nginx
  • --name my-nginx sets the container name to my-nginx

  • -p 8080:80 tells Docker to forward port 80 from the container to port 8080 of the host machine

Effective management of Docker networks involves monitoring network traffic, identifying and resolving network issues, and implementing necessary security protocols. Docker Compose and Docker Swarm tools simplify the process of managing and scaling applications across multiple containers and networks.

Data Management with Docker Volumes

Docker volumes are responsible for managing data and its storage in a separate location from the container. This allows the container to access and utilize the data. Volumes act as external directories, separate from the container's file system, that can be accessed and utilized by the container. The data stored in a volume will remain even if the container is stopped or removed, making it particularly valuable for databases that require persistent storage even when the container is not running.

Docker volumes can be generated by the Docker command line interface or with Dockerfile. Each volume is assigned a name and is stored in a designated location on the host system. This approach to managing volumes makes them easier to identify and access. Volumes can be shared among multiple containers to access data by different containers.

Mounting volumes to containers involves linking volumes to containers, enabling them to access and utilize the data stored inside. This can be done dynamically through the Docker CLI during runtime or by specifying it in Dockerfile. This allows for data to be exchanged between the container and the host machine, as well as among multiple containers.

Mastering Docker on Debian

To become a proficient user of Docker on Debian, it is essential to explore its advanced options, such as orchestration for effectively managing and coordinating multiple containers. The use of Docker Swarm, the native orchestration tool, is fully compatible with Debian and enables the creation of highly available and scalable applications. Docker Swarm on Debian allows for the deployment and management of containers across multiple hosts, making it a valuable asset in production environments.

Docker is able to create lightweight and disposable environments, making it easier to set up new machines for development. It is also useful for establishing a consistent and reproducible environment for continuous integration and deployment. In addition, the extensive selection of packages offered by Debian allows users to effortlessly construct customized images tailored to their specific requirements.

Conclusion

Docker is an impressive utility that enables the creation, deployment, and management of applications on Debian. Its versatility, scalability, and effectiveness make it an invaluable resource for developers, system administrators, and businesses alike. With its ever-evolving capabilities and endless potential, we have provided a guide on how to install Docker on Debian. By incorporating Docker into your workflow, you can streamline and optimize your development and deployment process.

The potential of Docker on Debian is constantly expanding as it continues to evolve. One particularly valuable advantage for developers is its ability to create a uniform testing and deployment environment. Through Docker, applications and their necessary components can be bundled into a single image, simplifying the process of reproducing and testing on various systems. This promotes better collaboration among team members, as everyone is operating within the same environment.

By the way, Hostman offers cloud servers starting from just $4 per month, in case you were wondering.

Debian
14.06.2024
Reading time: 10 min

Similar

Debian

How to Install MySQL on Debian

Installing MySQL on Debian effectively creates a robust and flexible database (DB) infrastructure that accommodates a wide range of applications as well as services. It is renowned for its scalability, dependability, and durability. By setting it, individuals experience the operations in an efficient manner and enhance the overall efficiency of DB infrastructure. This combination is especially beneficial for administrators, DB analysts, and industries that demand a dependable database solution for dealing with huge data. Additionally, MySQL's comprehensive guide and supporters help make it simpler to troubleshoot problems and enhance operations.  In this guide, we will demonstrate the thorough procedure for installing and configuring MySQL on Debian. How to Install MySQL on Debian The default repositories do not contain the MySQL database server package on Debian. To install it on a  Linux system follow the below instructions. We will download the recent version of the MySQL. Step 1: Download MySQL Package Let us obtain the MySQL repository information package, which is in the .deb format: wget https://dev.mysql.com/get/mysql-apt-config_0.8.30-1_all.deb Note: To authenticate the most updated release, go to the MySQL repository webpage. Step 2: MySQL Configuration Package Installation Then, employ the .deb file for initializing the installation via dpkg: sudo dpkg -i mysql-apt-config_0.8.30-1_all.deb Respond to the prompt. For instance, pick MySQL Server & Cluster and hit Enter for starting configurations: For picking a version such as (mysql-8.4-lts), scroll downward and hit OK for the next step: Step 3: Refresh the System Now, update the server's package indexes to implement the updated MySQL info: sudo apt update Step 4: MySQL Installation Debian's default manager makes sure to install MySQL in an easier manner. Installing the package with this command: sudo apt install mysql-server -y You will see the interface for setting the root account. Input a stronger password to secure the database. In the end, hit the Ok button: Check the version on the server via the --version utility: mysql --version Step 5: Managing the Services Now, you can enable the MySQL service to initialize automatically at boot time: sudo systemctl enable mysql Activate the service via the systemctl utility: sudo systemctl start mysql Check if the system service is operational by viewing its status: sudo systemctl status mysql Step 6: MySQL Secure Installation The key or password that the individual created at the initialising procedure is currently protecting the root DB user on the server. MySQL also includes other insecure defaults, such as remote access to test databases and the root database user on the server.  It is vital to secure the MySQL installation after it has been completed as well as disable all unsafe default settings. There is a security script that can assist us in this procedure. Run the script: sudo mysql_secure_installation To activate the VALIDATE PASSWORD component and guarantee stringent password procedures, type Y and hit Enter. Next, you will need to configure several security settings: Set the Root Password: Select a strong password and make sure that it is correct. Configure the password policy for the DB server. For instance, type 2 to permit only the strong passwords on the server and hit Enter. When required to modify the root password, input N; alternatively, input Y to modify the password. Eliminate Anonymous Users: It is advised to eliminate the accessibility of anonymous users. For this, input Y and Enter when prompted. Prevent Accessibility of Remote Root: It is a better practice to avoid remote root login for multiple security concerns. To prevent the root user from having a remote access, input Y and hit Enter. Delete the Test DB: For enhancing security, the test database, which is utilized for testing, can be deleted. To do so, input Y and hit Enter. Refreshing Privilege Tables: It guarantees that all modifications are implemented instantly. To implement the configuration and edit the privileges table, hit Enter. Step 7: Access MySQL Utilizing the mysql client utility, MySQL establishes the connection and provides access to the database server console.  Now, access the shell interface and run general statements on the DB server. Let’s input the root and the password created at the time of the safe installation procedure: sudo mysql -u root -p Step 8: Basic MySQL Operations The creation of a DB and a new user for your applications rather than utilizing the root is a better practice. To accomplish the task, employ the given instructions: Create a Database: First, create a database. For instance, hostmandb is created via the below command: CREATE DATABASE hostmandb; Display All Databases: List all databases to make sure hostmandb is created: SHOW DATABASES; Create of a New User: Create a user and assign a strong password. In our example, we set Qwer@1234 as a password for the user  minhal. Replace these values with your data. CREATE USER 'minhal'@'localhost' IDENTIFIED BY 'Qwer@1234'; Give Permissions to the User: Give complete access to the hostmandb to the new user: GRANT ALL PRIVILEGES ON hostmandb.* TO 'minhal'@'localhost'; Flush Privileges: To implement the modifications, refresh the table: FLUSH PRIVILEGES; Exit the Shell: For closing the interface, utilize the EXIT statement: EXIT; Access MySQL Console as the Particular User For the purpose of testing hostmandb access, log in to MySQL as the new user, in our case minhal. sudo mysql -u minhal -p It accesses the console after entering the minhal user password when prompted: For verification, display all DBs and confirm that the hostmandb is available: SHOW DATABASES; Step 9: Configuration for Remote Access Setting up the server for supporting remote accessibility is necessary if an individual is required to access MySQL remotely. Follow these steps: Access the mysql.cnf file and modify the particular file for MySQL: sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf Look for the line with the bind-address and change it to: bind-address = 0.0.0.0 Reload the MySQL service: sudo systemctl restart mysql Permit the user to have remote access: sudo mysql -u root -p GRANT ALL PRIVILEGES ON hostmandb.* TO 'minhal'@'localhost';FLUSH PRIVILEGES;EXIT; Step 10: Firewall Configuration If you have a firewall activated, you need to open the MySQL port 3306 to traffic. Set up the firewall following the below steps: Allow traffic through MySQL: sudo ufw allow mysql Now, activate the UFW on the system: sudo ufw enable Reload the firewall: sudo ufw reload Step 11: Restore and Backup Maintaining regular backups is crucial to avoiding data loss. The mysqldump utility is provided by MySQL for backup creation. To achieve this, consider these instructions: Backup a Single Database: This command employs mysqldump to create the backup of the hostmandb as a hostmandb_backup.sql file: sudo mysqldump -u root -p hostmandb> hostmandb_backup.sql Backup All Databases: For creating a backup of all databases as a file named all_databases_backup.sql with root privileges, utilize mysqldump: sudo mysqldump -u root -p --all-databases > all_databases_backup.sql Restore a Particular Database: Now, restore the hostmandb from the backup file hostmandb_backup.sql: sudo mysql -u root -p hostmandb < hostmandb_backup.sql Step 12: Optimize MySQL Operations (Optional) Depending on the workload and server resources, you can adjust settings to guarantee peak performance. These instructions will help you maximize MySQL's speed: Adjust InnoDB Buffer Pool Size: Caches for data and indexes are kept in the InnoDB buffer pool. Expanding its size can enhance its functionality. Edit the MySQL configuration file: sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf The below line should be added or changed: innodb_buffer_pool_size = 1G Its size should be adjusted according to the amount of memory on the server. Enable Query Cache: The query cache stores the outcome of SELECT queries. Enabling it can enhance operations for repetitive queries. Modify the .cnf file: sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf Add or edit the below lines: query_cache_type = 1query_cache_size = 64M Optimize Table Structure: Frequently optimize your customers table in hostmandb to recover wasted space and boost efficiency: USE hostmandb;OPTIMIZE TABLE customers; Analyze Operations: DB operations can be tracked and analyzed with tools like MySQL Workbench and mysqltuner. Using the command below, install mysqltuner: sudo apt install mysqltuner Run mysqltuner to get performance recommendations: sudo mysqltuner Conclusion Installing a MySQL environment is important in today's digital world. By following this instruction, you'll be able to safely install and connect to your MySQL database. This strategy not only increases security but also improves remote database maintenance efficiency. It helps to prevent breaches and ensures the confidentiality of your data. This article has given thorough instructions for the installation of MySQL's database environment on Debian. It is suggested that MySQL servers should be regularly monitored and optimized to guarantee optimum performance and dependability. In addition, Hostman offers pre-configured and ready-to-use cloud databases, including cloud MySQL. 
14 January 2025 · 8 min to read
Debian

How to Install the Latest Static Build of FFmpeg on Debian

FFmpeg is a powerful multimedia framework capable of decoding, encoding, transcoding, muxing, demuxing, streaming, filtering, and playing virtually any media file format. Given its extensive utility in media processing, having the latest version of FFmpeg installed on your Debian system is essential. This guide walks through the process of installing the latest static build of FFmpeg on Debian, ensuring that you have access to the most up-to-date features and performance improvements. Prerequisites Before beginning the installation, ensure that your system meets the following requirements: A Debian-based distribution (e.g., Debian, Ubuntu) Access to a terminal with root or sudo privileges Basic understanding of the Linux command line Installing FFmpeg Downloading the Latest Static Build To get started, you need to download the latest static build of FFmpeg. This version is precompiled, making it a hassle-free option that requires no additional dependencies. 1. Open your terminal. 2. Navigate to the /usr/local/bin directory where you will store the FFmpeg binaries:   cd /usr/local/bin 3. Download the latest static build of FFmpeg using wget. You can find the latest release on the FFmpeg official website. Use the following command to download the tarball: wget https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-i686-static.tar.xz Make sure to replace the URL with the latest version's link if a newer release is available. Extracting the Archive Once the download is complete, you need to extract the tarball to access the FFmpeg binaries. 1. Extract the downloaded archive using the tar command: tar -xvf ffmpeg-release-i686-static.tar.xz 2. List the contents of the extracted directory to verify that the extraction was successful: ls ffmpeg-*-static You should see the FFmpeg binary files listed in the directory. Moving FFmpeg to a System Path To make FFmpeg accessible from any location in your terminal, you need to move it to a system path. 1. Move the FFmpeg binaries to /usr/local/bin: sudo mv ffmpeg-*-static/ffmpeg /usr/local/bin/sudo mv ffmpeg-*-static/ffprobe /usr/local/bin/ 2. Grant execution permissions to the binaries: sudo chmod +x /usr/local/bin/ffmpegsudo chmod +x /usr/local/bin/ffprobe Verifying the FFmpeg Installation To confirm that FFmpeg is installed correctly and is functioning as expected, you can check its version. 1. Run the following command to verify the installation: ffmpeg -version 2. You should see an output similar to this, displaying the FFmpeg version and configuration details: If you see the FFmpeg version listed, the installation was successful. Updating FFmpeg When new versions of FFmpeg are released, it's a good practice to update your installation to benefit from the latest improvements and features. 1. Navigate to /usr/local/bin: cd /usr/local/bin 2. Remove the old FFmpeg binaries: sudo rm ffmpeg ffprobe 3. Download and extract the latest version using the steps mentioned in the "Downloading the Latest Static Build of FFmpeg" and "Extracting the Archive" sections. 4. Move the new binaries to /usr/local/bin and set the execution permissions as detailed in the "Moving FFmpeg to a System Path" section. Common Usage Examples FFmpeg is highly versatile, and there are countless ways to use it. Here are a few common examples: Converting a Video Format Convert a video from MP4 to AVI: ffmpeg -i input.mp4 output.avi Extracting Audio from a Video Extract the audio from a video file and save it as an MP3: ffmpeg -i input.mp4 -q:a 0 -map a output.mp3 Cutting a Video Segment Cut a segment from a video between the 00:01:00 and 00:02:00 marks: ffmpeg -i input.mp4 -ss 00:01:00 -to 00:02:00 -c copy output.mp4 Compressing a Video Reduce the file size of a video: ffmpeg -i input.mp4 -vcodec h264 -acodec mp2 output.mp4 Troubleshooting Common Issues FFmpeg Command Not Found If you encounter the error ffmpeg: command not found, it likely means that FFmpeg isn’t in your system’s path. Ensure that you moved the binaries to /usr/local/bin and that they have the correct execution permissions. Unsupported Codec or Format If FFmpeg returns an error regarding unsupported codecs or formats, you may need to recompile FFmpeg with additional libraries or use precompiled binaries that include the necessary support. Conclusion Installing the latest static build of FFmpeg on Debian ensures you have the most recent features and optimizations without the need for compiling from source. By following this guide, you’ve set up FFmpeg, verified its installation, and explored some common uses. With this powerful tool at your disposal, you can handle a wide range of multimedia tasks efficiently.
20 August 2024 · 4 min to read
Debian

Installing Debian on Ubuntu via VirtualBox

In the world of Linux distributions, the connection between Debian and Ubuntu is a remarkable combination of reliability, variety, and use. While both Debian and Ubuntu are capable operating systems in their own right, the ability to install Debian atop Ubuntu opens up a world of possibilities, providing users with a distinct set of features and benefits that distinguish it from other solutions. In this article, deep dive into how to install Debian on Ubuntu and how the two well-known distributions work together seamlessly. Discover the benefits and advantages of this hybrid architecture, which provides users with unrivaled customization, software diversity, and system reliability. Prerequisites System running in Ubuntu User with Root access on the terminal At least 10GB disk space (recommended 20GB) At least 512 GB RAM (recommended 4GB) Debian ISO file (will be described below) VirtualBox (will be described below) Once all requirements are met, proceed with installation. Installing VirtualBox Install VirtualBox on Ubuntu. Access the terminal and update the package index. sudo apt-get update Run the below command to install and type yes or y to proceed. sudo apt-get install virtualbox Check if installation was successful by running the command: sudo dpkg -l virtualbox Or login to Ubuntu Desktop and look for VirtualBox on the application search box. After successful installation of VirtualBox, it is now ready to install Debian. Installing Debian with VirtualBox To install Debian, follow the instruction below: Download the Debian ISO file on official website of Debian: https://cdimage.debian.org/debian-cd/current/amd64/iso-dvd/. Wait for download to finish. Launch the VirtualBox and click New. Create the Debian machine and name it. Allocate the required memory and click Next. Select the hard disk file type and click Next. Choose if the hard disk is dynamically or fixed sized then click Next. Allocate the required size of disk and click Create. Validate details and click start to proceed with installation. Locate the Debian ISO file that has been downloaded on the previous step. Select your Debian ISO file. Click Start. Follow the instruction prompt. Reply to the system's prompts such as selecting the language and location. Wait for the installation to complete. Once done, it will look like below.  Debian installation is successful. Conclusion As technology advances and user expectations increase, Debian and Ubuntu's collaboration paves the road for open-source innovation and excellence. Embracing this synergy not only improves individual users' capacities, but it also adds to the global advancement of Linux-based solutions. Hostman allows you to launch a server for as low as $4 per month, in case you were wondering.
29 March 2024 · 3 min to read

Do you have questions,
comments, or concerns?

Our professionals are available to assist you at any moment,
whether you need help or are just unsure of where to start.
Email us
Hostman's Support