【发布时间】:2017-02-04 02:44:54
【问题描述】:
我正在尝试熟悉 docker 生态系统并尝试设置一个 mysql 数据库容器。 docker-compose 看起来像这样:
version: '2'
services:
db:
image: mysql:5.6.33@sha256:31ad2efd094a1336ef1f8efaf40b88a5019778e7d9b8a8579a4f95a6be88eaba
volumes:
- "./db/data:/var/lib/mysql"
- "./db/log:/var/log/mysql"
- "./db/conf:/etc/mysql/conf.d"
restart: "yes"
environment:
MYSQL_ROOT_PASSWORD: rootpw
MYSQL_DATABASE: db
MYSQL_USER: db
MYSQL_PASSWORD: dbpw
我的 conf 目录包含一个文件:
[mysqld]
log_error =/var/log/mysql/mysql_error.log
general_log_file=/var/log/mysql/mysql.log
general_log =1
slow_query_log =1
slow_query_log_file=/var/log/mysql/mysql_slow.log
long_query_time =2
log_queries_not_using_indexes = 1
不幸的是,我没有以这种方式获得任何日志文件。设置本身是正确的,并且使用了 cnf 文件。连接到容器并创建 3 个文件后,将 chown 它们到 mysql 并重新启动容器,日志记录按预期工作。
我很确定这是一种常见的情况,而我目前运行它的方法似乎非常愚蠢。 正确的做法是什么?
我可以通过将所有这些东西移动到 Dockerfile 中来改进我的方法,但这对我来说仍然很奇怪。
【问题讨论】: