How to Install and Secure MariaDB Database on Debian 11

This tutorial teaches how to install MariaDB database on Debian 11 "Bullseye" from the official Debian repository.

The article also shows you how to secure MariaDB, add an admin user, and connect to the database management system from the command line.

MariaDB is an open-source RDBMS (Relational Database Management System), backward compatible, binary drop-in replacement of MySQL. It is being developed by several of MySQL’s original developers and many community members.

Compared to MySQL, MariaDB provides improved performance with faster replication speeds, tighter security measures, and additional storage engines.

With MariaDB Server as the default in Debian, it’s included in the Stable repository for Debian 11 and available to all users. Being the default means that MariaDB Server is part of Debian’s Stable repository and built by the Debian build system on all possible platforms.

Step 1: Update System Packages

Ensure that you are running the latest system packages before installation to avoid possible inconveniences with dependencies.

sudo apt update
sudo apt upgrade

Step 2: Installing MariaDB Server on Debian 11

The most recommended method for installing MariaDB on Debian is to use the default package manager for Debian 11. The MariaDB packages are available under the official repositories. Therefore, you can directly install it without adding extra repositories to your system.

To install MariaDB on Debian 11, execute the below-mentioned command:

sudo apt install mariadb-server
Installing MariaDB on Debian 11

Note that the command above will install MariaDB but will not ask you to create a password or modify any other settings.

Step 3: Testing MariaDB

MariaDB should start automatically after being installed from the default repositories. To test this, check its status.

sudo systemctl status mariadb
Testing the MariaDB Service Status

Step 4: Securing the MariaDB Server

Next, we’ll use a script (mysql_secure_installation) provided by the mariadb-server package to restrict access to the server and remove unused accounts because the default setup makes your MariaDB installation unsafe.

sudo mysql_secure_installation

After running the above command, you will be prompted to enter the MariaDB root password. Just leave the root password empty, and hit Enter. For the rest, enter “Y” and hit “Enter.”

Securing MariaDB Installation on Debian

Step 5: Create Privileged User with Authentication

The root MariaDB user on Debian is configured to authenticate using the unix_socket plugin rather than a password by default. Using unix_socket means that if you are the system root user, you can log in as root on localhost without a password.

It is based on the simple truth that asking for a password from the system root provides no additional protection because the root already has complete access to all data files and processes.

The Debian package maintainers recommend creating a separate administrative account for password-based access. So, we’ll create a new admin account with the same privileges as the root account, but with password authentication enabled.

First, to create a new user, you need to login into MariaDB as a root user using the following command:

sudo mysql

Now that you have logged into the MariaDB shell go ahead and create a new administrative user called admin with a password in the MariaDB server.

CREATE USER 'admin'@'localhost' IDENTIFIED BY 'your_password_here';Code language: JavaScript (javascript)

Next, to grant the newly created user the same privileges as the MariaDB root user, use the following command:

GRANT ALL ON *.* TO 'admin'@'localhost' WITH GRANT OPTION;Code language: JavaScript (javascript)

Finally, reload the privileges to ensure they are saved and exit the MariaDB shell.

FLUSH PRIVILEGES;
exitCode language: PHP (php)
Creating Admin User Account

Step 6: Connecting to MariaDB Database Server

To access the MariaDB shell using the credentials you created in the previous step, you have to execute:

mysql -u admin -p

You will be prompted to enter the MariaDB admin user password, after which you can access your MariaDB server.

Connecting to the MariaDB Server Installed on Debian 11

Conclusion

In this guide, you installed the MariaDB database server on Debian 11. Moreover, during the installation process, you secured the server through the mysql_secure_installation script and created a new administrative user.

Once you’ve completed the setup, you can begin managing and storing data. The concepts covered in this article should give you a solid start to learning more.

For more information about MySQL databases, see the official MariaDB documentation. If you have any questions or feedback, feel free to leave a comment.

Bobby Borisov

Bobby Borisov

Bobby, an editor-in-chief at Linuxiac, is a Linux professional with over 20 years of experience. With a strong focus on Linux and open-source software, he has worked as a Senior Linux System Administrator, Software Developer, and DevOps Engineer for small and large multinational companies.