国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

            手機站
            千鋒教育

            千鋒學習站 | 隨時隨地免費學

            千鋒教育

            掃一掃進入千鋒手機站

            領取全套視頻
            千鋒教育

            關注千鋒學習站小程序
            隨時隨地免費學習課程

            當前位置:首頁  >  技術干貨  > 如何搭建基于容器的深度學習環(huán)境

            如何搭建基于容器的深度學習環(huán)境

            來源:千鋒教育
            發(fā)布人:xqq
            時間: 2023-12-06 14:50:50 1701845450

            歷史上,人工智能的概念幾經沉浮。如今,憑借低成本的存儲、高性能的算力和改進的訓練方法,舊的概念再次煥發(fā)出新的生機。以TensorFlow和PyTorch為代表的一眾深度學習框架的出現(xiàn),更是將這個領域的門檻降到天下何人不煉丹的程度。

            然而,深度學習靠框架,框架還要挑CUDA。

            技術的飛速發(fā)展和訓練框架的野蠻迭代背后,是一地不兼容的版本號,和繞口令一般的困境。

            不同的PyTorch版本依賴不同的CUDA版本

            不同的TensorFlow版本依賴不同的cuDNN版本

            不同的cuDNN版本也依賴不同的CUDA版本

            不同的CUDA版本依賴不同的NVIDIAGPU驅動版本

            最后不同操作系統(tǒng)的不同版本只支持個別版本的GPU驅動

            所以新手最常遇到的場景是,為了運行一份最后更新于三年前的、散發(fā)著古早味的、據(jù)說很厲害的代碼,降級并重裝整個操作系統(tǒng),并且常常因為誤信了網上流傳的同樣古早的二手知識而以失敗告終。

            基于云的GPU環(huán)境一般都會提供預裝的鏡像,但畢竟選擇有限,不能覆蓋所有的場景。數(shù)據(jù)科學家們大多不是工程師,糾纏這些底層細節(jié)既不擅長也無意義。工程化的缺失一直是深度學習領域面臨的重大問題,年輕的煉丹師們流汗又流淚。

            本文將介紹如何基于容器技術快速供給和切換不同的cuDNN/CUDA運行時,輕松搭建不同版本的深度學習環(huán)境。

            GPU容器化的核心是NVIDIA Container Toolkit:

            不同的容器共享GPU硬件和驅動,上層的cuDNN/CUDA組件已經預先打包在鏡像里,CUDA與底層的驅動和操作系統(tǒng)實現(xiàn)解耦,不同版本的運行時可以在同一臺主機上共存,宿主機上只需要安裝最新版本的NVIDIA GPU驅動即可。

            盡管很寬泛,但是NVIDIAContainer Toolkit對操作系統(tǒng)的發(fā)行版和版本號還是有基本的要求:

            上表中常用的操作系統(tǒng),Debian過于保守,Ubuntu太過激進,裝機量較大的CentOS又前途不明,所以我們選擇完全兼容CentOS又有Oracle官方長期支持保障的Oracle Linux作為環(huán)境安裝的基石,這里使用最新的8.4版本。

            首先安裝GPU驅動,NVIDIA提供了三種安裝方式:本地全量rpm包、網絡rpm倉庫和二進制可執(zhí)行文件。毫無疑問應該選擇本地全量rpm包,因為舊的依賴包不久就會被從網絡上移除,而GPU硬件的使用壽命明顯遠遠長于這些軟件,所以不建議選擇網絡倉庫,以免將來無法重新安裝;不選擇二進制可執(zhí)行文件是因為安裝后難以干凈地移除,升級時可能會遇到沖突。

            在https://developer.nvidia.com/cuda-downloads下載全量rpm包:

            安裝內核頭文件,注意OracleLinux默認使用的是UEK內核,如果使用主線內核請做相應調整(安裝kernel-devel):

            【代碼】

            安裝驅動模塊和必要的依賴:

            【代碼】

            第二步,安裝并啟動Docker服務:

            【代碼】

            最后,安裝NVIDIA Container Toolkit并且重啟Docker服務:

            【代碼】

            NVIDIA在https://gitlab.com/nvidia/container-images/cuda/blob/master/doc/supported-tags.md提供了從CUDA 9.2到CUDA 11..4.1的多種官方鏡像,創(chuàng)建不同版本的cuDNN/CUDA運行時只需要簡單拉取對應的鏡像即可。

            比如安裝PyTorch 1.9.0所需的CUDA 10.2:

            【代碼】

            【輸出】

            不要被右上角的CUDA版本號嚇到,它只是表明當前宿主機的GPU驅動所能支持CUDA的最高版本,容器中真正的CUDA版本可以通過nvcc命令來驗證:

            【代碼】

            【輸出】

            祝煉丹成功。

            tags: IT培訓
            聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
            10年以上業(yè)內強師集結,手把手帶你蛻變精英
            請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
            免費領取
            今日已有369人領取成功
            劉同學 138****2860 剛剛成功領取
            王同學 131****2015 剛剛成功領取
            張同學 133****4652 剛剛成功領取
            李同學 135****8607 剛剛成功領取
            楊同學 132****5667 剛剛成功領取
            岳同學 134****6652 剛剛成功領取
            梁同學 157****2950 剛剛成功領取
            劉同學 189****1015 剛剛成功領取
            張同學 155****4678 剛剛成功領取
            鄒同學 139****2907 剛剛成功領取
            董同學 138****2867 剛剛成功領取
            周同學 136****3602 剛剛成功領取
            相關推薦HOT
            嵌入式培訓課程:探索技術的無限可能

            近年來,嵌入式系統(tǒng)的廣泛應用已經深刻改變了我們的生活方式。從智能手機到智能家居,從汽車到醫(yī)療設備,嵌入式技術已經成為現(xiàn)代社會不可或缺的...詳情>>

            2023-12-12 11:02:35
            嵌入式開發(fā):Linux網絡編程的探索與實踐

            在當今的科技世界中,嵌入式系統(tǒng)已經滲透到我們生活的方方面面,從智能手機、電視、汽車到醫(yī)療設備等。而在這些設備中,Linux網絡編程扮演著至...詳情>>

            2023-12-12 09:55:55
            Java游戲項目開發(fā):技術概覽與實踐

            在數(shù)字化世界中,游戲已經成為了人們休閑娛樂的重要方式之一。隨著科技的不斷進步,游戲開發(fā)行業(yè)也在不斷發(fā)展,而Java作為一門廣泛使用的編程語...詳情>>

            2023-12-12 08:49:15
            Web前端的基石:HTML

            在數(shù)字化的時代,網頁設計已經成為了一個重要的領域。而在這個領域中,HTML(HyperTextMarkupLanguage)無疑是最基礎、最重要的一環(huán)。它是構建...詳情>>

            2023-12-12 08:15:55
            嵌入式開發(fā):內存分配的方式

            嵌入式系統(tǒng)開發(fā)中,內存分配是一個至關重要的話題。嵌入式系統(tǒng)通常具有有限的內存資源,因此合理的內存分配方式對系統(tǒng)的性能和穩(wěn)定性至關重要。...詳情>>

            2023-12-12 06:35:55