前提:

  异常:

    docker 安装 mysql 8  外部连接会报一下异常: Authentication plugin 'caching_sha2_password' cannot be loaded

  原因

    出现这个原因是mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password, 解决问题方法有两种,一种是升级navicat驱动,一种是把mysql用户登录密码加密规则还原成mysql_native_password.

安装环境:

  centos7

  Docker version 1.13.1

安装步骤:

  1.拉取镜像,不带版本号,默认拉取最高版本: docker pull mysql 

  2.查看镜像:docker images

  

  3.启动镜像 做端口映射 3306到外网,不然连接不上:docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql

    更多映射 :  docker run --name mysql-hw --privileged=true -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /root/ancen/mysql/data:/var/lib/mysql -v /root/ancen/mysql/log:/var/log/mysql -d mysql --lower_case_table_names=1

    –restart=always: 当Docker 重启时,容器会自动启动。
    –privileged=true:容器内的root拥有真正root权限,否则容器内root只是外部普通用户权限
    -e MYSQL_ROOT_PASSWORD :设置mysql密码
    -v /home/mysql/:/var/lib/mysql:挂载磁盘实现数据持久化
    –lower_case_table_names=1 :忽略大小写,docker mysql默认区分大小写的

    设置时区

     default-time_zone=‘+8:00’

       //只要将配置文件拷贝镜像文件出来,在其修改后,在替换上去
      docker cp mysql-hw:/etc/mysql/my.cnf /root/ancen/mysql
    docker cp /root/ancen/mysql/my.cnf mysql-hw:/etc/mysql/my.cnf
    //修改完后需重启
    docker restart mysql-hw

  4.查看运行中的容器,看是否启动成功:

  

 

   5.外部连接报错:

  

解决方法

  1.进入docker容器 :docker exec -it c4bf367b7155  bash

  

  2.登陆数据库 : mysql -uroot -p{密码}。  借鉴  :https://blog.csdn.net/u014527619/article/details/80509671 不成功 。

  

  以这种方式登陆(成功) : 

    1. mysql -uroot -p   。回车

    2.输入密码

  

 

    

    3.修改数据库
      mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';

    4.重新修改密码后可连接成功
      mysql> alter user 'root'@'%' identified by '123456';

    5.刷新数据库
      mysql> flush privileges;
    6.重新外网登陆ok

 

文章借鉴:https://blog.csdn.net/u014527619/article/details/80509671

 

posted on 2019-08-05 23:40  JonRain0625  阅读(7484)  评论(0编辑  收藏  举报