【Docker Compose】mysql部署

06-01 1158阅读

前言:本文将指导你如何使用 Docker Compose 轻松部署 MySQL,并加载自定义配置文件,以实现数据持久化和灵活的配置管理。在开始之前,请确保你的系统已安装 Docker 和 Docker Compose。如果你尚未安装,可以参考我的: 往期博客。

文章目录

    • 1. 创建挂载目录
    • 2. 配置 docker-compose.yml 文件
    • 3. 创建 Mysql 配置文件
    • 4. 启动 MySQL 容器
    • 5. 后续操作
    • 总结

      1. 创建挂载目录

      首先,我们需要创建两个目录用于挂载 MySQL 的数据和配置文件,确保数据的持久化和配置的自定义。

      # 创建用于存放 MySQL 数据的目录
      mkdir -p /data/mysql/data
      # 创建用于存放 MySQL 配置文件的目录
      mkdir -p /data/mysql/conf
      
      • /data/mysql/data: 该目录将挂载到 MySQL 容器的 /var/lib/mysql 目录,用于持久化存储 MySQL 的数据库文件。
      • /data/mysql/conf: 该目录将用于存放自定义的 my.cnf 配置文件,并通过数据卷挂载到容器中,覆盖默认配置。

        2. 配置 docker-compose.yml 文件

        接下来,在 /data/mysql 目录下创建一个 docker-compose.yml 文件,并粘贴以下配置信息:

        version: '3'
        services:
          mysql:
            image: mysql:8.0.33 # 使用 MySQL 8.0.33 镜像
            container_name: mysql # 定义容器名称为 mysql
            volumes:
              - /data/mysql/data:/var/lib/mysql # 挂载数据目录
              - /data/mysql/conf/my.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf # 挂载自定义配置文件
            restart: always # 容器总是尝试重新启动
            ports:
              - 3336:3306 # 将宿主机的 3336 端口映射到容器的 3306 端口
            environment:
              MYSQL_ROOT_PASSWORD: 12345678 # 设置 root 用户的密码
              TZ: Asia/Shanghai # 设置容器的时区为上海
            command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci # 设置 MySQL 服务的默认字符集和排序规则
        
        • image: mysql:8.0.33: 指定了要使用的 Docker 镜像为 MySQL,版本为 8.0.33。你可以根据需要选择其他版本。

        • container_name: mysql: 为运行的 MySQL 容器指定一个名称,方便后续使用 Docker 命令进行管理。

        • volumes: 定义了数据卷的挂载。

          • /data/mysql/data:/var/lib/mysql: 将宿主机上的 /data/mysql/data 目录挂载到容器内的 /var/lib/mysql 目录,用于持久化存储 MySQL 的数据。
          • /data/mysql/conf/my.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf: 将宿主机上的/data/mysql/conf/my.cnf文件挂载到容器内的指定路径,用于覆盖 MySQL 的默认配置。
          • restart: always: 配置 Docker 在容器意外停止时自动重新启动。

          • ports: - 3336:3306: 将宿主机的 3336 端口映射到容器内部 MySQL 服务的默认端口 3306。你可以根据需要修改宿主机端口,但请注意不要与其他服务冲突。

          • environment: 设置容器的环境变量。

            • MYSQL_ROOT_PASSWORD: 12345678: 设置 MySQL root 用户的初始密码。请务必修改为你自己的安全密码。
            • TZ: Asia/Shanghai: 设置容器的时区为亚洲/上海,避免时区问题。
            • command: 覆盖容器启动时执行的默认命令,这里用于设置 MySQL 服务的默认字符集为 utf8mb4 和排序规则为 utf8mb4_unicode_ci,以支持更广泛的字符。

              3. 创建 Mysql 配置文件

              在 /data/mysql/conf 目录下创建一个名为 my.cnf 的配置文件,并粘贴以下内容:

              [mysqld]
              default-storage-engine=INNODB  # 创建新表时将使用的默认存储引擎
              character-set-server=utf8mb4      # 设置 mysql 服务端默认字符集
              pid-file        = /var/run/mysqld/mysqld.pid  # pid 文件所在目录
              socket          = /var/run/mysqld/mysqld.sock # 用于本地连接的 socket 套接字
              datadir         = /var/lib/mysql              # 数据文件存放的目录
              symbolic-links=0
              sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION # 定义 mysql 应该支持的 sql 语法,数据校验等!
              # 允许最大连接数
              max_connections=200
              # 同一局域网内注意要唯一
              server-id=3336
              # 开启二进制日志功能 & 日志位置存放位置`/var/lib/mysql`
              #log-bin=mysql-bin
              log-bin=/var/lib/mysql/mysql-bin
              # binlog 格式
              # 1. STATEMENT:基于 SQL 语句的模式,binlog 数据量小,但是某些语句和函数在复制过程可能导致数据不一致甚至出错;
              # 2. MIXED:混合模式,根据语句来选用是 STATEMENT 还是 ROW 模式;
              # 3. ROW:基于行的模式,记录的是行的完整变化。安全,但 binlog 会比其他两种模式大很多;
              binlog_format=ROW
              # FULL:binlog 记录每一行的完整变更 MINIMAL:只记录影响后的行
              binlog_row_image=FULL
              # 日志文件大小
              max_binlog_size=100M
              # 定义清除过期日志的时间(这里设置为 7 天)
              expire_logs_days=7
              # ================= ↑↑↑ mysql 主从同步配置 end ↑↑↑ =================
              [mysql]
              default-character-set=utf8mb4
              [client]
              default-character-set=utf8mb4  # 设置 mysql 客户端默认字符集
              
              • [mysqld]: 该部分配置了 MySQL 服务端的参数。

                • default-storage-engine=INNODB: 设置默认的存储引擎为 InnoDB,它支持事务和行级锁定,是推荐的存储引擎。
                • character-set-server=utf8mb4: 设置服务端使用的默认字符集为 utf8mb4,支持存储更广泛的 Unicode 字符。
                • datadir=/var/lib/mysql: 指定 MySQL 数据文件存放的目录,与 docker-compose.yml 中挂载的数据卷对应。
                • sql_mode: 定义了 MySQL 应该支持的 SQL 语法和数据校验规则。这里设置了严格模式。
                • max_connections: 设置允许的最大客户端连接数。
                • server-id: 在主从复制环境中用于唯一标识服务器。在单机部署中,保持唯一即可。
                • log-bin: 启用二进制日志,用于数据恢复和主从复制。这里指定了日志文件的路径。
                • binlog_format=ROW: 设置二进制日志的格式为 ROW,记录每一行的更改,更安全可靠。
                • binlog_row_image=FULL: 记录完整的行变更信息。
                • max_binlog_size: 设置单个二进制日志文件的最大大小。
                • expire_logs_days: 设置二进制日志的过期天数,MySQL 会自动清理过期的日志。
                • [mysql]: 该部分配置了 MySQL 客户端的默认字符集。

                • [client]: 该部分配置了 MySQL 命令行客户端的默认字符集。

                  4. 启动 MySQL 容器

                  完成以上配置后,切换到 /data/mysql 目录,并使用 Docker Compose 启动 MySQL 容器:

                  【Docker Compose】mysql部署
                  (图片来源网络,侵删)
                  cd /data/mysql
                  docker-compose up -d
                  

                  如果镜像未拉取,执行该命令会自动去拉取对应的镜像

                  5. 后续操作

                  容器启动后,你可以使用以下命令查看容器的运行状态:

                  【Docker Compose】mysql部署
                  (图片来源网络,侵删)
                  docker ps
                  

                  你应该能看到名为 mysql 的容器正在运行,并且宿主机的 3336 端口已经映射到容器的 3306 端口。

                  重要提示:

                  【Docker Compose】mysql部署
                  (图片来源网络,侵删)
                  • 云服务器: 如果你使用的是云服务器,请务必在服务器的安全组或防火墙设置中开放 TCP 协议的 3336 端口(你在 docker-compose.yml 中配置的宿主机端口),否则外部无法连接到 MySQL 服务。
                  • 本地服务器: 如果你在本地服务器上运行,也需要检查并允许防火墙通过 TCP 协议的 3336 端口。例如,在使用 ufw 的 Linux 系统上,可以使用 sudo ufw allow 3336/tcp 命令。

                    接下来,你可以使用任何 MySQL 客户端工具(例如 Navicat、DBeaver、MySQL Workbench 等)通过 你的服务器IP地址:3336 连接到 MySQL 数据库。默认的 root 用户密码是你在 docker-compose.yml 中设置的 12345678 。

                    总结

                    通过本文的步骤,你已经成功地使用 Docker Compose 部署了 MySQL 8.0.33,并实现了数据的持久化和自定义配置。Docker Compose 通过简单的 YAML 文件,极大地简化了多容器应用的部署和管理流程。你可以根据实际应用场景的需求,进一步调整 docker-compose.yml 和 my.cnf 文件,以满足更复杂的配置和性能优化需求。

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码