首页 > 解决方案 > Docker 容器在 kubernetes 内工作/不工作

问题描述

我在这里有点困惑。它确实像普通的 docker 容器一样工作,但是当它进入 pod 时它不会。所以这就是我的做法。

Dockerfile 在我的本地创建图像并发布到 docker 注册表

FROM alpine:3.7
COPY . /var/www/html
CMD tail -f /dev/null

现在,如果我只是拉出图像(在删除本地之后)并作为容器运行。它可以工作,我可以在 /var/www/html 中看到我的文件。

现在我想在我的 kubernetes 集群中使用它。

定义:Minikube --vm-driver=none

我在 minikube 中运行 kube,但没有驱动程序选项。所以对于单节点集群。

编辑

如果我从部署文件中删除卷安装和声明,我可以在 /var/www/html 中看到我的数据。

部署文件

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    io.kompose.service: app
  name: app
spec:
  replicas: 1
  strategy:
    type: Recreate
  template:
    metadata:
      creationTimestamp: null
      labels:
        io.kompose.service: app
    spec:
      securityContext:
        runAsUser: 1000
        runAsGroup: 1000
      containers:
      - image: kingshukdeb/mycode
        name: pd-mycode
        resources: {}
        volumeMounts:
        - mountPath: /var/www/html
          name: claim-app-storage
      restartPolicy: Always
      volumes:
      - name: claim-app-storage
        persistentVolumeClaim:
          claimName: claim-app-nginx
status: {}

PVC文件

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  creationTimestamp: null
  labels:
    io.kompose.service: app-nginx1
  name: claim-app-nginx
spec:
  storageClassName: testmanual
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 100Mi
status: {}

文件

apiVersion: v1
kind: PersistentVolume
metadata:
  name: app-nginx1
  labels:
    type: local
spec:
  storageClassName: testmanual
  capacity:
    storage: 100Mi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: "/data/volumes/app"

现在,当我运行这些文件时,它会创建 pod、pv、pvc 和 pvc 绑定到 pv。但如果我进入我的容器,我看不到我的文件。hostpath/data/volumes/app。任何想法将不胜感激。

标签: dockerkuberneteskubernetes-pod

解决方案


当 PVC 绑定到 pod 时,卷将安装在 pod/deployment yaml 文件中描述的位置。在你的情况下:mountPath: /var/www/html。这就是无法访问“烘焙到”容器映像中的文件的原因(简单解释为什么在这里

kubectl exec YOUR_POD -i -t -- /bin/sh您可以通过 running和 running对容器执行 exec 来确认这一点mount | grep "/var/www/html"

解决方案

您可以通过多种方式解决此问题。最好的做法是将静态数据分开(即在 PV 中),并使容器映像尽可能小且快。

如果您将要在 PV 中挂载的文件传输到主机路径/data/volumes/app,它们将可以在您的 pod 中访问,那么您可以创建新图像而省略该COPY操作。这样,即使 pod 崩溃,您的应用程序对文件所做的更改也将被保存。

如果 PV 将被多个 pod 认领,您需要按照此处accessModes所述进行更改:

访问模式有:

  • ReadWriteOnce – 卷可以由单个节点以读写方式挂载
  • ReadOnlyMany – 卷可以被许多节点以只读方式挂载
  • ReadWriteMany – 卷可以被许多节点以读写方式挂载

Kubernetes 文档中 Volumes 的深入解释: https ://kubernetes.io/docs/concepts/storage/persistent-volumes/


推荐阅读