我们有一个docker镜像,它正在处理samba共享上的一些文件。
为此,我们创建了一个cifs共享,该共享挂载到/mnt/dfs,可以使用以下命令访问容器中的文件:
docker run -v /mnt/dfs/project1:/workspace image现在我要做的是将容器放到k8s中,并从pod访问cifs共享,可以使用cifs卷驱动程序usiong FlexVolume。这就是出现一些问题的地方。
我安装了这个存储库作为一个守护进程
https://k8scifsvol.juliohm.com.br/
它已经启动并运行了。
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: cifs-volumedriver-installer
spec:
selector:
matchLabels:
app: cifs-volumedriver-installer
template:
metadata:
name: cifs-volumedriver-installer
labels:
app: cifs-volumedriver-installer
spec:
containers:
- image: juliohm/kubernetes-cifs-volumedriver-installer:2.4
name: flex-deploy
imagePullPolicy: Always
securityContext:
privileged: true
volumeMounts:
- mountPath: /flexmnt
name: flexvolume-mount
volumes:
- name: flexvolume-mount
hostPath:
path: /usr/libexec/kubernetes/kubelet-plugins/volume/exec/接下来要做的是添加一个PeristentVolume,但这需要一个容量,在本例中为1Gi。这是否意味着我们将丢失smb服务器上的所有数据?为什么要为已经存在的服务器提供容量?
另外,如何从pod中访问mount /mnt/dfs的子目录?那么如何从pod中的/mnt/dfs/project1访问数据呢?
我们甚至需要PV吗?pod能否仅从主机的挂载共享中读取?
apiVersion: v1
kind: PersistentVolume
metadata:
name: mycifspv
spec:
capacity:
storage: 1Gi
flexVolume:
driver: juliohm/cifs
options:
opts: sec=ntlm,uid=1000
server: my-cifs-host
share: /MySharedDirectory
secretRef:
name: my-secret
accessModes:
- ReadWriteMany发布于 2021-05-21 20:30:16
设法让它与fstab/cifs插件一起工作。
将其cifs脚本复制到/usr/libexec/kubernetes/kubelet-plugins/volume/exec,并授予其执行权限。还要在所有节点上重新启动kubelet。
然后添加了
containers:
- name: pablo
image: "10.203.32.80:5000/pablo"
volumeMounts:
- name: dfs
mountPath: /data
volumes:
- name: dfs
flexVolume:
driver: "fstab/cifs"
fsType: "cifs"
secretRef:
name: "cifs-secret"
options:
networkPath: "//dfs/dir"
mountOptions: "dir_mode=0755,file_mode=0644,noperm"现在在容器中有了指向//dfs/dir的/data挂载
发布于 2021-05-21 15:50:41
不,该字段对您链接的FlexVol插件没有影响。它甚至不会解析出您传入的大小:)
https://stackoverflow.com/questions/67632578
复制相似问题