centos删除docker_Centos7上出现Docker的bug怎么办?两个方法教你解决难题

87fd5f585e168d63e09e95c77d3f5a99.gif

Cannot ssh into a running pod/container – rpc error: code = 2 desc = oci 

runtime error: exec failed: container_linux.go:247: starting container 

process caused “process_linux.go:110: decoding init error from pipe 

caused \“read parent: connection reset by peer\“” command terminated 

with exit code 126 #21590

4527c7946b105c5a733ed353a8e455f4.png0 1

Bug的影响

如果你使用的是 CentOS7,需要用到 kubectl exec 或者为 Pod 配置了基于命令返回值的健康检查(非常用的 HTTP Get 方式)的话,该 Bug 将导致命令返回错误,Pod 无法正常启动,引起大规模故障,而且也无法使用 kubectl exec 或者 docker exec 与容器交互。

 livenessProbe:

     exec:

       command:

       - /usr/local/bin/sidecar-injector

       - probe

       - --probe-path=/health

       - --interval=4s

     failureThreshold: 3

     initialDelaySeconds: 10

     periodSeconds: 4

     successThreshold: 1

     timeoutSeconds: 1

   readinessProbe:

     exec:

       command:

       - /usr/local/bin/sidecar-injector

       - probe

       - --probe-path=/health

       - --interval=4s

     failureThreshold: 3

     initialDelaySeconds: 10

     periodSeconds: 4

     successThreshold: 1

     timeoutSeconds: 1

以上 YAML 配置摘自 Istio 发行版中的 istio-demo.yaml 文件。

4527c7946b105c5a733ed353a8e455f4.png0 2

Bug成因

根据 RedHat 的 Bug 报告,导致该 Bug 的原因是:

CentOS7 发行版中的 Docker 使用的 docker-runc 二进制文件使用旧版本的 golang 构建的,这里面一些可能导致 FIPS 模式崩溃的错误。

4527c7946b105c5a733ed353a8e455f4.png0 3

发现原因

使用docker1.13.1-84的版本创建镜像容器,docker exec总是提示最上面的错误。

4527c7946b105c5a733ed353a8e455f4.png0 4

解决方法

有两种解决方法,都需要替换 Docker 版本。

4-1 降级到旧的 RedHat CentOS 官方源中的 Docker 版本

将 RedHat 官方源中的 Docker 版本降级,这样做的好处是所有的配置无需改动。

查看docker版本

$ rpm -qa | grep -i docker

docker-common-1.13.1-84.git07f3374.el7.centos.x86_64

docker-client-1.13.1-84.git07f3374.el7.centos.x86_64

docker-1.13.1-84.git07f3374.el7.centos.x86_64

降级 Docker 版本

yum downgrade docker-1.13.1-75.git8633870.el7.centos.x86_64 docker-client-1.13.1-75.git8633870.el7.centos.x86_64 docker-common-1.13.1-75.git8633870.el7.centos.x86_64

降级之后再查看 Docker 版本:

$ rpm -qa | grep -i docker

docker-common-1.13.1-75.git8633870.el7.centos.x86_64

docker-1.13.1-75.git8633870.el7.centos.x86_64

docker-client-1.13.1-75.git8633870.el7.centos.x86_64

此为临时解决方法,RedHat 也在着手解决该问题,为了可能会提供补丁,见 Bug 1655214 - docker exec does not work with registry.access.redhat.com/rhel7:7.3。

4-2  更新到 Docker-CE

Docker 自1.13版本之后更改了版本的命名方式,也提供了官方的 CentOS 源,替换为 Docker-CE 亦可解决该问题,不过 Docker-CE 的配置可能会与 Docker 1.13 有所不同,所以可能需要修改配置文件。

02df3c08bd8ec0cf6575b77907c6d2d4.gif

8e0471d5a54290da0b16e7f199897e12.png

链接:https://www.jianshu.com/p/cbe27fcc4bb5

本文为51Testing经授权转载,转载文章所包含的文字来源于作者。如因内容或版权等问题,请联系51Testing进行删除

推荐阅读

点击阅读☞最难调试修复的BUG是怎样的?

点击阅读☞脑壳疼!让程序员改完Bug又发生了啥?!

点击阅读☞程序员总是不搭理你?报bug时需要注意这3点!

点击阅读☞Docker领路,走进压力测试的现代化 | 51上头条

点击阅读☞Docker与自动化测试及其测试实践

a3504f486e9f5179e58d280caf57e5a3.gif

c55535be94afc260369151127197bb5f.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值