docker_practice/network/dns.md

45 lines
1.8 KiB
Markdown
Raw Normal View History

## 配置 DNS
2017-11-23 21:25:42 +08:00
2017-11-26 11:28:55 +08:00
如何自定义配置容器的主机名和 DNS 呢?秘诀就是 Docker 利用虚拟文件来挂载容器的 3 个相关配置文件。
在容器中使用 `mount` 命令可以看到挂载信息:
2017-11-22 11:13:23 +08:00
```bash
2014-09-05 15:50:54 +08:00
$ mount
/dev/disk/by-uuid/1fec...ebdf on /etc/hostname type ext4 ...
/dev/disk/by-uuid/1fec...ebdf on /etc/hosts type ext4 ...
tmpfs on /etc/resolv.conf type tmpfs ...
```
2017-11-23 21:25:42 +08:00
这种机制可以让宿主主机 DNS 信息发生更新后,所有 Docker 容器的 DNS 配置通过 `/etc/resolv.conf` 文件立刻得到更新。
配置全部容器的 DNS ,也可以在 `/etc/docker/daemon.json` 文件中增加以下内容来设置。
```json
{
"dns" : [
"114.114.114.114",
"8.8.8.8"
]
}
```
这样每次启动的容器 DNS 自动配置为 `114.114.114.114``8.8.8.8`。使用以下命令来证明其已经生效。
```bash
2018-07-10 08:09:10 +08:00
$ docker run -it --rm ubuntu:18.04 cat etc/resolv.conf
2017-11-23 21:25:42 +08:00
nameserver 114.114.114.114
nameserver 8.8.8.8
```
2017-12-10 10:51:40 +08:00
如果用户想要手动指定容器的配置,可以在使用 `docker run` 命令启动容器时加入如下参数:
2014-09-05 15:50:54 +08:00
`-h HOSTNAME` 或者 `--hostname=HOSTNAME` 设定容器的主机名,它会被写到容器内的 `/etc/hostname``/etc/hosts`。但它在容器外部看不到,既不会在 `docker container ls` 中显示,也不会在其他的容器的 `/etc/hosts` 看到。
2014-09-05 15:50:54 +08:00
2017-11-26 11:28:55 +08:00
`--dns=IP_ADDRESS` 添加 DNS 服务器到容器的 `/etc/resolv.conf` 中,让容器用这个服务器来解析所有不在 `/etc/hosts` 中的主机名。
2014-09-05 15:50:54 +08:00
2017-11-26 11:28:55 +08:00
`--dns-search=DOMAIN` 设定容器的搜索域,当设定搜索域为 `.example.com` 时,在搜索一个名为 host 的主机时DNS 不仅搜索 host还会搜索 `host.example.com`
2017-11-27 14:31:01 +08:00
2017-12-10 10:51:40 +08:00
>注意如果在容器启动时没有指定最后两个参数Docker 会默认用主机上的 `/etc/resolv.conf` 来配置容器。