在主机网络仍然无法工作的情况下进行Docker堆栈部署

jli*_*lim 4 docker docker-compose docker-swarm

我了解docker问题#25873中的一些讨论说,ce 17.06中支持此功能。我已经在Linux中安装了17.09,在Windows中安装了18.03。两者都有同样的问题抱怨

network "host" is declared as external, but it is not in the right scope: "local" instead of "swarm"

想知道为什么我不能在本地范围内使用主机网络吗?运行docker stack deploy时是否可以使用主机网络?

Docker版本

Client:
 Version:       18.03.0-ce
 API version:   1.37
 Go version:    go1.9.4
 Git commit:    0520e24
 Built: Wed Mar 21 23:06:28 2018
 OS/Arch:       windows/amd64
 Experimental:  false
 Orchestrator:  swarm

Server:
 Engine:
  Version:      18.03.0-ce
  API version:  1.37 (minimum version 1.12)
  Go version:   go1.9.4
  Git commit:   0520e24
  Built:        Wed Mar 21 23:14:32 2018
  OS/Arch:      linux/amd64
  Experimental: false
Run Code Online (Sandbox Code Playgroud)

Docker信息

Containers: 0
 Running: 0
 Paused: 0
 Stopped: 0
Images: 1
Server Version: 18.03.0-ce
Storage Driver: overlay2
 Backing Filesystem: extfs
 Supports d_type: true
 Native Overlay Diff: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins:
 Volume: local
 Network: bridge host macvlan null overlay
 Log: awslogs fluentd gcplogs gelf journald json-file logentries splunk syslog
Swarm: active
 NodeID: cqa33vk220d3zpp9g2gqar9hd
 Is Manager: true
 ClusterID: cphphnyrr379dbm5044snxrjy
 Managers: 1
 Nodes: 1
 Orchestration:
  Task History Retention Limit: 5
 Raft:
  Snapshot Interval: 10000
  Number of Old Snapshots to Retain: 0
  Heartbeat Tick: 1
  Election Tick: 3
 Dispatcher:
  Heartbeat Period: 5 seconds
 CA Configuration:
  Expiry Duration: 3 months
  Force Rotate: 0
 Autolock Managers: false
 Root Rotation In Progress: false
 Node Address: 192.168.65.3
 Manager Addresses:
  192.168.65.3:2377
Runtimes: runc
Default Runtime: runc
Init Binary: docker-init
containerd version: cfd04396dc68220d1cecbe686a6cc3aa5ce3667c
runc version: 4fc53a81fb7c994640722ac585fa9ca548971871
init version: 949e6fa
Security Options:
 seccomp
  Profile: default
Kernel Version: 4.9.87-linuxkit-aufs
Operating System: Docker for Windows
OSType: linux
Architecture: x86_64
CPUs: 2
Total Memory: 1.934GiB
Name: linuxkit-00155d006407
ID: YRXM:MKGD:7VQM:ZNK2:XKCI:DYTL:VVQH:XP5X:QRCY:CKP2:5EVJ:3QE4
Docker Root Dir: /var/lib/docker
Debug Mode (client): false
Debug Mode (server): true
 File Descriptors: 33
 Goroutines: 145
 System Time: 2018-04-08T07:24:34.2713256Z
 EventsListeners: 1
Registry: https://index.docker.io/v1/
Labels:
Experimental: false
Insecure Registries:
 127.0.0.0/8
Live Restore Enabled: false
Run Code Online (Sandbox Code Playgroud)

Docker Compose文件

version: '3.4'

services:
  test:
    image: alpine
    command: top
    networks:
      - host

networks:
  host:
    external:
      name: host
Run Code Online (Sandbox Code Playgroud)

执行中

C:\>docker stack deploy -c docker-compose.yml test

network "host" is declared as external, but it is not in the right scope: "local" instead of "swarm"
Run Code Online (Sandbox Code Playgroud)

Bre*_*her 5

从Docker 18.09版本开始,该版本应在与Windows Server 2019相同的现代Linux上运行。您可以将一项服务直接连接到主机端口以及覆盖网络。

要将主机NIC直接用于已发布的端口,则不使用网络,只需更改已发布的端口模式,如下所示:

services:
  traefik:
    image: traefik:alpine
    ports:
      - target: 80
        published: 80
        protocol: tcp
        mode: host
Run Code Online (Sandbox Code Playgroud)

对于正常发布的端口,它将是 mode: ingress

如果您还希望服务与覆盖网络通信,则可以按常规方式添加网络。我在这里有Traefik完整示例