news 2026/5/23 14:16:29

CANN 容器化部署:Docker 与 K8s 实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CANN 容器化部署:Docker 与 K8s 实战

一、为什么需要容器化

1.1 容器化优势

裸机部署: 环境依赖复杂,版本冲突 扩缩容困难,手动运维 资源隔离差,互相影响 容器化部署: 环境一致性,开箱即用 弹性扩缩容,自动运维 资源隔离,互不影响 版本管理,灰度发布

1.2 CANN 容器架构

┌──────────────────────────────────────┐ │ Kubernetes 集群 │ ├──────────────────────────────────────┤ │ ┌─────────────┐ ┌─────────────┐ │ │ │ Pod 0 │ │ Pod 1 │ │ │ │ ┌─────────┐ │ │ ┌─────────┐ │ │ │ │ │推理服务 │ │ │ │推理服务 │ │ │ │ │ └─────────┘ │ │ └─────────┘ │ │ │ │ /dev/davinci0│ │ /dev/davinci1│ │ │ └─────────────┘ └─────────────┘ │ ├──────────────────────────────────────┤ │ 宿主机 (Host OS) │ │ ┌──────────────────────────┐ │ │ │ CANN 驱动 + Docker NPU │ │ │ └──────────────────────────┘ │ └──────────────────────────────────────┘

二、Docker 环境搭建

2.1 基础镜像

# Dockerfile.cann-base FROM ubuntu:20.04 # 安装基础依赖 RUN apt-get update && apt-get install -y \ build-essential \ cmake \ git \ wget \ && rm -rf /var/lib/apt/lists/* # 安装 CANN COPY Ascend-cann-toolkit_8.2.RC1_linux-aarch64.run /tmp/ RUN /tmp/Ascend-cann-toolkit_8.2.RC1_linux-aarch64.run --install --quiet \ && rm /tmp/Ascend-cann-toolkit_8.2.RC1_linux-aarch64.run # 设置环境变量 ENV ASCEND_HOME=/usr/local/Ascend ENV PATH=${ASCEND_HOME}/ascend-toolkit/bin:${ASCEND_HOME}/nnae/bin:${PATH} ENV LD_LIBRARY_PATH=${ASCEND_HOME}/ascend-toolkit/lib64:${ASCEND_HOME}/driver/lib64:${LD_LIBRARY_PATH} # 验证安装 RUN npu-smi info WORKDIR /workspace

2.2 构建推理镜像

# Dockerfile.inference FROM cann-base:latest # 安装 Python RUN apt-get update && apt-get install -y python3 python3-pip && \ pip3 install --upgrade pip # 安装依赖 COPY requirements.txt /tmp/ RUN pip3 install -r /tmp/requirements.txt # 复制模型和代码 COPY model/ /workspace/model/ COPY src/ /workspace/src/ # 暴露端口 EXPOSE 50051 # 启动命令 CMD ["python3", "/workspace/src/server.py", "--model", "/workspace/model/model.om"]

2.3 构建与运行

# 构建基础镜像dockerbuild-fDockerfile.cann-base-tcann-base:latest.# 构建推理镜像dockerbuild-fDockerfile.inference-tinference-server:latest.# 运行容器 (需要 NPU 设备)dockerrun-d\--nameinference\--device/dev/davinci0\--device/dev/davinci_manager\--device/dev/devmm_svm\--device/dev/hisi_hdc\-v/usr/local/Ascend:/usr/local/Ascend\-p50051:50051\inference-server:latest

三、NPU 设备透传

3.1 设备挂载参数

# 必须挂载的设备dockerrun-d\--device/dev/davinci0\# NPU 设备节点--device/dev/davinci_manager\# NPU 管理器--device/dev/devmm_svm\# 设备内存管理--device/dev/hisi_hdc\# HDC 通信-v/usr/local/Ascend:/usr/local/Ascend\# CANN 驱动inference-server:latest# 挂载所有 NPU (多卡)dockerrun-d\--device/dev/davinci0\--device/dev/davinci1\--device/dev/davinci2\--device/dev/davinci3\--device/dev/davinci_manager\--device/dev/devmm_svm\--device/dev/hisi_hdc\-v/usr/local/Ascend:/usr/local/Ascend\inference-server:latest

3.2 Docker Compose 配置

