08.12.2025

How to Reset MySQL and MariaDB Root Password on Ubuntu 20.04 LTS - Step-by-Step Guide

MySQL and MariaDB rank among the most popular relational database management systems (RDBMS) for managing SQL-based databases.They are commonly used in a variety of environments — from powering dynamic websites and web applications to supporting machine learning pipelines, data analytics platforms, and software development projects.
Thanks to their speed, reliability, and open-source nature, both systems remain a top choice for developers and system administrators worldwide.

Why password reset may be needed

The reasons are obvious - current password may be "dropped" after database service upgrade, you can accidentally forget it, your personal passwords storage could be lost etc.

Resetting the Root Password in MySQL and MariaDB

To set new database service root password (it is NOT "built-in" system root!) please follow rurther steps:

Login to your server as privileged user;

Stop the service;

service mysql stop # for MySQL
service mariadb stop # for MariaDB

Allow temporary "passwordless" authentication and start the service:

cat << EOF >> /etc/mysql/my.cnf
[mysqld]
skip-grant-tables
EOF
service mysql start

Authenticate into the database service and set the new password:

mysql
FLUSH PRIVILEGES;
ALTER USER 'root'@'localhost' IDENTIFIED BY 'NewStr0ngPassword';
exit

Remove skip-grant-tables directive from configuration file and restart the service:

service mysql stop; sed -i -e '$d' /etc/mysql/my.cnf && sed -i -e '$d' /etc/mysql/my.cnf; service mysql start

NOTE: I run sed -i -e '$d' twice cause need to delete two last file rows.

Checking and tuning

To check the result just run:

mysql -uroot -p<your_new_password>

As you see, authorization is successful. To make your further life more comfortable, it is possible to save this password to the special file in your home directory. It will allow you to authenticate without typing password each time:

cat << EOF >> ~/.my.cnf

[client]
user = root
password = <your_new_password>
EOF

All in all

Now you are familiar with the process of resetting the root password for MySQL or MariaDB, the common reasons this may be required, and techniques to simplify daily authentication. Regularly reviewing and updating your database credentials is a key part of maintaining a secure environment, especially after service upgrades or administrative changes.

To make ongoing management easier, consider storing credentials securely in a .my.cnf file with proper permissions or using a trusted password manager designed for database accounts. Additionally, always verify that services like MySQL or MariaDB are running correctly after changes, and keep backups of critical configuration files. Implementing these practices not only prevents accidental lockouts but also strengthens your overall database security and reliability for both development and production environments.

FAQ: Resetting Root Password in MySQL and MariaDB