MariaDB закрываем доступ

Вангую, что при запуске клиента mysql под системным пользователем root, и при указании логина -u root, он по умолчанию соединяется только через UNIX Sockets, и не проверяет пароль, даже если он есть и/или указан. И да, он тебя не пустит по-другому (например через IPv4 localhost), даже если укажешь правильный пароль.

В общем, я подумал и решил выложить, что надо сделать, чтобы ввод пароля работал (мне понадобилось, при установке кое-какого софта). Может, и самому понадобится. Ссылки не привожу, очень долго искал, по разным местам собирая инфу.

Смотри:
# mysql -u root
use mysql;
update user set password=PASSWORD("megapsswd") where User='root';
flush privileges;
update user set plugin='' where User='root';
quit;
# systemctl restart mariadb
Вернуть обратно так:
# mysql -u root -p
Enter password: 
( вводим пароль my-new-cool-password )
MariaDB [(none)]> use mysql;
Database changed
MariaDB [mysql]> update user set plugin='unix_socket' where User='root';
MariaDB [mysql]> quit;
Bye
# systemctl restart mariadb
Проверяем вход root без пароля:
# mysql -u root
MariaDB [(none)]> quit;
Bye

По смыслу уберешь в коде изменение пароля. Проверено на Debian GNU/Linux 9 AMD64.