美文网首页
Docker 中创建 mysql 容器,并设置远程连接

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

作者: 张云飞Vir | 来源:发表于2020-05-22 17:22 被阅读0次

    0. 背景

    Docker 中创建 mysql 容器

    1.创建MySQL容器

      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

      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 连接数据库了。

    END

    相关文章

      网友评论

          本文标题:Docker 中创建 mysql 容器,并设置远程连接

          本文链接:https://www.haomeiwen.com/subject/zlccahtx.html