docker安装mysql8.0

本文介绍如何在CentOS 7.3环境下使用Docker部署MySQL 8.0,包括启动Docker服务、拉取镜像、创建并启动容器、配置容器参数等步骤,同时解决MySQL 8.0远程连接及字符集问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境: 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. 创建并启动容器

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

 

### 使用 Docker 安装 MySQL 8.0 的教程 #### 准备工作 确保已经成功安装 Docker。如果尚未完成此操作,在某些操作系统上可能还需要更新 WSL,可以通过 `wsl --update` 命令来实现[^3]。 #### 拉取 MySQL 镜像 为了获取特定版本的 MySQL 8.0 镜像,可以使用如下命令: ```bash docker pull mysql:8.0.20 ``` 这会从官方仓库中下载指定版本的 MySQL 镜像文件到本地环境之中。 对于希望使用华为云容器镜像服务中的 Bitnami 版本,则应采用以下指令集: ```bash docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/bitnami/mysql:8.0.33 docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/bitnami/mysql:8.0.33 mysql:8.0.33 ``` 上述命令不仅能够拉取所需镜像,还会创建一个新的标签以便于后续管理与调用[^2]。 #### 启动 MySQL 容器实例 启动新创建的 MySQL 数据库服务器实例时,建议设置必要的环境变量以及挂载卷用于持久化存储数据。下面是一个简单的例子说明如何运行带有自定义配置选项的服务端口映射至主机上的方式: ```bash docker run -d \ --name=mysql-server \ -e MYSQL_ROOT_PASSWORD=your_password_here \ -p 3306:3306 \ -v /path/to/data:/var/lib/mysql \ mysql:8.0.20 ``` 这里 `-d` 参数表示以后台模式启动;`--name` 给定容器名称方便识别;`-e` 设置根用户密码;而 `-p` 则指定了外部访问端口号;最后通过 `-v` 将宿主机路径绑定到容器内部位置以保存数据库资料。 #### 自定义配置文件应用 如果有特殊需求想要修改默认参数或者优化性能表现的话,还可以准备一份 `.cnf` 文件并通过下述方法将其复制进入正在运行着的目标容器里边覆盖原有设定: ```bash docker cp /tmp/my.cnf <container_id_or_name>:/etc/mysql/my.cnf ``` 请注意替换 `<container_id_or_name>` 成实际存在的 ID 或者名字即可生效[^4]。 停止已有的 MySQL 实例可利用这条语句达成目的: ```bash docker stop mysql8.0 ``` 该命令将会终止名为 `mysql8.0` 的进程运作状态[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值