我有一个流程需要每天在Docker容器中运行,将一些数据从存储桶同步到外部卷(Google Cloud持久磁盘) . 到目前为止,我设法通过创建单节点容器集群来启动该过程 .
由于该过程在几个小时内完成,我想在完成后删除VM资源(当然除了持久性磁盘) . 启动/删除单个计算VM(没有kubernetes集群设置)似乎更简单,因此我试图在容器优化的 Cloud 实例上运行single kubelet . Persistent disk mounting 是失败的地方 .
我的启动命令:
gcloud compute instances create cvm-name-0 \
--image-family=cos-stable \
--image-project=cos-cloud \
--boot-disk-type pd-ssd \
--boot-disk-size 10GB \
--metadata-from-file \
"google-container-manifest=containers.yaml,user-data=cloudinit.yaml" \
--zone "$gzone" \
--scopes default,storage-rw \
--machine-type n1-highcpu-4
container.yaml
的内容:
apiVersion: v1
kind: Pod
metadata:
name: container-name
spec:
containers:
- name: container-name
image: gcr.io/project-name/container-name
imagePullPolicy: Always
volumeMounts:
- name: persistent-disk-name
mountPath: /home/someuser/somedir
volumes:
- name: persistent-disk-name
gcePersistentDisk:
pdName: persistent-disk-name
fsType: ext4
cloudinit.yaml
的内容:
#cloud-config
bootcmd:
- echo "KUBELET_OPTS=\"--cloud-provider=gce\"" > /etc/default/kubelet
runcmd:
- systemctl start kubelet.service
虽然 --cloud-provider=gce
选项修复了每个this question的"Failed to get GCE Cloud Provider"错误,但仍然存在安装磁盘的问题 .
容器操作系统日志中可能相关的行说:
EXT4-fs(dm-0):由于功能不兼容而无法挂载为ext3
有没有办法让这个工作在一个计算实例上(没有kubernetes集群)?我还应该在哪里寻找更多信息错误日志?
1 回答
我目前不使用kubernetes,但我正在备份到 Cloud 存储桶 .
我的cloud-config中有类似的东西: