Fork me on GitHub

Docker安装配置mysql

Docker安装mysql踩坑日记

  • 拉取镜像

sudo docker pull mysql:5.7

  • 运行镜像
docker run -p 3306:3306 --name mysql -v /mydata/mysql/log:/var/log/mysql -v	/mydata/mysql/data:/var/lib/mysql -v /mydata/mysql/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7

  • 如果有问题尝试下面方式运行:
    docker run -itd --name msyql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=ROOT -d mysql:5.7

  • 解决 docker分组问题

    • 查看docker所属组

sudo cat /etc/group | grep docker

  • 将当前成员加入组
    • 将当前成员加入组
sudo gpasswd -a ubuntu docker 

sudo systemctl restart docker

解决进入容器内部失败的问题

docker ps -a # 查看id

docker start [id]  # 启动实例

数据库远程连接

参数说明

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

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

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

2. 设置远程登录

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;

然后就可以使用 GUI工具 连接数据库了。

posted @ 2021-04-22 01:02  Noir-  阅读(81)  评论(0编辑  收藏  举报