在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

AI計算教程,從單機到集群

云知聲 ? 來源:djl ? 作者:云知聲 ? 2019-08-09 09:20 ? 次閱讀

AI 計算:從單機到集群(上)中我們介紹了任務計算容器化的概念,解決單機計算的便利性問題。當我們進一步深入使用,尤其是有多臺計算節點時,會面臨一個新問題:多臺 GPU 節點如何實現 GPU 資源的合理自動分配,達到共享使用 GPU 集群資源的目的。本篇介紹如何利用 Kubernetes 實現 GPU 資源的集群化管理,我們結合 Kubernetes 相關源碼,詳細分析 Kubernetes 框架下 GPU 設備管理邏輯和方式,以及如何實現對 GPU 資源的調度,幫助大家邁出從單機到集群的關鍵一步。

Kubernetes

容器技術簡化了計算框架單機運行的問題,但是沒法解決多機資源分配問題。雖然目前很多計算框架支持分布式運行,但缺少資源分配和調度的功能。這就是本篇我們所需要解決的問題,我們期望計算平臺(集群)能夠提供 GPU 任務調度、監控、失敗重啟等全生命周期管理的功能。當集群計算規模擴大時,如果沒有這些功能,我們很難手工地去每一個計算節點上啟動計算任務,也無法實時監控任務運行。除此之外,目前大多數分布式計算框架不支持生命周期管理,結束的訓練進程并不會自動關閉,這也需要進行額外的處理。同時,當多用戶共享使用計算資源時,如果依靠人工協調資源分配,會帶來集群資源利用效率低下和使用繁瑣等問題。總之,當存在多機集群或者多用戶共享使用的情況時,我們需要一種平臺幫助我們實現以下目標:

GPU 計算資源的自動調度與管理

計算任務的全生命周期管理

自動實現多用戶任務共享使用計算資源

而我們本篇將要介紹的 Kubernetes 能夠滿足我們上述要求。Kubernetes (簡稱:k8s) 是 Google 開源的容器集群管理系統(內部代號:Borg)。Kubernetes 是一套完備的分布式系統平臺,具有完備的集群管理能力,以容器技術為基礎,為容器化的應用提供部署運行、資源調度、服務發現和動態伸縮等一系列完整功能,提高了大規模容器集群管理的便捷性,包括:容器自動化部署、可擴展資源自動調度機制以及多粒度的資源配額管理等。這是 Kubernetes 針對傳統云服務和云計算所提供的一攬子功能。然而要實現我們所需要的目標,僅僅具備這些功能是不夠的。我們需要能夠對 GPU 資源進行管理和調度,包括更進一步的配額管理功能等。

Kubernetes 從 1.6 版本開始,逐漸開始支持 GPU 資源的調度,而且功能實現也在快速更新迭代,大致分為兩個階段:

在 1.8 版本之前,GPU 的管理在功能實現上比較簡單粗暴,處于試驗階段,具備初步的基本功能,但還不能大規模的應用在生產環境。

在 1.8 版本之后,Kubernetes 重構了 GPU 的管理邏輯,引入 Device Manager 和 Device Plugin 組件,以更加規范完善的框架實現對擴展硬件的支持,不局限于只支持 GPU 硬件資源,還支持 FPGA,InfiniteBand 等。除此之外,還添加了設備健康檢查等新功能。

本篇以 Kubernetes 1.10 版本為例,介紹 Kubernetes 如何實現 GPU 資源管理與調度,以及用戶如何利用 Kubernetes 提交 GPU 任務。

Kubernetes 的 GPU 資源管理與調度

Kubernetes 1.8 版本之后,由 Device Manager 管理擴展硬件資源,包括 GPU,FPGA,InfiniteBand 等。不同硬件資源或者同一種硬件的不同廠商均可開發對應設備的 Device Plugin。Device Plugin 按照約定的 API 與 Kubernetes 中的 Device Manager 進行交互,實現對設備的管理、分配、回收以及運行狀態監控和健康檢查。