# docker-compose.ymlversion:'3.8'services:inference:build:context:.dockerfile:Dockerfile.inferencecontainer_name:inference-serverrestart:unless-stoppedports:-"50051:50051"devices:-/dev/davinci0:/dev/davinci0-/dev/davinci_manager:/dev/davinci_manager-/dev/devmm_svm:/dev/devmm_svm-/dev/hisi_hdc:/dev/hisi_hdcvolumes:-/usr/local/Ascend:/usr/local/Ascend-./model:/workspace/modelenvironment:-ASCEND_HOME=/usr/local/Ascend-PYTHONUNBUFFERED=1deploy:resources:limits:memory:16Greservations:memory:8Gnginx:image:nginx:latestports:-"80:80"volumes:-./nginx.conf:/etc/nginx/nginx.confdepends_on:-inference

四、Kubernetes 部署

4.1 NPU Device Plugin

# npu-device-plugin.ymlapiVersion:apps/v1kind:DaemonSetmetadata:name:ascend-npu-device-pluginnamespace:kube-systemspec:selector:matchLabels:name:ascend-npu-device-plugintemplate:metadata:labels:name:ascend-npu-device-pluginspec:tolerations:-key:CriticalAddonsOnlyoperator:ExistspriorityClassName:system-node-criticalcontainers:-name:npu-device-pluginimage:ascend-k8sdeviceplugin/amd64-npu-plugin:latestimagePullPolicy:IfNotPresentsecurityContext:privileged:truevolumeMounts:-name:device-pluginmountPath:/var/lib/kubelet/device-plugins-name:davincimountPath:/dev/davincivolumes:-name:device-pluginhostPath:path:/var/lib/kubelet/device-plugins-name:davincihostPath:path:/dev/davinci

4.2 推理服务 Deployment

# inference-deployment.ymlapiVersion:apps/v1kind:Deploymentmetadata:name:inference-servernamespace:defaultspec:replicas:3selector:matchLabels:app:inference-servertemplate:metadata:labels:app:inference-serverspec:containers:-name:inferenceimage:inference-server:latestimagePullPolicy:IfNotPresentports:-containerPort:50051name:grpcresources:limits:huawei.com/npu:1# 请求 1 张 NPUrequests:huawei.com/npu:1volumeMounts:-name:model-volumemountPath:/workspace/modelreadinessProbe:grpc:port:50051initialDelaySeconds:10periodSeconds:5livenessProbe:grpc:port:50051initialDelaySeconds:15periodSeconds:10volumes:-name:model-volumepersistentVolumeClaim:claimName:model-pvc---apiVersion:v1kind:Servicemetadata:name:inference-servicenamespace:defaultspec:selector:app:inference-serverports:-name:grpcport:50051targetPort:50051type:ClusterIP

4.3 自动扩缩容

# hpa.ymlapiVersion:autoscaling/v2kind:HorizontalPodAutoscalermetadata:name:inference-hpanamespace:defaultspec:scaleTargetRef:apiVersion:apps/v1kind:Deploymentname:inference-serverminReplicas:2maxReplicas:10metrics:-type:Resourceresource:name:cputarget:type:UtilizationaverageUtilization:70-type:Podspods:metric:name:inference_queue_sizetarget:type:AverageValueaverageValue:"10"behavior:scaleUp:stabilizationWindowSeconds:60policies:-type:Podsvalue:2periodSeconds:60scaleDown:stabilizationWindowSeconds:300policies:-type:Podsvalue:1periodSeconds:120

五、资源限制与隔离

5.1 NPU 资源配额

# resource-quota.ymlapiVersion:v1kind:ResourceQuotametadata:name:npu-quotanamespace:inferencespec:hard:requests.huawei.com/npu:"8"limits.huawei.com/npu:"8"requests.cpu:"32"limits.cpu:"64"requests.memory:"128Gi"limits.memory:"256Gi"

5.2 Pod 资源限制

# pod-with-limits.ymlapiVersion:v1kind:Podmetadata:name:inference-podspec:containers:-name:inferenceimage:inference-server:latestresources:limits:huawei.com/npu:1cpu:"8"memory:"32Gi"requests:huawei.com/npu:1cpu:"4"memory:"16Gi"

六、监控与日志

6.1 Prometheus 指标暴露

