Ubuntu 20.04 设置mysql phpmyadmin root 密码

Posted

技术标签:

【中文标题】Ubuntu 20.04 设置mysql phpmyadmin root 密码【英文标题】:Ubuntu 20.04 set mysql phpmyadmin root password 【发布时间】:2020-08-09 07:47:34 【问题描述】:

我在 Ubuntu 20.04 上安装了 LAMP。

(德语) https://wiki.ubuntuusers.de/mysql/Werkzeuge/

获取root密码登录localhost/phpmyadmin总是一个问题。在 Ubuntu 18.04 中有一个很好的教程(几个):

SERVER BEENDEN:
  sudo service mysql stop
  sudo mkdir -p /var/run/mysqld
  sudo chown mysql:mysql /var/run/mysqld
  sudo /usr/sbin/mysqld --skip-grant-tables --skip-networking &
PRÜFEN MIT:
  jobs
STARTEN von MYSQL:
  mysql -u root
    mysql> FLUSH PRIVILEGES;
    mysql> USE mysql; 
    mysql> UPDATE user SET authentication_string=PASSWORD("NEWPASSWORD") WHERE user='root';
    mysql> UPDATE user SET plugin="mysql_native_password" WHERE User='root';
    mysql> quit
  sudo pkill mysqld
  sudo service mysql start

在实际的 ubuntu 版本中,似乎不知道 PASSWORD 命令。我收到以下错误。

mysql> UPDATE user SET authentication_string=password('YOURNEWPASSWORD') WHERE user='root';

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的 '('YOURNEWPASSWORD') WHERE user='root'' 附近使用正确的语法

我的mysql版本:

mysql Ver 8.0.19-0ubuntu5 for Linux on x86_64 ((Ubuntu))

【问题讨论】:

【参考方案1】:

这个谜题有几个部分

更改密码

从 CLI 以 root 身份登录:

sudo mysql -u root -p

然后

ALTER USER 'root'@'localhost' IDENTIFIED BY '<New-Password-Here>';

真正让事情发挥作用

From phpmyadmin.net

由于 MySQL 身份验证方法的更改,7.4 之前的 PHP 版本无法通过 MySQL 8.0 进行身份验证 blah blah blah https://bugs.php.net/bug.php?id=76243。

有一个解决方法,就是将您的用户帐户设置为使用当前样式的密码哈希方法 mysql_native_password。 这种不幸的缺乏协调导致不兼容影响所有 PHP 应用程序,而不仅仅是 phpMyAdmin。

所以

UPDATE user SET plugin="mysql_native_password" WHERE user='root';

真正让事情发挥作用......真的

MySQL 已更改其安全模型,root 登录现在需要 sudo。这对 CLI 来说没问题,但这意味着 PhpMyAdmin 和所有其他客户端将无法使用 root 凭据

最好的解决方案是为 PhpMyAdmin 创建一个新用户(或使用现有用户,如果它是在安装期间创建的)并授予它所需的权限。

CREATE USER 'phpmyadmin'@'localhost' IDENTIFIED BY '<New-Password-Here>';
GRANT ALL PRIVILEGES ON *.* TO 'phpmyadmin'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;

在您希望 “root” 访问的任何地方使用此用户。


还要确保您使用的是最新版本的 PHP。这是我的完整安装脚本

PHP

sudo apt install -y php7.4
sudo apt install php7.4-curl php7.4-gd php7.4-json php7.4-mbstring php7.4-xml

APACHE

sudo apt install apache2 libapache2-mod-php7.4

MYSQL

sudo apt install mysql-server php7.4-mysql
sudo mysql_secure_installation

PHPMYADMIN

sudo apt install phpmyadmin

【讨论】:

以上是关于Ubuntu 20.04 设置mysql phpmyadmin root 密码的主要内容,如果未能解决你的问题,请参考以下文章

Ubuntu20.04下安装并使用MySQL8.0

在 Ubuntu 20.04 上安装 MySQL 5.6

Ubuntu20.04安装Mysql

Ubuntu 20.04安装mysql 5.7

无法重新启动 mysql.service:从 18.4 升级后,单元 mysql.service 在 Ubuntu 20.04 中被屏蔽

UBUNTU 20.04 docker部署 企业级开源局域网IP地址管理系统 Phpipam系统安装设置