首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用dask-kubernetes在Dask worker上挂载卷?

如何使用dask-kubernetes在Dask worker上挂载卷?
EN

Stack Overflow用户
提问于 2020-02-01 00:28:24
回答 1查看 188关注 0票数 1

我使用以下代码创建了一个集群

代码语言:javascript
复制
from dask_kubernetes import KubeCluster
cluster = KubeCluster.from_yaml('worker.yaml')
cluster.adapt(minimum=1, maximum=10)

使用以下yaml代码(worker.yaml):

代码语言:javascript
复制
kind: Pod
metadata:
  labels:
    foo: bar
spec:
  restartPolicy: Never
  containers:
  - image: daskdev/dask:latest
    imagePullPolicy: IfNotPresent
    args: [dask-worker, --nthreads, '4', --no-bokeh, --memory-limit,  3GB, --death-timeout, '300']
    name: dask
    resources:
      limits:
        cpu: "4"
        memory: 3G
      requests:
        cpu: "2"
        memory: 2G

这就像预期的一样。现在,我添加了一个卷装载,如下所示

代码语言:javascript
复制
kind: Pod
metadata:
  labels:
    foo: bar
spec:
  restartPolicy: Never
  containers:
  - image: daskdev/dask:latest
    imagePullPolicy: IfNotPresent
    args: [dask-worker, --nthreads, '4', --no-bokeh, --memory-limit,  3GB, --death-timeout, '300']
    name: dask
    resources:
      limits:
        cpu: "4"
        memory: 3G
      requests:
        cpu: "2"
        memory: 2G
    volumeMounts:
    - name: somedata
      mountPath: /opt/some/data
  volumes:
  - name: somedata
    azureFile:
      secretName: azure-secret
      shareName: somedata
      readOnly: true

我没有看到卷被挂载。但是当我简单地运行

代码语言:javascript
复制
kubectl create -f worker.yaml

我可以看到卷正在挂载。

KubeCluster是否支持卷挂载?如果是这样,您如何配置它们?

EN

回答 1

Stack Overflow用户

发布于 2020-05-26 17:52:06

在使用HostPath卷进行测试时,我无法重现您的问题。

代码语言:javascript
复制
from dask_kubernetes import KubeCluster
cluster = KubeCluster.from_yaml('worker.yaml')
cluster.adapt(minimum=1, maximum=10)
代码语言:javascript
复制
# worker.yaml
kind: Pod
metadata:
  labels:
    foo: bar
spec:
  restartPolicy: Never
  containers:
  - image: daskdev/dask:latest
    imagePullPolicy: IfNotPresent
    args: [dask-worker, --nthreads, '4', --no-bokeh, --memory-limit,  3GB, --death-timeout, '300']
    name: dask
    resources:
      limits:
        cpu: "4"
        memory: 3G
      requests:
        cpu: "2"
        memory: 2G
    volumeMounts:
    - name: somedata
      mountPath: /opt/some/data
  volumes:
  - name: somedata
    hostPath:
      path: /tmp/data
      type: Directory

如果对创建的工作进程运行kubectl describe po <podname>,则可以看到卷已成功创建。

代码语言:javascript
复制
Volumes:
  somedata:
    Type:          HostPath (bare host directory volume)
    Path:          /tmp/data
    HostPathType:  Directory

它被安装在我所期望的位置。

代码语言:javascript
复制
    Mounts:
      /opt/some/data from somedata (rw)

另外,如果我使用kubectl exec -it <podname> bashls /opt/some/data在容器中创建一个外壳程序,我可以看到我在主机路径中创建的文件。

因此,卷可以与KubeCluster一起工作,所以如果您遇到azureFile存储的问题,那么您的Kubernetes集群一定存在一些配置问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60007738

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档