我們通過 Kubernetes 的代碼可以發現,Device Manager 的功能邏輯集成在 Kubernetes 的核心組件 kubelet 代碼中。Device Manager 與 Device Plugin 交互方式如下圖所示。圖中左側是 Device Manager 的功能邏輯組件(綠色),右側是 Device Plugin 的功能邏輯組件(紅色),其中 Device Plugin 的紅色色塊代表功能執行,Device Manager 的綠色色塊代表功能發起,空心矩形框為雙方的 gRPC Server 邏輯功能。雙方的 gPRC 交互過程分為四種,具體包括:

設備注冊

設備監控

設備分配

設備回收

AI計算教程,從單機到集群

我們以 Nvidia GPU 設備為例,詳細介紹 Device Manager 和 Device Plugin 如何通過這四個交互過程實現對 GPU 的資源管理和調度。Nvidia 官方發布了k8s-device-plugin(github.com/NVIDIA/k8s-device-plugin),我們以此作為 Device Plugin 的示例,下文簡稱插件。

一、Device Plugin

準備工作

k8s-device-plugin 在運行之前,需要準備好 GPU 驅動,確保 GPU 能夠正常工作。k8s-device-plugin 并不提供 GPU 驅動安裝工作,需要管理員在每一個計算節點提前安裝好 GPU 驅動。

k8s-device-plugin 以容器方式或者直接運行在計算節點上,推薦以 daemon set 方式,插件啟動的 YAML 參考官方推薦配置文件(github.com/NVIDIA/k8s-device-plugin/blob/v1.10/nvidia-device-plugin.yml)。

k8s-device-plugin 需要和 Nvidia runtime 配合使用,在集群使用之前,每一個 GPU 計算節點上安裝 Nvidia runtime,并修改 /etc/docker/daemon.json,設置 Nvidia runtime 為默認的 docker runtime,如下所示:

{ "default-runtime": "nvidia", "runtimes": { "nvidia": { "path": "/usr/bin/nvidia-container-runtime", "runtimeArgs": [] } } }

Kubernetes 版本 1.8、1.9 需要添加 kubelet 參數 --feature-gates=DevicePlugins=true 開啟 Device Plugin 功能,在 1.10 版本,此功能已經默認開啟,無需再添加 kubelet 參數。

設備注冊

Device Manager 內部維護一個供插件注冊的 gRPC server,k8s-device-plugin 利用 gRPC 協議,并通過 /var/lib/kubelet/device-plugins/kubelet.sock 向 Device Manager 發起注冊請求,對應的是圖中紅色色塊的 Register 向左邊的 Registry gRPC Server 發送注冊信息,k8s-device-plugin 注冊過程如下:

k8s-device-plugin 向 Device Manager 發起 RegisterRequest gRPC 請求,匯報 GPU 設備的信息:

設備名稱 nvidia.com/gpu

API 版本號

k8s-device-plugin 的 gPRC server unix socket: /var/lib/kubelet/device-plugins/nvidia.sock

Device Manager 響應 RegisterRequest,利用 RegisterResponse 返回響應結果,如果設備注冊成功后,更新節點擴展設備資源狀態信息。

如果 Device Manager 響應成功,k8s-device-plugin 啟動插件端的 gPRC Server,供 Device Manager 與 k8s-device-plugin 通信

AI計算教程,從單機到集群

k8s-device-plugin 通過 kubelet.sock 持續監控 kubelet 的運行狀態,當 kubelet 重啟后,k8s-device-plugin 需要向 Device Manager 重新注冊。由于雙方需要通過 socket 通訊,當k8s-device-plugin 以容器的方式運行時,需要掛載主機的 /var/lib/kubelet/device-plugins/ 目錄。

設備發現

當插件注冊成功后,Device Manager 通過 ListAndWatch gRPC 請求獲取當前設備的列表和健康狀態,這個交互是雙向的,如果設備狀態發生改變,比如當 Device Plugin 檢測到某個設備不健康的時候,就會主動通知 Device Manager。如果這個不健康的設備處于空閑狀態,Device Manager 就會將其挪出可分配列表。如果該設備已經被某個任務使用,kubelet 中止此任務的使用。

