【问题标题】:Docker and Rails: unable to access log fileDocker 和 Rails:无法访问日志文件
【发布时间】:2025-01-01 14:35:01
【问题描述】:

当我启动我的 Rails 开发服务器(或运行测试)时,我收到以下错误:

Rails 错误:无法访问日志文件。请确保 /usr/src/app/log/development.log 存在且可写(即,使其 用户和组可写:chmod 0664 /usr/src/app/log/development.log)。日志级别已提升到 WARN 并将输出定向到 STDERR,直到问题得到解决。

即使在我执行chmod -R 777 log 之后,这个问题仍然存在。

我的应用 Dockerized 运行 Alpine Linux。

这个问题的原因可能是什么?

【问题讨论】:

  • 您的log 文件夹是否在您的volumes 上共享? (我想你正在使用 docker-compose)
  • 是的,结果证明是问题所在。

标签: ruby-on-rails docker permissions


【解决方案1】:

原来问题是因为我的 log 目录被挂载为 PostgreSQL 日志目录。

services:
  postgres:
    image: postgres:12.3-alpine
    mem_limit: 64m
    volumes:
      - ./log:/root/log:cached # <-- this line was the culprit
      - postgresql:/var/lib/postgresql/data:delegated
    ports:
      - "127.0.0.1:5432:5432"
    environment:
      PSQL_HISTFILE: /root/log/.psql_history
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: postgres
    restart: on-failure
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 10s
      timeout: 2s
      retries: 10
    logging:
      driver: none

我在this GitHub issue 中更详细地描述了这个问题。

【讨论】: