docker安装mysql8.0

环境: centos7.3                    docker --version: 17.12.0-ce

1. 操作系统切换到root用户:

        # su root

2. 启动docker
        # systemctl start docker

3. 拉取mysql8.0镜像
        # docker pull mysql:8.0

4. 创建并启动容器(映射本地端口3306,设置root密码为root,设置默认数据库编码为utf8mb4,默认排序规则为utf8mb4_unicode_ci)

  注意:mysql8.0安装默认编码为utf8mb4,所以可以不需要参数--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

# docker run \
--name mysql \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=root \
-d \
mysql:8.0 \
--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci

5. 进入docker的mysql容器
        #  docker exec -it mysql /bin/bash

6. 登录数据库(此处的密码为参数-e MYSQL_ROOT_PASSWORD=root对应的值,此处密码为root)
        #  mysql -uroot -proot

7. 使用mysql数据库
mysql> use mysql;

扫描二维码关注公众号,回复: 2941668 查看本文章

8. mysql8.0的root用户的验证方式变了,通过查询:select host,user,plugin from user;

得知:root的用户的加密方式为caching_sha2_passoword, 而navicat连接所用的方式为native_password。mysql为远程连接和本地连接提供了不同的密码验证方式。

修改root用户插件验证方式:

mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';

注意:先更改ser表中用户为root的host字段,若为localhost则改为%,只有改为%,该用户才可以远程访问。

刷新权限:

mysql> flush privileges;

此时,可以使用mysql客户端工具连接数据库。

如果navicat 提示“1045 access denied for user 'root'@'localhost' ”,则执行:

mysql> alteruser 'root'@'localhost' identified by 'root';

同理:如果navicat 提示“1045 access denied for user 'root'@'%' ”,则执行:

mysql> alteruser 'root'@'%' identified by 'root';

9. 修改mysql数据库编码,防止中文乱码

    (1)进入docker的mysql容器
             #  docker exec -it mysql /bin/bash

    (2)容器默认没有安装任何编辑器,先安装vim。

             #  apt-get update

             #  apt-get install vim

      (3)  安装完vim之后,开始修改mysql数据库编码

             #  vim /ect/mysql/conf.d/mysql.cnf

            增加以下内容,然后保存,退出:      

           [client]
           default-character-set=utf8

           [mysql]
           default-character-set=utf8

      (4)  重启mysql容器,查询编码:此时编码已经修改为utf8。

            mysql>  show variables like'character%';

10.  查看挂载卷位置:获取容器/镜像的元数据。

       #  docker inspect  容器ID

其中:
    "Mounts": [
            {
                "Type": "volume",
                "Name": "ebc0e8f50d451650f29d7ac1a696a0130316073173835c1b5c9f7f88c5fb976f",
                "Source": "/var/lib/docker/volumes/ebc0e8f50d451650f29d7ac1a696a0130316073173835c1b5c9f7/_data",
                "Destination": "/var/lib/mysql",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ]

Source:为本地主机挂载卷的路径

猜你喜欢

转载自blog.csdn.net/mmingxiang/article/details/81946046