前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Docker 中创建 mysql 容器,并设置远程连接

Docker 中创建 mysql 容器,并设置远程连接

作者头像
张云飞Vir
发布2020-05-26 22:02:19
发布2020-05-26 22:02:19
12.2K00
代码可运行
举报
文章被收录于专栏:写代码和思考写代码和思考
运行总次数:0
代码可运行

0. 背景

Docker 中创建 mysql 容器

1.创建MySQL容器

代码语言:javascript
代码运行次数:0
运行
复制
  docker run -di --name mysql -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

-p 代表端口映射,格式为 宿主机映射端口:容器运行端口 -e 代表添加环境变量 MYSQL_ROOT_PASSWORD是root用户的登陆密码

可能遇到的问题 这个时候使用客户端连接工具连接的话,会遇到: Client does not support authentication protocol 的错误。

解决办法是设置远程登录,让我们继续。

2. 设置远程登录

2.1 进入MySQL容器,登陆MySQL

代码语言:javascript
代码运行次数:0
运行
复制
  docker exec -it mysql /bin/bash

2.2 登陆mysql**

代码语言:javascript
代码运行次数:0
运行
复制
  mysql -u root -p

2.3 输入密码

这个时候会提示输入密码,输入即可。

2.4 进行授权远程连接授权

代码语言:javascript
代码运行次数:0
运行
复制
GRANT ALL ON *.* TO 'root'@'%';

刷新权限

代码语言:javascript
代码运行次数:0
运行
复制
flush privileges

注意,这时还不能远程访问 因为Navicat只支持旧版本的加密,需要更改mysql的加密规则

2.5 更改加密规则

代码语言:javascript
代码运行次数:0
运行
复制
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;

更新root用户密码

代码语言:javascript
代码运行次数:0
运行
复制
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

刷新权限

代码语言:javascript
代码运行次数:0
运行
复制
flush privileges;

然后就可以使用 Navicat 连接数据库了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0. 背景
  • 1.创建MySQL容器
  • 2. 设置远程登录
    • 2.1 进入MySQL容器,登陆MySQL
    • 2.2 登陆mysql**
    • 2.3 输入密码
    • 2.4 进行授权远程连接授权
    • 2.5 更改加密规则
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档