完美解决docker安装mysql后Navicat连接不上的问题⼀、docker拉取镜像
docker pull mysql (默认拉取最新版本的)
⼆、运⾏mysql
docker run -p 3308:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
容器名:mysql 密码:123456
三、查看是否运⾏自学编程怎么入门零基础学
docker ps -a
四、查看启动⽇志
docker logs mysql
vip音乐解析源码mysql就是刚刚启动的容器名,确认mysql启动是正常的免费网站程序
五、错误
当我⽤Navicat进⾏链接的时候,发现下图错误
我们需要下⾯的处理⽅式
1、进⼊mysql客户端
docker exec -it c6c8e8e7940f /bin/bash
其中c6c8e8e7940f是我的mysql的容器名
----等价命令 docker exec -it mysql /bin/bash
mysql -u root -p123456
123456就是mysql的登录密码,在docker run的时候设置的
2、查看⽤户信息
select host,user,plugin,authentication_string from mysql.user;
3、重新设置密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'newpassword'
newpassword就是新的密码
我把密码设置成了‘mysql'
4、使⽤Navicat重新连接
附:也能是防⽕墙的问题
sudo firewall-cmd --add-port=3306/tcp (放开3306的端⼝)
或者
sudo systemctl stop firewalld (关闭防⽕墙)
补充:docker安装mysql 8 并配置远程连接
第⼀步:下载mysql镜像镜像
docker pull mysql
默认是下载最新稳定版
第⼆步:启动mysql镜像
linux命令记不住
docker run --name dockermysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=mysqlpassword -d mysql
1、--name 是镜像的别名
2、-p 将3306映射到3306(docker是个虚拟机有⾃⼰的端⼝)
3、-e MYSQL_ROOT_PASSWORD=mysqlpassword 设置mysql 服务器密码(后⾯需要,⼀定记住)
4、-d 后端启动
5、启动的镜像名称(可以⽤id代替)
第三步:查询启动的镜像
docker ps
如下:
第四步:进⼊容器
docker exec -it dockermysql bash
dockermysql是镜像的名字,可以⽤id替代
第五步:登录mysql
mysql -u root -p
然后输⼊上⾯设置的密码
第六步:设置远程访问
切换数据库(默认应该就是这个,不切换也⾏,保险起见切换⼀下)
use mysql;
更改远程链接授权java的抽象类详解
grant all privileges on *.* to 'root'@'%';
第七步:navicat链接时报 2059 错误mysql无法连接到服务器
报错原因是加密⽅式问题
查询⼀下:
select Host,User,plugin from user;
没有修改前结果如下:
执⾏修改命令:
alter user 'root'@'%' identified with mysql_native_password by 'yourPassword';
修改成你的mysql密码
修改成功后结果如下:
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。如有错误或未考虑完全的地⽅,望不吝赐教。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。