记录一次破坏集群node节点镜像文件,节点调度失败的问题,failed to register layer

原因:k8s 某一node docker 根目录磁盘不足。修改docker默认的存储路径,将之间的docker 目录同步到新的存储路径,中间有一些操作导致文件缺失。

  1. 查看节点状态

    kubectl get nodes
    

    节点正常。但是pod并没有调度到节点上。

  2. 排查问题,发现节点使用pull image 会报错,错误信息如下

    failed to register layer: symlink ../88be7b5d39d745b76c97dea7c242a2ce5df7c619455255f5dc5ed5c2e01d4b3d/diff /data/docker/overlay2/l/QTAOVO74TH53ZCX47XRXER256Q: no such file or directory: Process exited with status 1
    

    发现是因为镜像文件损坏,docker按照之前的目录构建镜像时,找不到文件。

  3. 重新pull镜像,发现还是会根据之前的目录构建镜像,个人猜测是因为docker元数据保存了之前镜像的镜像层信息。

  4. 解决办法
    删除docker 镜像目录 data/docker/
    停止docker

    systemctl stop docker.service
    systemctl stop docker.socket
    

    删除docker
    重新安装

    yum install docker
    

    重新pull镜像

注意:如果涉及删除docker关联的挂载数据,请谨慎操作。欢迎大家多多交流。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,我可以为您提供一个k8s集群中布置node节点的资源配置文件,如下所示: apiVersion: v1 kind: Pod metadata: name: node spec: containers: - name: node image: your-image resources: requests: cpu: 500m memory: 512Mi limits: cpu: 100m memory: 1Gi 您需要将上述配置文件保存为yaml格式,然后使用kubectl apply命令将其应用到您的k8s集群中的每个node节点上。如果您的node节点数量不止5台,您需要将该配置文件复制并修改节点名称,以适应您的实际情况。 ### 回答2: 在Kubernetes集群中,每个节点Node)代表一台物理或虚拟机器,用于运行应用程序和容器。每个节点都需要通过资源配置文件(Node配置文件)进行相关的配置。 为了布置5台node节点的资源配置文件,需要按照以下步骤进行: 1. 创建一个主机名列表:将5台node节点的主机名按顺序写入一个文本文件,例如: ``` node1 node2 node3 node4 node5 ``` 2. 创建每个节点的资源配置文件:对于每台节点,创建一个YAML格式的资源配置文件,例如node1.yaml,node2.yaml,以此类推。示例内容如下: ```yaml apiVersion: v1 kind: Node metadata: name: node1 labels: type: worker spec: capacity: cpu: "4" memory: 8Gi allocatable: cpu: "4" memory: 8Gi # 可根据实际情况配置其他资源,例如磁盘空间、GPU等 ``` 在每个配置文件中,可以根据实际情况设置节点的资源容量(capacity)和可分配资源(allocatable)。可以根据需求配置CPU核心数、内存大小等,也可以添加其他自定义的资源。 3. 应用资源配置文件:通过Kubernetes的API Server将每个节点的资源配置文件应用到集群中。使用kubectl工具执行如下命令: ``` kubectl apply -f node1.yaml kubectl apply -f node2.yaml kubectl apply -f node3.yaml kubectl apply -f node4.yaml kubectl apply -f node5.yaml ``` 以上命令将会依次应用每个节点的资源配置文件,并将相应的资源配置信息存储在Kubernetes集群的etcd中。 通过以上步骤,您就可以成功布置5台node节点的资源配置文件。根据实际需求可以根据上述示例调整配置文件中的资源参数。 ### 回答3: 在Kubernetes(K8s集群中为5个节点配置资源文件,可以按照以下步骤进行: 1. 首先,创建一个空的资源配置文件,并设置一个高级别的API版本和类型: ```yaml apiVersion: v1 kind: ConfigMap ``` 2. 为每个节点创建一个配置块,配置块的名称根据节点的名称进行命名,例如: ```yaml data: node1.yaml: | --- apiVersion: v1 kind: Node metadata: name: node1 spec: capacity: cpu: "4" memory: 8Gi storage: 50Gi node2.yaml: | --- apiVersion: v1 kind: Node metadata: name: node2 spec: capacity: cpu: "2" memory: 4Gi storage: 100Gi node3.yaml: | --- apiVersion: v1 kind: Node metadata: name: node3 spec: capacity: cpu: "8" memory: 16Gi storage: 200Gi node4.yaml: | --- apiVersion: v1 kind: Node metadata: name: node4 spec: capacity: cpu: "4" memory: 8Gi storage: 100Gi node5.yaml: | --- apiVersion: v1 kind: Node metadata: name: node5 spec: capacity: cpu: "2" memory: 4Gi storage: 50Gi ``` 以上是一个示例,您可以根据需求调整每个节点的资源配置如cpu、memory和storage的值。 3. 将每个配置块的内容保存为独立的YAML文件,并将其作为data字段的值进行配置。 4. 将所有节点的配置块添加到资源配置文件中: ```yaml apiVersion: v1 kind: ConfigMap data: node1.yaml: | ... node2.yaml: | ... node3.yaml: | ... node4.yaml: | ... node5.yaml: | ... ``` 将每个节点的配置块使用正确的缩进添加到data字段下。 5. 保存和应用资源配置文件: ```bash $ kubectl apply -f node_config.yml ``` 经过上述步骤,您就能成功在K8s集群中为5个节点配置资源文件。请注意根据实际需求自行调整每个节点的资源配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值