重新启动Docker后,Docker撰写无法启动未找到的服务网络

时间:2018-07-09 09:37:34

标签: windows docker docker-compose docker-for-windows

我在Windows 10专业版中为Windows使用docker(版本18.03.0-ce-win59(16762))。运行命令docker-compose -up -d后,所有容器都可以正常运行。问题是当我重新启动docker服务时。然后,一旦重新启动,所有容器都将停止,当我运行命令docker-compose start -d时,将显示以下错误:

Error response from daemon: network ccccccccccccc not found

我不知道发生了什么。当我使用run--restart=always选项运行容器时,一切正常。重新启动时未显示错误。

这是docker-compose文件:

version: '3'

services:
  service_1:
    image: image1
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/foo2
      dockerfile: Dockerfile
      args:
        ENTRY: "1"
    volumes:
      - C:/ProgramData/Docker/volumes/foo1:C:/foo1
      - C:/ProgramData/Docker/volumes/foo2:C:/foo2
  service_2:
    image: image2
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/foo2
      dockerfile: Dockerfile
      args:
        ENTRY: "2"
    volumes:
      - C:/ProgramData/Docker/volumes/foo1:C:/foo1
      - C:/ProgramData/Docker/volumes/foo2:C:/foo2
  service_3:
    image: image3
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/foo2
      dockerfile: Dockerfile
      args:
        ENTRY: "4"
    volumes:
      - C:/ProgramData/Docker/volumes/foo1:C:/foo1
      - C:/ProgramData/Docker/volumes/foo2:C:/foo2

dockerfile是这样的:

FROM microsoft/dotnet-framework:3.5

ARG ENTRY
ENV my_env=$ENTRY

WORKDIR C:\\foo2

ENTRYPOINT C:/foo2/app.exe %my_env%

4 个答案:

答案 0 :(得分:3)

网络已更改。我使用“ docker network prune”命令来解决相同的问题。删除容器可以解决该问题。

Docker将再次创建容器并设置网络

docker rm $(docker ps -qa)

答案 1 :(得分:1)

我发现了如下编辑docker-compose.yml文件的可能解决方案:

version: '3'

services:
  cm04:
    image: tnc530_cm04
    networks:
      - test
    privileged: false
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC530
      dockerfile: Dockerfile
      args:
        ENTRY: "1"
    volumes:
      - C:/ProgramData/Docker/volumes/sqlite:C:/sqlite
      - C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC530/bin/x86/Release:C:/adontec
  cm06:
    image: tnc620_cm06
    networks:
      - test
    privileged: false
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC620
      dockerfile: Dockerfile
      args:
        ENTRY: "2"
    volumes:
      - C:/ProgramData/Docker/volumes/sqlite:C:/sqlite
      - C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC620/bin/x86/Release:C:/adontec
  cm08:
    image: tnc620_cm08
    networks:
      - test
    privileged: false
    restart: always
    build:
      context: C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC620
      dockerfile: Dockerfile
      args:
        ENTRY: "4"
    volumes:
      - C:/ProgramData/Docker/volumes/sqlite:C:/sqlite
      - C:/ProgramData/Docker/volumes/adontec/LSV2_Lib/Heidenhain/TNC620/bin/x86/Release:C:/adontec

networks:
  test:
    external:
      name: nat

如您所见,我创建了一个名为test的网络,该网络与外部网络nat链接。现在,当我重新启动Docker服务时,容器将正确启动。

答案 2 :(得分:0)

可能存在一些未删除的旧容器实例。使用

检查实例
docker container ls -a

如果您有一些未删除的实例,您可能会得到这样的输出

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                   PORTS               NAMES
8b4678e6666b        b4a75a01d539        "/bin/sh -c 'eval `s…"   6 weeks ago         Exited (1) 6 weeks ago                       zealous_allen
ee862a3418f2        1eaaf48e9b42        "/bin/sh -c 'eval `s…"   6 weeks ago         Exited (1) 6 weeks ago                       jolly_torvalds

通过容器ID删除容器

docker container rm 8b4678e6666b
docker container rm ee862a3418f2 

现在使用docker-compose文件启动容器 这对我有用。希望能帮助到你!

答案 3 :(得分:0)

或者,您可以直接打开 docker 应用程序并手动删除容器。然后在终端上运行 docker-compose up。现在它应该可以工作了。转到端口 9000 或 9001 或您使用的任何端口,看看 minio 是否实际运行。