設備發現的功能依賴每個插件根據不同設備的具體情況做出不同的處理。k8s-device-plugin 的設備發現過程調用如下:getDevices 函數獲取 GPU UUID ,并傳遞給 Device Manager。GPU UUID 由 k8s-device-plugin 調用 Nvidia 的 NVML 庫獲取。NVIDIA Management Library (NVML)(developer.nvidia.com/nvidia-management-library-nvml)是 Nvidia 官方發布的基于 C 語言接口,用于監控和管理 Nvidia GPU 的工具庫。其編譯版隨 GPU 驅動一起發布。Nvidia 的 nvidia-smi 和其他常用的第三方工具均使用 NVML 作為管理 GPU 的底層接口,k8s-device-plugin 由于是基于 go 語言的實現,所以直接使用了 nvidia-docker 1.0 中 NVML go 語言 Binding(github.com/NVIDIA/nvidia-docker/tree/1.0/src/nvml)。

funcgetDevices()[]*pluginapi.Device{n,err:=nvml.GetDeviceCount()check(err)vardevs[]*pluginapi.Devicefori:=uint(0);i

設備分配

設備分配由插件實現 Allocate 功能,負責配置硬件環境。kubelet 創建任務時,通過 gPRC 調用插件的 Allocate,完成設備的分配,以及確保設備在容器中能正常使用。常見的操作包括設置環境變量、掛載 volume、初始化容器所需的設備等。

k8s-device-plugin 是如何實現 GPU 設備分配呢?借助于AI 計算:從單機到集群(上)介紹的 Nvidia runtime,極大簡化了 GPU 的分配邏輯,所以 k8s-device-plugin 的 Allocate 實現非常優雅,如下面代碼所示,只需要設置容器的環境變量即可。其具體過程是:

Device Manager 傳遞待分配 GPU UUID 列表,調用 k8s-device-plugin 的 Allocate 模塊。

k8s-device-plugin 的 Allocate 模塊設置 Nvidia runtime 的環境變量 NVIDIA_VISIBLE_DEVICES。

response:=pluginapi.ContainerAllocateResponse{Envs:map[string]string{"NVIDIA_VISIBLE_DEVICES":strings.Join(req.DevicesIDs,","),},}

設備回收

在設備回收階段,插件可以做一些比如驅動卸載等收尾工作。由于 GPU 不需要每次任務結束時卸載驅動,k8s-device-plugin 無需處理設備回收工作,任務資源的釋放由 kubelet 控制。

二、Device Manager

Device Manager 的主要功能點包括:

提供注冊 gRPC Server, 接受 Device Plugin 的注冊請求,獲取并維護節點上的設備列表。

與 Device Plugin 保持長連接通信,為 Device Plugin 提供回調函數,當節點設備狀態改變時,Device Plugin 通知 Device Manager 根據設備列表信息,更新節點設備狀態。

設備的分配與管理,維護當前運行任務與已使用設備的映射關系,提供待分配設備列表,并通過調用 Device Plugin 的 Allocate,協助 kubelet 完成任務設備分配相關的工作。

Device Manager 實現結構體如下,包括:

通信 socket 文件

負責注冊的 gRPC Server

activePods 獲取當前運行任務

sourceReady 用于從 checkpoint 移除不活動任務

callback 提供回調給 Device Plugin,用于設備監控狀態

healthyDevices 健康設備列表,unhealthyDevices 問題設備列表,allocatedDevices 已使用設備列表

podDevices 記錄運行任務和已使用的設備映射關系

//ManagerImplisthestructureinchargeofmanagingDevicePlugins.typeManagerImplstruct{socketnamestring socketdirstring endpointsmap[string]endpoint//KeyisResourceName mutexsync.Mutexserver*grpc.Server//activePodsisamethodforlistingactivepodsonthenode//sotheamountofpluginResourcesrequestedbyexistingpods//couldbecountedwhenupdatingallocateddevices activePodsActivePodsFunc//sourcesReadyprovidesthereadinessofkubeletconfigurationsourcessuchasapiserverupdatereadiness.//Weuseittodeterminewhenwecanpurgeinactivepodsfromcheckpointedstate. sourcesReadyconfig.SourcesReady//callbackisusedforupdatingdevices'statesinonetimecall.//e.g.anewdeviceisadvertised,twoolddevicesaredeletedandarunningdevicefails. callbackmonitorCallback //healthyDevicescontainsalloftheregisteredhealthyresourceNamesandtheirexporteddeviceIDs. healthyDevicesmap[string]sets.String //unhealthyDevicescontainsalloftheunhealthydevicesandtheirexporteddeviceIDs. unhealthyDevicesmap[string]sets.String //allocatedDevicescontainsallocateddeviceIds,keyedbyresourceName. allocatedDevicesmap[string]sets.String //podDevicescontainspodtoallocateddevicemapping. podDevicespodDevicesstoreutilstore.StorepluginOptsmap[string]*pluginapi.DevicePluginOptions }

由于篇幅限制,這里對 Device Manager 的實現細節不多做介紹,展開說一下 Device Manager 如何維護當前運行任務與已使用設備的映射關系。每個計算節點上的 Device Manager 創建保存當前運行任務與已使用設備映射關系的 checkpoint 文件 /var/lib/kubelet/device-plugins/kubelet_internal_checkpoint ,其內容如下,分為兩部分:

PodDeviceEntries 保存節點正在運行任務的 PodID,ContainerName,ResourceName, 正在使用的 DeviceIDs 列表,以及 Device Plugin 返回的消息 AllocResp。其中,DeviceIDs 中多個 GPU UUID 代表多卡任務。

RegisteredDevices 保存節點處于健康狀態的設備列表,以 ResourceName 為 key,其值為 DeviceIDs 列表。

將設備使用映射關系通過 checkpoint 文件的方式保存到硬盤上,其目的是為了解決由于 kubelet 重啟帶來的設備映射關系信息丟失的問題。當 kubelet 重啟時,自動讀取硬盤上的 checkpoint 文件以獲得重啟前的設備使用映射關系,保證設備映射關系與實際任務使用的一致性,避免將已經分配的設備當做未使用設備重新分配使用的問題。

{"PodDeviceEntries":[ {"PodUID":"51a38fdb-3ef0-11e8-b8fe-0cc47ae55a2c","ContainerName":"task1","ResourceName":"nvidia.com/gpu","DeviceIDs":[ "GPU-77ccee89-7bbc-8838-a56e-f0ca79518232" ],"AllocResp":"CkIKFk5WSURJQV9WSVNJQkxFX0RFVklDRVMSKEdQVS03N2NjZWU4OS03YmJjLTg4MzgtYTU2ZS1mMGNhNzk1MTgyMzI="}, {"PodUID":"e7f290e2-3be0-11e8-b8fe-0cc47ae55a2c","ContainerName":"task2","ResourceName":"nvidia.com/gpu","DeviceIDs":["GPU-93d815e1-0bda-ea1f-08d9-0864e895553d","GPU-ffd50dfd-2578-342e-9a53-19b0f3d40852","GPU-68aed792-9550-6ef7-bd91-f8422efd7b5a","GPU-a6ec8254-2bd0-3237-142a-496fa2059d73" ],"AllocResp":"Cr4BChZOVklESUFfVklTSUJMRV9ERVZJQ0VTEqMBR1BVLTkzZDgxNWUxLTBiZGEtZWExZi0wOGQ5LTA4NjRlODk1NTUzZCxHUFUtZmZkNTBkZmQtMjU3OC0zNDJlLTlhNTMtMTliMGYzZDQwODUyLEdQVS02OGFlZDc5Mi05NTUwLTZlZjctYmQ5MS1mODQyMmVmZDdiNWEsR1BVLWE2ZWM4MjU0LTJiZDAtMzIzNy0xNDJhLTQ5NmZhMjA1OWQ3Mw==" }],"RegisteredDevices":{"nvidia.com/gpu":["GPU-68aed792-9550-6ef7-bd91-f8422efd7b5a","GPU-02a18b6f-3098-7c10-33f9-ededd1b150b8","GPU-e4ce184a-d4a9-8b90-9ba1-9f40ec4cc2d7","GPU-68258d71-d70e-f8bd-9c9a-b7b5240c8b58","GPU-a6ec8254-2bd0-3237-142a-496fa2059d73","GPU-6d8322d9-b8b5-89ce-2804-5cbaacc7b6ef","GPU-93d815e1-0bda-ea1f-08d9-0864e895553d","GPU-ffd50dfd-2578-342e-9a53-19b0f3d40852","GPU-77ccee89-7bbc-8838-a56e-f0ca79518232","GPU-69bf1feb-66bc-67b9-c38e-c5a38ac93e20" ]} }

用戶使用

我們從用戶角度看一下,從任務提交開始的整個交互工作流程:

用戶提交任務申請,通過在 YAML 文件里指定nvidia.com/gpu申請 X 個 GPU 卡

Scheduler 過濾滿足條件的候選節點

任務 Pod 被分發到節點,該節點 Device Manager 決定待分配設備的 GPU UUID 列表

Device Manager 調用 gPRC Allocate,通知 Device Plugin 將 GPU UUID 列表中的設備映射到任務 Pod 中使用(比如上面介紹的:k8s-device-plugin 設置 Nvidia runtime 的環境變量 NVIDIA_VISIBLE_DEVICES)

任務完成創建

我們也給出 YAML 文件示例,如下面的 YAML 文件所示,用戶提交 GPU 任務時,只需要通過nvidia.com/gpu指定 GPU 使用數量,Kubernetes 的 scheduler 查找合適的節點資源,并自動調度到滿足要求的節點上,由節點上的 kubelet 完成任務的啟動和運行。如果沒有資源空余,則任務會處于 Pending 狀態,等待任務需求的資源滿足,則自動轉入運行狀態。

apiVersion:v1 kind:Pod metadata:name:tensorflow spec:containers:-name:tensorflowargs:["sleep1d"]command:["/bin/sh","-c"]image:tensorflow/tensorflow:latest-gpuresources:limits:nvidia.com/gpu:"1"

Kubernetes 支持對不同的 GPU 資源需求做篩選,比如,可以根據 GPU 型號做任務選擇調度。如下所示,指定使用 Tesla P100 卡,則 Kubernetes 會自動調度任務到 P100 卡的節點上。

apiVersion:v1 kind:Pod metadata:name:tensorflow spec:containers:-name:tensorflowargs:["sleep1d"]command:["/bin/sh","-c"]image:tensorflow/tensorflow:latest-gpuresources:limits:nvidia.com/gpu:"1"nodeSelector:accelerator:nvidia-tesla-p100

這里需要進一步說明下使用 k8s-device-plugin 的一個小 bug,由于 GPU 計算節點上的 docker runtime 默認設置為 Nvidia runtime,而 Nvidia runtime 的 NVIDIA_VISIBLE_DEVICES 環境變量默認值為 all。所以,當用戶提交非 GPU 任務時,如下所示,在 YAML 文件中沒有指定nvidia.com/gpu,則此時,在任務容器中能使用該節點上的所有 GPU 資源。這顯然不是我們期望的,繞過了原有的資源分配邏輯。一種解決方式是在 YAML 文件中顯式設置容器的環境變量 NVIDIA_VISIBLE_DEVICES,如下所示:

apiVersion:v1 kind:Pod metadata:name:tensorflowspec:containers:-name:tensorflowargs:["sleep1d"]command:["/bin/sh","-c"]image:tensorflow/tensorflow:latest-gpuenv:-name:NVIDIA_VISIBLE_DEVICES回顧與展望

本文開始提到 Kubernetes 1.8 之前版本的 GPU 管理比較簡單,這里對 1.8 之前版本的實現邏輯簡單介紹一下,并與本文介紹的 1.8 版本及之后的實現做對比,方便讀者了解 Kubernetes GPU 資源管理和調度的演進歷史,并能對當前實現方式的特點有直觀的認識。

設備發現:1.8 之前版本是通過直接匹配計算節點上的設備文件 /dev/nvidia* 、/dev/nvidia-uvm 和 /dev/nvidiactl。這是一種折中做法,并不是真實的查詢設備信息,存在不可靠的問題。資源的名稱alpha.kubernetes.io/nvidia-gpu,和當前的nvidia.com/gpu也有區別。

設備分配:1.8 之前版本用戶需要在 YAML 文件中顯式掛載驅動相關動態庫,1.8 之后版本用戶不需要掛載。除此之外,在 Allocate 這部分,1.8 之前版本是通過 docker 的 API 實現,這其實不滿足軟件通用性的要求,也是一個臨時的折中做法。1.8 之后版本是通過 Device Manager + Device Plugin 實現。

代碼耦合:1.8 之前版本 GPU 資源管理的代碼耦合在 Kubernetes 代碼中,不利于社區貢獻,而且增加了 Kubernetes 穩定運行的風險。

基于 Device Manager + Device Plugin 方式管理擴展硬件設備,不局限于 GPU,還可以管理 InfiniBand,高性能網卡,FPGA 等。

1.8 之后的版本新增了設備健康檢查,此功能依賴于具體設備的 Device Plugin 實現,1.8 之前版本無健康監控功能。

目前,Kubernetes 社區對 GPU 的功能實現也在快速迭代,大致集中在兩個方向:

當前 GPU 調度的數量均以整數為單位,考慮到利用 Kubernetes 做 GPU Inference,在后續功能改進上,將來有可能實現類似 0.5 這種非整數的調度單位,多容器之間共享 GPU 計算資源。

除了繼續完善 GPU 管理調度的功能外,Kubernetes 與常用 AI 計算框架的結合也是社區工作的重點,兩者的緊密配合將會帶來更加便捷和高效的 AI 計算。

總結

在利用容器技術簡化 AI 計算框架單機運行的基礎上,本文詳細介紹了利用 Kubernetes 實現集群的 GPU 資源調度和管理,重點介紹了當前的 Device Plugin + Device Manager 實現邏輯。并以 Nvidia 官方的 k8s-device-plugin 為例,分析了 k8s-device-plugin 與 Device Manager 的功能交互過程。在介紹 Device Manager 功能點之后,我們從用戶的角度梳理了在 Kubernetes 上 GPU 任務提交的工作流程,并針對不同的應用場景,給出了三個示例。最后,我們回顧了 Kubernetes GPU 功能的演進歷史,對比了 1.8 前后兩個版本實現的優缺點,并展望了未來的發展方向。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 云計算
    +關注

    關注

    39

    文章

    7843

    瀏覽量

    137604
  • 人工智能
    +關注

    關注

    1792

    文章

    47485

    瀏覽量

    239162
  • 代碼
    +關注

    關注

    30

    文章

    4807

    瀏覽量

    68803
收藏 人收藏

    評論

    相關推薦

    基于FPGA的類腦計算平臺 —PYNQ 集群的無監督圖像識別類腦計算系統

    STDP 無監督學習算法,可運用于圖像的 無監督分類。 平臺設計角度: (1)本設計搭建的基于 PYNQ 集群的通用低功耗的大規模類腦計算平臺,搭載 PYNN,NEST 等通用 SNN
    發表于 06-25 18:35

    ADI版的Multisim11拷單機上使用安裝后無法激活

    官網上下載了ADI版的Multisim11,拷單機上使用,安裝后無法激活,請問ADI公司是否只允許在聯網計算機上使用此軟件?未聯網的工控機上如何使用?
    發表于 11-23 08:55

    zookeeper單機版的安裝步驟

    zookeeper安裝單機版以及集群部署
    發表于 03-06 16:39

    Linux下單機版的安裝流程概述

    本文先講述Linux下單機版的安裝流程,集群的配置后續再補上。關于Zookeeper的基本介紹和原來在本文不做更多介紹,可以自行查找。本文的操作流程相對簡單,僅做備忘而已。
    發表于 07-11 06:10

    Firefly集群服務器解決方案

    服務器,而隨著人們對服務器工作負載模式的新需求,越來越多的智能場景需要小型服務器來部署。方案簡介集群服務器解決方案,以多塊核心板的組合方式,提供標準的軟硬件接口,支持分布式AI運算,可用于機器學習
    發表于 08-16 15:09

    K8s 懵圈熟練 – 集群網絡詳解

    是 192.168.0.0/16,我們得到若干 ECS,他們 VPC 網段里分配到 IP 地址。集群階段在以上出初始資源的基礎上,我們利用集群創建控制臺得到集群 CIDR。這個值會以
    發表于 10-14 15:06

    Android AI 之路:Java與Python 攜手同行

    ` Android AI 之路:Java與Python 攜手同行 1.以Python撰寫 AI模型框架(Framework)2.準備Java與Python協同開發環境3.在An
    發表于 12-17 09:52

    色環電阻計算單機

    電子發燒友網站提供《色環電阻計算單機版.exe》資料免費下載
    發表于 08-11 14:03 ?0次下載

    深入了解AI計算單機集群的概括

    平臺中運行著各種計算任務,需要利用鏡像管理系統對所有的任務鏡像提供統一的管理。Docker 官方維護的Docker Registry(https://link.zhihu.com/?target
    的頭像 發表于 08-09 09:29 ?4797次閱讀
    深入了解<b class='flag-5'>AI</b><b class='flag-5'>計算</b><b class='flag-5'>從</b><b class='flag-5'>單機</b><b class='flag-5'>到</b><b class='flag-5'>集群</b>的概括

    AI進階AI,意味著經典計算機過渡到量子計算

    和強人工智能,AI進階AI,代表著人類使用的經典計算機,過渡到量子計算機,強人工智能時代
    的頭像 發表于 10-20 14:34 ?2481次閱讀

    Meta發布采用NVIDIA系統的AI研究超級集群

    Meta的AI超級計算機是迄今為止最大的NVIDIA DGX A100客戶系統。該系統將為Meta的AI研究人員提供5百億億次級AI計算性能
    的頭像 發表于 02-07 10:40 ?1865次閱讀

    計算集群計算有何區別?

    在文本中,小編將給大家分享一下云計算集群計算有何區別? 一、云計算: 云計算是指通過互聯網按需交付IT資源,特別是
    的頭像 發表于 09-11 17:51 ?1467次閱讀

    高性能計算集群的能耗優化

    高性能計算(HighPerformanceComputing,HPC)是指利用大規模并行計算集群來解決復雜的科學和工程問題的技術。高性能計算集群
    的頭像 發表于 05-25 08:27 ?467次閱讀
    高性能<b class='flag-5'>計算</b><b class='flag-5'>集群</b>的能耗優化

    千卡集群卡到萬卡集群,燧原科技打造更好的AI算力底座

    :WAIC 2024)上,不僅有國內各大模型廠商同場競技,也有豐富的算力基礎設施展示,其中包括專注人工智能領域云端算力產品的燧原科技。 ? 燧原科技展臺 千卡集群萬卡集群 ?除了里
    的頭像 發表于 07-07 09:45 ?2387次閱讀
    <b class='flag-5'>從</b>千卡<b class='flag-5'>集群</b>卡到萬卡<b class='flag-5'>集群</b>,燧原科技打造更好的<b class='flag-5'>AI</b>算力底座

    科技云報到:大模型云端,“AI+云計算”還能講出什么新故事

    科技云報到:大模型云端,“AI+云計算”還能講出什么新故事
    的頭像 發表于 01-07 13:27 ?94次閱讀
    主站蜘蛛池模板: www一级毛片| 午夜精品久久久久久久| 欧美a色爱欧美综合v| 女人张开腿男人猛桶视频| 久久mimi色| 免费国内精品久久久久影院| 亚洲天天干| 欧美又黄又嫩大片a级| 国产欧美精品午夜在线播放| 91操碰| 日韩亚洲人成在线综合| 亚洲天堂成人网| 国产精品夜色7777青苹果| xxxx大片| 国产一区中文字幕在线观看| 性大特级毛片视频| 一级特黄女人生活片| 欧美一区二区三区不卡免费观看| 欧美 亚洲 一区| 亚洲欧美日韩在线精品2021| 色多多·com| 三级黄色录像| 久草视频资源在线| 97av视频在线播放| 久久观看| 一区二区3区免费视频| 亚洲国产日韩精品怡红院 | 久久久精品免费| 8888四色奇米在线观看不卡| 看黄网站免费| 日本黄色站| 亚洲+国产+图片| 欧美一区二区影院| 欧美zooz人与禽交| 二级黄色大片| 精品福利在线视频| 日本a级特黄三级三级三级| 婷婷99视频精品全部在线观看| 亚洲激情| 两性毛片| 色天天天天|