无法停止或删除 Docker 容器 - 权限被拒绝错误

新手上路,请多包涵

问题:无法停止 docker 容器,每当我尝试停止容器时,我都会收到以下错误消息,

 ERROR: for yattyadocker_web_1  cannot stop container: 1f04148910c5bac38983e6beb3f6da4c8be3f46ceeccdc8d7de0da9d2d76edd8: Cannot kill container 1f04148910c5bac38983e6beb3f6da4c8be3f46ceeccdc8d7de0da9d2d76edd8: rpc error: code = PermissionDenied desc = permission denied

操作系统版本/内部版本: Ubuntu 16.04 | Docker 版本 17.09.0-ce,构建 afdb6d4 | Docker Compose 版本 1.17.1,构建 6d101fb

重现步骤:

  • 使用 Dockerfile 和 docker-compose.yml 创建了一个 rails 项目。 docker-compose.yml 是版本 3。
  • 使用 docker build -t <project name> .docker-compose up --build 成功构建映像
  • 容器启动并成功运行。
  • 尝试使用 docker-compose down 停止 docker compose。

我尝试了什么::

  • 我必须运行 sudo service docker restart 然后可以删除容器。
  • 卸载 docker,删除 docker 目录,然后重新安装所有内容。仍然面临同样的问题。

注意:此配置之前工作正常,但不知何故文件权限可能已更改,我看到此错误。我必须运行 sudo service docker restart 然后可以删除容器。但这非常不方便,我不知道如何解决这个问题。

参考文件:

 # docker-compose.yml
version: '3'
volumes:
  db-data:
    driver: local
  redis-data:
    driver: local
services:
  db:
    image: postgres:9.4.1
    volumes:
      - db-data:/var/lib/postgresql/data
    ports:
      - "5432:5432"
    env_file: local_envs.env
  web:
    image: yattya_docker:latest
    command: bundle exec puma -C config/puma.rb
    tty: true
    stdin_open: true
    ports:
      - "3000:3000"
    links:
      - db
      - redis
      - memcached
    depends_on:
      - db
      - redis
      - memcached
    env_file: local_envs.env
  redis:
    image: redis:3.2.4-alpine
    ports:
      # We'll bind our host's port 6379 to redis's port 6379, so we can use
      # Redis Desktop Manager (or other tools) with it:
      - 6379:6379
    volumes:
      # We'll mount the 'redis-data' volume into the location redis stores it's data:
      - redis-data:/var/lib/redis
    command: redis-server --appendonly yes
  memcached:
    image: memcached:1.5-alpine
    ports:
      - "11211:11211"
  clock:
    image: yattya_docker:latest
    command: bundle exec clockwork lib/clock.rb
    links:
      - db
    depends_on:
      - db
    env_file: local_envs.env
  worker:
    image: yattya_docker:latest
    command: bundle exec rake jobs:work
    links:
      - db
    depends_on:
      - db
    env_file: local_envs.env

和 Dockerfile:

 # Dockerfile
FROM ruby:2.4.1

RUN apt-get update && apt-get install -y nodejs --no-install-recommends && rm -rf /var/lib/apt/lists/*

ENV APP_HOME /app
RUN mkdir -p $APP_HOME
WORKDIR $APP_HOME

ADD Gemfile* $APP_HOME/
RUN bundle install

ADD . $APP_HOME

RUN mkdir -p ${APP_HOME}/log
RUN cat /dev/null > "$APP_HOME/log/development.log"

RUN mkdir -p ${APP_HOME}/tmp/cache \
    && mkdir -p ${APP_HOME}/tmp/pids \
    && mkdir -p ${APP_HOME}/tmp/sockets

EXPOSE 3000

原文由 Parth Modi 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 2.7k
2 个回答

我能够解决这个问题。由于某些未知问题,ubuntu 中的 Apparmor 服务无法正常工作。该问题类似于 moby 项目 https://github.com/moby/moby/issues/20554 中报告的问题。

/etc/apparmor.d/tunables 文件夹为空, https://github.com/mlaventure 建议 清除/重新安装 apparmor 以使其恢复到初始状态。

所以我重新安装了apparmor, 重新启动后 问题就解决了。

希望这可以帮助。

原文由 Parth Modi 发布,翻译遵循 CC BY-SA 3.0 许可协议

我从 snap 包中安装了 Docker,过了一会儿我决定转向 apt 存储库安装。

我遇到了同样的问题,使用 sudo aa-remove-unknown 为我工作。

所以不需要重新安装 Apparmor。

原文由 Alejandro S. 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题