docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > docker-compose安装MySQL8.0.39

docker-compose安装MySQL8.0.39全过程

作者:会飞的土拨鼠呀

这篇文章主要介绍了docker-compose安装MySQL8.0.39全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

好的,这是一个使用 Docker Compose 安装 MySQL 8.0.39 的详细指南,包含数据持久化、自定义配置和基本安全设置。

1. 创建项目目录

首先,创建一个独立的目录来存放所有相关文件,避免与其他项目混淆。

mkdir mysql-docker
cd mysql-docker

2. 创建docker-compose.yml文件

这是核心配置文件,定义了MySQL服务、卷、端口映射等。

version: '3.8'

services:
  mysql:
    image: mysql:8.0.39  # 指定精确版本
    container_name: mysql-8.0.39-container  # 自定义容器名,便于管理
    restart: unless-stopped  # 总是重启,除非手动停止
    environment:
      MYSQL_ROOT_PASSWORD: your_strong_root_password  # !!!务必修改!!!
      MYSQL_DATABASE: my_app_db  # 可选:容器启动时创建的数据库
      MYSQL_USER: my_app_user    # 可选:创建普通用户
      MYSQL_PASSWORD: your_strong_user_password  # !!!务必修改!!!
      TZ: Asia/Shanghai          # 可选:设置容器时区
    ports:
      - "3306:3306"  # 将宿主机的3306端口映射到容器的3306端口
    volumes:
      - mysql_data:/var/lib/mysql  # 持久化数据
      - ./conf/my.cnf:/etc/mysql/conf.d/custom.cnf  # 挂载自定义配置文件
      - ./logs:/var/log/mysql  # 可选:挂载日志目录
    networks:
      - mysql-network  # 加入自定义网络(更安全)

volumes:
  mysql_data:  # 声明一个命名卷,Docker会自动管理其位置

networks:
  mysql-network:  # 声明一个自定义网络
    driver: bridge

3. (可选) 创建自定义配置文件

创建 conf 目录并放入你的 my.cnf 文件,用于覆盖默认的MySQL设置。

mkdir -p conf

编辑 conf/my.cnf 文件:

[mysqld]
# 服务器字符集
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci

# 默认认证插件 (MySQL 8.0+ 默认使用 caching_sha2_password)
default_authentication_plugin=mysql_native_password

# 自定义其他参数,例如最大连接数、缓冲区大小等
max_connections=200
innodb_buffer_pool_size=256M

[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

4. 启动 MySQL 容器

在包含 docker-compose.yml 文件的目录下,运行以下命令来构建并启动服务:

# 以后台模式启动 (-d 或 --detach)
docker-compose up -d

# 或者,如果你想在前台启动并查看日志,用于调试
# docker-compose up
# 使用 Ctrl+C 停止后,容器也会停止

5. 管理及常用命令

容器启动后,你可以使用以下命令进行管理:

# 查看容器运行状态
docker-compose ps

# 查看MySQL容器的实时日志
docker-compose logs -f mysql

# 停止服务(数据会保留在卷中)
docker-compose down

# 停止并删除数据卷(警告:这会清除所有数据!)
# docker-compose down -v

# 进入MySQL容器内部的bash终端
docker-compose exec mysql bash

# 使用MySQL命令行客户端直接连接(推荐方式)
# 方式一:在宿主机上连接(因为映射了端口)
mysql -h 127.0.0.1 -P 3306 -u root -p
# 然后输入在yml文件中设置的 MYSQL_ROOT_PASSWORD

# 方式二:通过exec在容器内执行mysql命令(无需网络和密码,安全快捷)
docker-compose exec mysql mysql -u root -p

关键配置解释

image: mysql:8.0.39

volumes

environment

ports

networks

安全建议

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文