三步解决,dial tcp: lookup production.cloudflare.docker.com on 114.114.114.114:53: read udp i/o timeout

本文提供了解决Docker DNS超时问题的步骤:更换DNS服务器、使用国内镜像并配置hosts文件来避免DNS查询超时。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

突然间,我的docker开始报类似这样的错误

dial tcp: lookup production.cloudflare.docker.com on 114.114.114.114:53: read udp 192.168.1.117:25690->114.114.114.114:53: 
i/o timeout

真的是莫名其妙啊!各大站点逛遍也没有找到一个明确的解释!很寒心啊!

在这里,我明确地提出解决办法,按照我说的做,你就能解决!

首先,出问题的是我在公司的电脑,一台ubuntu 16.04 .

1.首先,这条log里包含一个信息。我的是114.114.114.114 也有人的是8.8.8.8 ,这是什么呢?是dns服务器,最开始的时候,我的dns是本地路由器,后来换成了114.114.114.114。所以,你要做的第一件事情就是,如果没有设置过dns的,先换一个dns。

2.第二步,docker仓库换到国内镜像,可以是DaoCloud的加速器,也可以是网易的,或者阿里的。设置完了service docker restart。

3.第三步,这时候其实做好了准备工作,接下来,继续执行之前报错的docker 命令,一般pull镜像就OK了,比如,docker pull python,每一次报错,都记录下log信息,比如第一次

dial tcp: lookup index.docker.io on 114.114.114.114:53: read udp 192.168.1.117:25690->114.114.114.114:53: i/o timeout

发现没,这其实是通过代理方式请求dns服务器,获取index.docker.io的ip超时了。原因可能是随机的本机(192.168.1.117)某端口无法正常访问。所以,为了避免向dns服务器请求,直接手动ping index.docker.io 的方式获取ip,然后写到hosts里面。

#其实所有会出现的log,是这样的
dial tcp: lookup [des-domin] on [dns-ip]:53: read udp [local-ip]:25690->[dns-ip]:53: i/o timeout

要做的,也很简单

ping [des-domin]

拿到ip,然后把这一条映射存到/etc/hosts里。

然后重复pull,ping,hosts。我只添加了两条dns映射就解决了。相信你也不会很多。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ucsheep

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值