docker 网络 ls

描述列出网络
用法docker network ls [OPTIONS]
别名
docker network list

描述

daemon列出引擎知道的所有网络。这包括跨越集群中多个主机的网络。

选项

选项默认描述
-f, --filter提供过滤器值(例如driver=bridge
--format使用自定义模板设置输出格式:
'table':以带有列标题的表格格式打印输出(默认)
'table TEMPLATE':使用给定的 Go 模板以表格格式打印输出
'json':以 JSON 格式打印
'TEMPLATE':打印使用给定的 Go 模板输出。有关使用模板格式化输出的更多信息,
请参阅 https://docker.github.net.cn/go/formatting/
--no-trunc不要截断输出
-q, --quiet仅显示网络 ID

例子

列出所有网络

$ docker network ls
NETWORK ID          NAME                DRIVER          SCOPE
7fca4eb8c647        bridge              bridge          local
9f904ee27bf5        none                null            local
cf03ee007fb4        host                host            local
78b03ee04fc4        multi-host          overlay         swarm

使用该--no-trunc选项显示完整的网络 ID:

$ docker network ls --no-trunc
NETWORK ID                                                         NAME                DRIVER           SCOPE
18a2866682b85619a026c81b98a5e375bd33e1b0936a26cc497c283d27bae9b3   none                null             local
c288470c46f6c8949c5f7e5099b5b7947b07eabe8d9a27d79a9cbf111adcbf47   host                host             local
7b369448dccbf865d397c8d2be0cda7cf7edc6b0945f77d2529912ae917a0185   bridge              bridge           local
95e74588f40db048e86320c6526440c504650a1ff3e9f7d60a497c4d2163e5bd   foo                 bridge           local
63d1ff1f77b07ca51070a8c227e962238358bd310bde1529cf62e6c307ade161   dev                 bridge           local

过滤(--filter)

过滤标志(-f--filter)格式为一key=value对。如果有多个过滤器,则传递多个标志(例如--filter "foo=bar" --filter "bif=baz")。多个过滤器标志组合起来作为一个OR过滤器。例如, -f type=custom -f type=builtin返回customandbuiltin网络。

目前支持的过滤器有:

  • 司机
  • id(网络的id)
  • 标签 (label=<key>label=<key>=<value>)
  • 名称(网络名称)
  • 范围 (swarm|global|local
  • 类型 (custom|builtin

司机

过滤driver器根据驱动程序匹配网络。

以下示例将网络与bridge驱动程序进行匹配:

$ docker network ls --filter driver=bridge
NETWORK ID          NAME                DRIVER            SCOPE
db9db329f835        test1               bridge            local
f6e212da9dfd        test2               bridge            local

ID

过滤器id匹配网络 ID 的全部或部分。

以下过滤器匹配 ID 包含该 63d1ff1f77b0...字符串的所有网络。

$ docker network ls --filter id=63d1ff1f77b07ca51070a8c227e962238358bd310bde1529cf62e6c307ade161
NETWORK ID          NAME                DRIVER           SCOPE
63d1ff1f77b0        dev                 bridge           local

您还可以过滤 ID 中的子字符串,如下所示:

$ docker network ls --filter id=95e74588f40d
NETWORK ID          NAME                DRIVER          SCOPE
95e74588f40d        foo                 bridge          local

$ docker network ls --filter id=95e
NETWORK ID          NAME                DRIVER          SCOPE
95e74588f40d        foo                 bridge          local

标签

过滤器根据单独的值或值与值label的存在来匹配网络。labellabel

以下过滤器将网络与usage标签匹配,无论其值如何。

$ docker network ls -f "label=usage"
NETWORK ID          NAME                DRIVER         SCOPE
db9db329f835        test1               bridge         local
f6e212da9dfd        test2               bridge         local

以下过滤器将具有usage标签和prod值的网络进行匹配。

$ docker network ls -f "label=usage=prod"
NETWORK ID          NAME                DRIVER        SCOPE
f6e212da9dfd        test2               bridge        local

姓名

过滤器name匹配网络名称的全部或部分。

以下过滤器匹配名称包含该foobar字符串的所有网络。

$ docker network ls --filter name=foobar
NETWORK ID          NAME                DRIVER       SCOPE
06e7eef0a170        foobar              bridge       local

您还可以过滤名称中的子字符串,如下所示:

$ docker network ls --filter name=foo
NETWORK ID          NAME                DRIVER       SCOPE
95e74588f40d        foo                 bridge       local
06e7eef0a170        foobar              bridge       local

范围

过滤scope器根据网络范围来匹配网络。

以下示例将网络与swarm范围进行匹配:

$ docker network ls --filter scope=swarm
NETWORK ID          NAME                DRIVER              SCOPE
xbtm0v4f1lfh        ingress             overlay             swarm
ic6r88twuu92        swarmnet            overlay             swarm

以下示例将网络与local范围进行匹配:

$ docker network ls --filter scope=local
NETWORK ID          NAME                DRIVER              SCOPE
e85227439ac7        bridge              bridge              local
0ca0e19443ed        host                host                local
ca13cc149a36        localnet            bridge              local
f9e115d2de35        none                null                local

类型

过滤type器支持两个值;builtin显示预定义网络(bridgenonehost),而custom显示用户定义的网络。

以下过滤器匹配所有用户定义的网络:

$ docker network ls --filter type=custom
NETWORK ID          NAME                DRIVER       SCOPE
95e74588f40d        foo                 bridge       local
63d1ff1f77b0        dev                 bridge       local

通过使用此标志,它允许批量清理。例如,使用此过滤器删除所有用户定义的网络:

$ docker network rm `docker network ls --filter type=custom -q`

尝试删除连接有容器的网络时,将会发出警告。

格式化输出(--format)

格式化选项 ( --format) 使用 Go 模板漂亮地打印网络输出。

下面列出了 Go 模板的有效占位符:

占位符描述
.ID网络ID
.Name网络名字
.Driver网络驱动程序
.Scope网络范围(本地、全球)
.IPv6网络上是否启用 IPv6。
.Internal网络是否是内部网络。
.Labels分配给网络的所有标签。
.Label该网络的特定标签的值。例如{{.Label "project.version"}}
.CreatedAt网络创建时间

使用该--format选项时,该network ls命令将完全按照模板声明的方式输出数据,或者在使用指令时还 table包括列标题。

以下示例使用不带标头的模板,并 为所有网络输出由冒号 ( ) 分隔的ID和条目:Driver:

$ docker network ls --format "{{.ID}}: {{.Driver}}"
afaaab448eb2: bridge
d1584f8dc718: host
391df270dc66: null

要以 JSON 格式列出所有网络,请使用以下json指令:

$ docker network ls --format json
{"CreatedAt":"2021-03-09 21:41:29.798999529 +0000 UTC","Driver":"bridge","ID":"f33ba176dd8e","IPv6":"false","Internal":"false","Labels":"","Name":"bridge","Scope":"local"}
{"CreatedAt":"2021-03-09 21:41:29.772806592 +0000 UTC","Driver":"host","ID":"caf47bb3ac70","IPv6":"false","Internal":"false","Labels":"","Name":"host","Scope":"local"}
{"CreatedAt":"2021-03-09 21:41:29.752212603 +0000 UTC","Driver":"null","ID":"9d096c122066","IPv6":"false","Internal":"false","Labels":"","Name":"none","Scope":"local"}