docker - 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。任何想法将不胜感激。
解决方案
当 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/