python

Docker 中创建 mysql 容器,并设置远程连接 - 云+社区 - 腾讯云

文章暂存

systemime
2021-05-30
2 min

摘要.

Docker 中创建 mysql 容器

docker run --name my-mysql8 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:laster

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

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

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

# 2.1 进入 MySQL 容器, 登陆 MySQL

  docker exec \-it mysql /bin/bash

# 2.2 登陆 mysql**

  mysql \-u root \-p

# 2.3 输入密码

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

# 2.4 进行授权远程连接授权

GRANT ALL ON \*.\* TO 'root'@'%';

刷新权限

flush privileges

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

# 2.5 更改加密规则

ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;

更新 root 用户密码

ALTER USER 'root'@'%' IDENTIFIED WITH mysql\_native\_password BY '123456';

刷新权限

flush privileges;

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。 https://cloud.tencent.com/developer/article/1633614

上次编辑于: 6/5/2021, 11:41:57 AM