前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker安装MySQL 8.0过程记录

Docker安装MySQL 8.0过程记录

作者头像
星哥玩云
发布2022-08-17 20:08:51
1.2K0
发布2022-08-17 20:08:51
举报
文章被收录于专栏:开源部署开源部署

环境:

Linux系统:CentOS 7.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. 创建并启动容器

        -p: 映射本地端口3306

        --restart-always: docker服务启动时,自动启动容器,并且当容器停止时,尝试重启容器。

                --restart具体参数值详细信息:                 no -  容器退出时,不重启容器;                 on-failure - 只有在非0状态退出时才从新启动容器;                 always - 无论退出状态是如何,都重启容器;

        MYSQL_ROOT_PASSWORD:设置root密码为root

        设置默认数据库编码为utf8mb4,默认排序规则为utf8mb4_unicode_ci

        -v : 挂载本地卷

  注意:mysql8.0安装默认编码为utf8mb4,所以可以不需要参数--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci docker run \ --name mysql \ -p 3306:3306 \ --restart=always \ -e MYSQL_ROOT_PASSWORD=root \ -v /var/lib/mysql/:/var/lib/mysql/ \ -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;

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客户端工具连接数据库

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

mysql> alter user 'root'@'localhost' identified by 'root';

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

mysql> alter user 'root'@'%' identified by 'root';

刷新权限:

mysql> flush privileges;

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

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

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

            #  apt-get update && apt-get install vim -y

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

            #  vim /etc/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:为本地主机挂载卷的路径

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档