rewrite the fast_config and dns part of the advanced network chapter

This commit is contained in:
Baohua Yang
2014-09-18 14:09:51 +08:00
parent 0d48072d5c
commit a3d8341e27
4 changed files with 40 additions and 39 deletions

View File

@@ -1,5 +1,8 @@
##配置DNS
docker没有定制为每一个容器定制image是怎么提供容器的主机名和dns配置呢秘诀就是它用主机上的3个配置文件来覆盖容器的这3个文件在容器中使用mount命令可以看到
Docker没有每个容器专门定制镜像那么怎么自定义配置容器的主机名和dns配置呢
秘诀就是它利用虚拟文件来挂载到来容器的3个相关配置文件。
在容器中使用mount命令可以看到挂载信息
```
$ mount
...
@@ -8,18 +11,19 @@ $ mount
tmpfs on /etc/resolv.conf type tmpfs ...
...
```
这种机制可以让宿主主机从dhcp更新dns信息后马上更新所有docker容器的dns配置。如果要保持docker中这些文件固定不变你可以不覆盖容器中的这些配置文件然后使用下面的选项来配置它们
配置容器dns服务的方法
这种机制可以让宿主主机DNS信息发生更新后所有Docker容器的dns配置通过`/etc/resolv.conf`文件立刻得到更新
-h HOSTNAME or --hostname=HOSTNAME
设定容器的主机名,它会被写到/etc/hostname/etc/hosts中的ip地址自动写成分配的ip地址在/bin/bash中显示该主机名。但它不会在docker ps中显示也不会在其他的容器的/etc/hosts中显示。
如果用户想要手动指定容器的配置,可以利用下面的选项。
--link=CONTAINER_NAME:ALIAS
这选项会在创建容器的时候添加一个其他容器CONTAINE_NAME的主机名到/etc/hosts文件中让新容器的进程可以使用主机名ALIAS就可以连接它。--link=会在容器之间的通信中更详细的介绍
`-h HOSTNAME or --hostname=HOSTNAME`
设定容器的主机名,它会被写到容器内的`/etc/hostname``/etc/hosts`。但它在容器外部看不到,既不会在`docker ps`中显示,也不会在其他的容器的`/etc/hosts`看到。
--dns=IP_ADDRESS
添加dns服务器到容器的/etc/resolv,conf中让容器用这ip地址来解析所有不在/etc/hosts中的主机名
`--link=CONTAINER_NAME:ALIAS`
选项会在创建容器的时候,添加一个其他容器的主机名到`/etc/hosts`文件中让新容器的进程可以使用主机名ALIAS就可以连接它
--dns-search=DOMAIN
设定容器的搜索域,当设定搜索域为.example.com时会在搜索一个host主机名时dns不仅搜索host还会搜索host.example.com
注意如果没有上述最后2个选项docker会用主机上的/etc/resolv.conf来配置容器它是默认配置。
`--dns=IP_ADDRESS`
添加dns服务器到容器的`/etc/resolv.conf`让容器用这ip地址来解析所有不在`/etc/hosts`中的主机名。
`--dns-search=DOMAIN`
设定容器的搜索域,当设定搜索域为`.example.com`在搜索一个名为host的主机时dns不仅搜索host还会搜索`host.example.com`
注意如果没有上述最后2个选项Docker会默认用主机上的`/etc/resolv.conf`来配置容器。

View File

@@ -1,23 +1,23 @@
##快速配置指南
下面是一个跟docker网络相关的命令列表希望可以让你快速找到需要的信息。有些命令选项只有在docker服务启动的时候才可以执行而且不能马上生效
* -b BRIDGE or --bridge=BRIDGE — 桥接配置
* --bip=CIDR — 定制docker0的掩码
* -H SOCKET... or --host=SOCKET... — 它告诉docker从哪个通道来接收run container stop
container这样的命令也是docker api的地址
下面是一个跟Docker网络相关的命令列表。
* --icc=true|false — 请看下文容器之间的通信
* --ip-forward=true|false — 请看下文容器之间的通信
* --iptables=true|false — 请看下文容器之间的通信
* --mtu=BYTES —请看下文定制docker0
其中有些命令选项只有在Docker服务启动的时候才能配置而且不能马上生效。
* -b BRIDGE or --bridge=BRIDGE --指定容器挂载的网桥
* --bip=CIDR --定制docker0的掩码
* -H SOCKET... or --host=SOCKET... --Docker服务端接收命令的通道
* --icc=true|false --是否支持容器之间进行通信
* --ip-forward=true|false --请看下文容器之间的通信
* --iptables=true|false --禁止Docker添加iptables规则
* --mtu=BYTES --容器网络中的MTU
下面2个可以在docker服务启动和docker run执行的时候指定服务启动的时候指定则会为docker run设定默认值docker run 后面指定可以覆盖默认值。
* --dns=IP_ADDRESS... — 请看下文dns配置
* --dns-search=DOMAIN... — 请看下文dns配置
下面2个命令选项既可以在启动服务时指定也可以Docker容器启动`docker run`时候指定。在Docker服务启动的时候指定则会成为默认值,后面执行`docker run`可以覆盖设置的默认值。
* --dns=IP_ADDRESS... --使用指定的DNS服务器
* --dns-search=DOMAIN... --指定DNS搜索域
最后这些选项只有在docker run后执行,因为它是针对容器的特性内容。
*-h HOSTNAME or --hostname=HOSTNAME 主机名配置
*--link=CONTAINER_NAME:ALIAS — link系统
*--net=bridge|none|container:NAME_or_ID|host —桥接配置
*-p SPEC or --publish=SPEC 映射容器端口到宿主主机
* -P or --publish-all=true|false 映射容器端口到宿主主机
最后这些选项只有在`docker run`执行时使用,因为它是针对容器的特性内容。
* -h HOSTNAME or --hostname=HOSTNAME --配置容器主机名
* --link=CONTAINER_NAME:ALIAS --添加到另一个容器的连接
* --net=bridge|none|container:NAME_or_ID|host --配置容器的桥接模式
* -p SPEC or --publish=SPEC --映射容器端口到宿主主机
* -P or --publish-all=true|false --映射容器所有端口到宿主主机