fromprometheus_clientimportCounter,Histogram,Gauge,start_http_server# 定义指标INFERENCE_REQUESTS=Counter('inference_requests_total','Total inference requests',['model_name','status'])INFERENCE_LATENCY=Histogram('inference_latency_seconds','Inference latency',['model_name'],buckets=[0.01,0.05,0.1,0.5,1.0,2.0,5.0])NPU_MEMORY_USAGE=Gauge('npu_memory_usage_bytes','NPU memory usage',['device'])# 在推理中记录指标defpredict_with_metrics(model_name,input_data):start=time.time()try:output=server.Inference(input_data)latency=time.time()-start INFERENCE_REQUESTS.labels(model_name=model_name,status='success').inc()INFERENCE_LATENCY.labels(model_name=model_name).observe(latency)returnoutputexceptExceptionase:INFERENCE_REQUESTS.labels(model_name=model_name,status='error').inc()raise# 启动指标服务器start_http_server(8000)

6.2 Grafana 看板

{"dashboard":{"title":"CANN Inference Dashboard","panels":[{"title":"QPS","type":"graph","targets":[{"expr":"rate(inference_requests_total[5m])","legendFormat":"{{model_name}}"}]},{"title":"P99 Latency","type":"graph","targets":[{"expr":"histogram_quantile(0.99, rate(inference_latency_seconds_bucket[5m]))","legendFormat":"{{model_name}}"}]},{"title":"NPU Memory","type":"graph","targets":[{"expr":"npu_memory_usage_bytes","legendFormat":"{{device}}"}]}]}}

七、常见问题

问题原因解决方案
容器内 NPU 不可用设备未挂载添加 --device 参数
NPU 驱动版本不匹配镜像与宿主机驱动版本不一致使用相同版本的 CANN
推理性能下降容器资源限制太严增加 CPU/内存限制
Pod 无法调度NPU 资源不足扩容集群或减少副本数
OOM Killed显存/内存超限增加资源限制或优化模型

相关仓库

  • ascend-docker- 昇腾 Docker 工具 https://gitee.com/ascend/ascend-docker
  • k8s-device-plugin- K8s NPU 插件 https://gitee.com/ascend/k8s-device-plugin
  • ascend-operator- K8s Ascend Operator https://gitee.com/ascend/ascend-operator
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 14:15:50

OpenPilot智能驾驶系统:如何实现300+车型的自动驾驶辅助?

OpenPilot智能驾驶系统:如何实现300车型的自动驾驶辅助? 【免费下载链接】openpilot openpilot is an operating system for robotics. Currently, it upgrades the driver assistance system on 300 supported cars. 项目地址: https://gitcode.com/G…

作者头像 李华
网站建设 2026/5/23 14:12:38

VideoDownloadHelper:打破视频下载壁垒的智能浏览器插件

VideoDownloadHelper:打破视频下载壁垒的智能浏览器插件 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 在信息爆炸的时代&#x…

作者头像 李华
网站建设 2026/5/23 14:12:14

1GHz单片机上部署大模型对话:从模型压缩到推理引擎的嵌入式AI实践

1. 项目概述:当大模型遇见“小”单片机最近在嵌入式圈子里,一个话题的热度正在悄然攀升:能不能让那些动辄需要几十GB显存、跑在云端服务器上的大语言模型(LLM),在一颗主频只有1GHz、内存可能只有几百KB的单…

作者头像 李华
网站建设 2026/5/23 14:11:46

终极指南:在Windows上无缝安装安卓应用的免费神器

终极指南:在Windows上无缝安装安卓应用的免费神器 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 想在Windows电脑上直接运行安卓应用吗?厌倦了…

作者头像 李华
网站建设 2026/5/23 14:11:05

AI Agent重构零售全链路(从导购到补货的12个自动化闭环)

更多请点击: https://intelliparadigm.com 第一章:AI Agent重构零售全链路的范式跃迁 传统零售依赖线性流程与人工决策,在需求预测、库存调度、客户服务等环节普遍存在响应滞后、颗粒度粗、协同断裂等问题。AI Agent 以其自主感知、推理、规…

作者头像 李华
网站建设 2026/5/23 14:08:45

微软Windows拆分:云AI战略转型下的业务重构与行业影响

1. 从“巨无霸”到“手术台”:微软拆分的深层逻辑与行业变局最近几年,关于微软可能进行业务拆分的讨论,就像科技行业的“月经帖”,每隔一段时间就会冒出来。但这一次,市场的风声似乎比以往任何时候都要紧。从“拆分Win…

作者头像 李华