docker安裝MySQL5.7示例!!坑,ERROR 1045 (28000): Access denied for user


docker  pull  mysql拉取鏡像

啟動mysql需要做端口映射 -p

其他幾個高級操作:

Docker安裝mysql5.7報錯 ERROR 1045 (28000): Access denied for user

【tips】docker安裝MySQL5.7ERROR 1045 (28000): Access denied for user解決辦法

進入mysql報錯:1045(28000), 原因:mysql5.7 首次安裝后,需要修改root的默認密碼才能使用。

為了解決這個問題,來來回回試了很多遍,這里就不說過程了,下面記錄下目前看正確的處理步驟:

docker安裝Mysql

1 docker拉取mysql版本:

docker pull mysql:5.7.23

2 創建掛載目錄:

mkdir /usr/local/mysql

用於掛載mysql數據文件

mkdir /usr/local/mysql/data

用於掛載mysql配置文件

mkdir /usr/local/mysql/conf.d

3 啟動容器

命令:

docker run --name mysql5.7 -p 3306:3306 -v /usr/local/mysql/data:/var/lib/mysql -v /usr/local/mysql/conf.d:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=rootroot -d mysql:5.7.23

注意: -e MYSQL_ROOT_PASSWORD 這里==敲錯了==,后面就是為了解決不知道root密碼情況下怎么處理。

處理mysql 1045報錯

1 在 /usr/local/mysql/conf.d目錄下增加文件: my.cnf

文件內容為:

[mysqld]
skip-grant-tables

2 重啟mysql:

docker restart mysql5.7

3進入docker的bash:

docker exec -it mysql5.7 bash

4登錄mysql:

mysql -uroot -p

5設置root密碼為空,注意root密碼是加密的,設置其它值不好找到對應的明文。

use mysql;

select user,authentication_string,host from user;

//更新為空

update user set authentication_string='' where user='root';

flush privileges;

6 退出mysql,把第一步的skip-grant-tables注釋。再重啟mysql

7 使用 root用戶,密碼 回車鍵登錄;

8 修改root密碼:

alter user 'root'@'localhost' IDENTIFIED BY 'rootroot';

alter user 'root'@'%' IDENTIFIED BY 'rootroot';

flush privileges;

修改root密碼完成。

9 可附加一步授權:

GRANT all ON . TO 'root'@'%' IDENTIFIED BY 'rootroot' ;

flush privileges;


【注意】

8的兩個alter其中第二個alter報錯,正常

9的授權改為grant all on *.* to root@'%' identified by  'rootroot'  with grant option;

 

 終於好了...

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM