使用 Docker Compose 部署 MySQL 时,遇到 “mysqld: Can't read dir of '/etc/mysql/conf.d/'” 错误如何解决?

使用 docker compose 部署 mysql 时,遇到 “mysqld: can't read dir of '/etc/mysql/conf.d/'” 错误如何解决?

mysql docker 部署疑难解答

本文旨在解决在 ubuntu 环境中使用 docker-compose 部署 mysql 时遇到的错误问题。

问题描述:

用户在执行以下 docker-compose.yml 文件时遇到了错误:

version: '3'
services:
  mysql: 
    restart: always
    image: mysql:8.2
    network_mode: bridge
    container_name: mysql
    environment:
      mysql_root_password: root123
    command:
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true
      --lower_case_table_names=1
      --max_allowed_packet=128m
    volumes:
      - /etc/localtime:/etc/localtime:ro
      - /data/docker/mysql/mysql:/var/lib/mysql
      - /data/docker/mysql/etc:/etc/mysql:ro
    ports:
      - 3306:3306

错误信息如下:

mysqld: can't read dir of '/etc/mysql/conf.d/' (os errno 2 - no such file or directory)

解决方法:

错误源于 /etc/mysql/conf.d/ 目录不存在。该目录用于存储 mysql 配置文件,而 docker-compose 配置将 /data/docker/mysql/etc 挂载到了 /etc/mysql/ 上。

要解决此问题,需要确保 /data/docker/mysql/etc 目录中存在 conf.d 子目录,并将其挂载到 /etc/mysql/conf.d/ 上。修改后的 docker-compose 如下:

volumes:
  - /etc/localtime:/etc/localtime:ro
  - /data/docker/mysql/mysql:/var/lib/mysql
  - /data/docker/mysql/etc/conf.d:/etc/mysql/conf.d:ro

以上就是使用 Docker Compose 部署 MySQL 时,遇到 “mysqld: Can't read dir of '/etc/mysql/conf.d/'” 错误如何解决?的详细内容,更多请关注其它相关文章!