Docker MySQL - 환경 변수를 설정해야 하지만 이미 설정되어 있습니다.

Docker MySQL - 환경 변수를 설정해야 하지만 이미 설정되어 있습니다.

ENV 변수를 설정했지만 여전히 컨테이너에서 변수를 설정해야 한다는 오류가 발생합니다.

제가 사용하려는 이미지는 다음과 같습니다.mysql-56-centos7.

이 문제를 해결하는 방법에 대한 제안이 있으십니까?

도커파일:

FROM centos/mysql-56-centos7


ENV MYSQL_USER=root \
    MYSQL_PASSWORD=test \
    MYSQL_DATABASE=test \
    MYSQL_DATA_DIR=/var/lib/mysql \
    MYSQL_RUN_DIR=/run/mysqld \
    MYSQL_LOG_DIR=/var/log/mysql

EXPOSE 3306/tcp

CMD ["run-mysqld"]

다음은 오류입니다:

[root@centos1 test01]# docker container logs cf0245546d47
=> sourcing 20-validate-variables.sh ...
You must either specify the following environment variables:
  MYSQL_USER (regex: '^[a-zA-Z0-9_]+$')
  MYSQL_PASSWORD (regex: '^[a-zA-Z0-9_~!@#$%^&*()-=<>,.?;:|]+$')
  MYSQL_DATABASE (regex: '^[a-zA-Z0-9_]+$')
Or the following environment variable:
  MYSQL_ROOT_PASSWORD (regex: '^[a-zA-Z0-9_~!@#$%^&*()-=<>,.?;:|]+$')
Or both.
Optional Settings:
  MYSQL_LOWER_CASE_TABLE_NAMES (default: 0)
  MYSQL_LOG_QUERIES_ENABLED (default: 0)
  MYSQL_MAX_CONNECTIONS (default: 151)
  MYSQL_FT_MIN_WORD_LEN (default: 4)
  MYSQL_FT_MAX_WORD_LEN (default: 20)
  MYSQL_AIO (default: 1)
  MYSQL_KEY_BUFFER_SIZE (default: 32M or 10% of available memory)
  MYSQL_MAX_ALLOWED_PACKET (default: 200M)
  MYSQL_TABLE_OPEN_CACHE (default: 400)
  MYSQL_SORT_BUFFER_SIZE (default: 256K)
  MYSQL_READ_BUFFER_SIZE (default: 8M or 5% of available memory)
  MYSQL_INNODB_BUFFER_POOL_SIZE (default: 32M or 50% of available memory)
  MYSQL_INNODB_LOG_FILE_SIZE (default: 8M or 15% of available memory)
  MYSQL_INNODB_LOG_BUFFER_SIZE (default: 8M or 15% of available memory)

답변1

간단히 말해서 이 이미지를 루트로 실행할 수 없습니다. 대부분의 경우 Docker 이미지를 루트로 실행하는 것은 나쁜 습관입니다.

다른 사용자로 실행해 보면 이미지를 실행할 수 있습니다.

자세한 내용은 다음을 참조하세요.이것논의. 또한 확실하지 않은 경우 항상 찾을 수 있는 기본 구성을 사용해 보십시오.도커허브.

참고: 이것은 오래된 이미지이므로 최신 이미지를 사용해야 합니다. 이 이미지는 3년 넘게 업데이트되지 않았습니다.

관련 정보