当前位置: 移动技术网 > IT编程>数据库>Mysql > Docker 安装 MySQL 并实现远程连接教程

Docker 安装 MySQL 并实现远程连接教程

2020年09月02日  | 移动技术网IT编程  | 我要评论
拉取镜像docker pull mysql查看拉取完成的镜像docker images通过镜像创建并启动一个mysql容器docker run --name mysql_dev -e mysql_ro

拉取镜像

docker pull mysql

查看拉取完成的镜像

docker images

通过镜像创建并启动一个mysql容器

docker run --name mysql_dev -e mysql_root_password=123456 -p 3333:3306 -d mysql

–name:给新创建的容器命名,此处命名为 mysql_dev
-e:配置信息,此处配置mysql的root用户的登陆密码
-p:端口映射,此处映射主机3333端口到容器mysql_dev的3306端口
-d:成功启动容器后输出容器的完整id\最后一个mysql指的是mysql镜像名字

此时,用navicat for mysql连接mysql发现报错:
client does not support authentication protocol requested by server。。。
解决再最下面 ^ _ ^

查看安装的所有容器

docker ps -a

查看启动中的容器

docker ps

暂停/启动容器中的服务

docker stop mysql_dev
docker start mysql_dev

进入容器

docker exec -it mysql_dev bash

查看容器中服务的ip

docker exec -it mysql_dev cat /etc/hosts

新版 mysql 授权用户时报错 near 'identified by '密码' with grant option' at line 1

1 问题:

当使用 grant 权限列表 on 数据库 to '用户名'@'访问主机' identified by '密码'; 时会出现"......near 'identified by '密码'' at line 1"这个错误

2 原因:

因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了

3 解决办法:

创建账户:create user '用户名'@'访问主机' identified by '密码';
赋予权限:grant 权限列表 on 数据库 to '用户名'@'访问主机' ;(修改权限时在后面加with grant option)

4 具体操作:

# 添加用户
create user 'mysql_dev' identified by '123456';
# 赋予权限
grant all privileges on *.* to 'mysql_dev'@'%';
# 修改加密规则 
alter user 'mysql_dev'@'%' identified by '123456' password expire never;
# 更新一下用户的密码
alter user 'mysql_dev'@'%' identified with mysql_native_password by '123456';
# 更新配置信息
flush privileges;

以上就是docker 安装 mysql 并实现远程连接教程的详细内容,更多关于docker 安装 mysql并远程连接的资料请关注移动技术网其它相关文章!

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网