docker部署mysql如何访问(完美解决docker安装mysql后Navicat连接不上的问题)
类别:服务器 浏览量:2868
时间:2021-10-20 08:38:15 docker部署mysql如何访问
完美解决docker安装mysql后Navicat连接不上的问题一、docker拉取镜像docker pull mysql (默认拉取最新版本的)
二、运行mysqldocker run -p 3308:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
容器名:mysql 密码:123456
三、查看是否运行docker ps -a
四、查看启动日志
docker logs mysql
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镜像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替代
第五步:登录mysqlmysql -u root -p
然后输入上面设置的密码
第六步:设置远程访问切换数据库(默认应该就是这个,不切换也行,保险起见切换一下)
use mysql;
更改远程链接授权
grant all privileges on *.* to 'root'@'%';
报错原因是加密方式问题
查询一下:
select Host,User,plugin from user;
没有修改前结果如下:
执行修改命令:
alter user 'root'@'%' identified with mysql_native_password by 'yourPassword';
修改成你的mysql密码
修改成功后结果如下:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣
- docker安装详细教程linux(linux中docker的安装教程)
- docker如何搭建mysql(docker容器访问宿主机的MySQL操作)
- docker是k8s 编排必备容器工具(Docker部署ELK7.3.0日志收集服务最佳实践)
- docker保存容器的配置文件(docker cp 拷贝文件 和 进入容器的操作)
- docker测试环境搭建(docker环境搭建JMeter+Grafana+influxdb可视化性能监控平台的教程)
- docker 部署参数配置(Docker搭建Redis5.0并挂载数据)
- windows docker 使用数据库教程(docker安装并持久化postgresql数据库的操作步骤)
- docker常用命令详解(docker常用命令总结推荐)
- docker 部署springboot项目(Spring Boot Docker打包工具小结)
- volume怎么添加docker(docker volume删除卷的操作)
- docker自动执行镜像(docker实现重新打tag并删除原tag的镜像)
- OpenLDAP docker使用教程(Docker搭建OpenLDAP+phpLDAPadmin统一用户认证的方法)
- docker启动命令大全(Docker常用命令Study03详解)
- docker中的mongodb(Docker mongoDB 4.2.1 安装并收集springboot日志的步骤详解)
- docker执行shell脚本(基于Docker搭建ELK 日志系统的方法)
- docker镜像如何打包(Docker打包镜像及修改配置的实现)
- 中华第一楷 张瑞龄 86岁高龄,苦练楷书71年,一幅字卖593万(中华第一楷张瑞龄)
- 冯骥才 年意(冯骥才年意)
- ()
- 百事大吉蓝底 绿底手机高清壁纸(绿底手机高清壁纸)
- 蓝底证件照怎么制作 证件照换底色 换尺寸快速搞定(蓝底证件照怎么制作)
- 你喜欢足球吗 足球如何点亮世界的(足球如何点亮世界的)
热门推荐
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9