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;

終於好了...