Windows安裝Docker Desktop開啟 Kubenetes制作并部署本地鏡像

1、安裝Docker Desktop

docker desktop官方下載鏈接,下載后一路點下來安裝就好了。

2、制作本地鏡像

跟著docker步驟制作鏡像,需要先配置docker 鏡像源,因為網絡問題

{"builder": {"gc": {"defaultKeepStorage": "20GB","enabled": true}},"debug": true,"dns": ["8.8.8.8","8.8.4.4"],"experimental": false,"features": {"buildkit": false},"insecure-registries": ["registry.docker-cn.com","docker.mirrors.ustc.edu.cn"],"registry-mirrors": ["https://docker.registry.cyou","https://docker-cf.registry.cyou","https://dockercf.jsdelivr.fyi","https://docker.jsdelivr.fyi","https://dockertest.jsdelivr.fyi","https://mirror.aliyuncs.com","https://dockerproxy.com","https://mirror.baidubce.com","https://docker.m.daocloud.io","https://docker.nju.edu.cn","https://docker.mirrors.sjtug.sjtu.edu.cn","https://docker.mirrors.ustc.edu.cn","https://mirror.iscas.ac.cn","https://docker.rainbond.cc","https://do.nark.eu.org","https://dc.j8.work","https://dockerproxy.com","https://gst6rzl9.mirror.aliyuncs.com","https://registry.docker-cn.com","http://hub-mirror.c.163.com","http://mirrors.ustc.edu.cn/","https://mirrors.tuna.tsinghua.edu.cn/","http://mirrors.sohu.com/"]
}

git clone https://github.com/docker/welcome-to-docker

cd welcome-to-docker

檢查dockerfile,并執行

docker build -t welcome-to-docker .

制作好之后,images列表就有了:


?

3、在docker desktop運行鏡像

?在Images列表,找到鏡像,點擊三角形run,指定端口,就可用運行。

例如名字是hello-docker,端口是8090,運行后,就會在Containers中出現,可查看日志、執行命令。

3、開啟Kubenetes

如果需要Kubenetes管理鏡像,可用在docker desktop開啟,因為網絡原因,要從阿里云鏡像源下載kubenetes的鏡像。

clone??k8s-for-docker-desktop?這個項目,找到?load_images.ps1?這個 powershell 文件,直接運行,

在powershell中執行

./load_images.ps1?

如果沒有權限,可用先執行

Set-ExecutionPolicy RemoteSigned

images.properties?文件中列到的鏡像可以看到kubenetes的版本,注意要與Docker Desktop的相同。

這樣就把kubenetes的鏡像拉下來了。

然后點擊設置,啟用Kubenetes

Apply&Restart之后,左下角就看見Kubenetes running了。

4、在Kubenetes運行鏡像

剛剛制作的鏡像要在kubenetes運行,就需要一個k8s.yaml

apiVersion: apps/v1
kind: Deployment
metadata:name: hello-docker-deployment # 部署的名稱namespace: defaultlabels:app: hello-docker  # 給資源打標簽,便于篩選和管理
spec:replicas: 2  # 定義副本數量以確保高可用selector:matchLabels:app: hello-docker  # 匹配 Pod 的標簽,確保服務與 Pod 綁定template:metadata:labels:app: hello-docker  # Pod 的標簽,需與 selector 對應spec:containers:- name: hello-docker  # 容器名稱imagePullPolicy: Neverimage: welcome-to-docker:latest  # 使用構建的鏡像名稱和標簽,從遠程倉庫拉取鏡像ports:- containerPort: 3000  # 容器內部監聽的端口env:- name: FLASK_APPvalue: "app.py"  # 設置 Flask 的主程序文件- name: FLASK_ENVvalue: "production"  # 設置 Flask 的運行環境- name: PYTHONDONTWRITEBYTECODEvalue: "1"  # 禁止生成 .pyc 文件- name: PYTHONUNBUFFEREDvalue: "1"  # 設置 Python 日志為非緩沖模式resources:  # 資源限制requests:memory: "128Mi"  # 請求的最小內存cpu: "250m"  # 請求的最小 CPUlimits:memory: "256Mi"  # 最大允許使用的內存cpu: "500m"  # 最大允許使用的 CPUlivenessProbe:  # 存活探針,用于檢測服務是否存活httpGet:path: "/"  # 檢測的路徑port: 3000  # 檢測的端口initialDelaySeconds: 5  # 初始延遲periodSeconds: 10  # 檢測間隔readinessProbe:  # 就緒探針,用于檢測服務是否準備好接收流量httpGet:path: "/"  # 檢測的路徑port: 3000  # 檢測的端口initialDelaySeconds: 5  # 初始延遲periodSeconds: 10  # 檢測間隔restartPolicy: Always  # 容器策略:始終重啟
---
apiVersion: v1
kind: Service
metadata:name: hello-docker-service # 服務的名稱labels:app: hello-docker  # 標簽與 Deployment 一致
spec:selector:app: hello-docker  # 匹配 Deployment 的標簽ports:- protocol: TCPnodePort: 30008  # 可以省略,Kuberrnetes 會自動分配一個端口 范圍 30000-32767port: 3000  # 服務暴露的端口targetPort: 3000  # 轉發到容器的端口type: NodePort    # 服務類型,NodePort 通過在每個 Node 上打開一個特定端口,將外部請求轉發到集群內部的Service,進而達到后端的Pod

然后執行命令即可(這里本地運行的關鍵是yaml的? imagePullPolicy: Never,不然就要將鏡像推送到docker倉庫才行)

kubectl create -f k8s.yaml

?因為k8s.yaml定義了30008端口映射3000,所以使用http://localhost:30008/訪問即可:

參考資料:在 Docker Desktop 中啟用 K8s 服務 - 墨墨墨墨小宇 - 博客園

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/906900.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/906900.shtml
英文地址,請注明出處:http://en.pswp.cn/news/906900.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

嵌入式學習筆記 - freeRTOS 列表,鏈表,節點跟任務之間關系

一 下圖說明了 freeRTOS 就緒列表,鏈表,節點跟任務之間關系 一個任務對應一個節點,一個鏈表對應一個優先級,一個任務根據優先級可以插入任何一個鏈表中。 插入函數為,這也是freeRTOS的核心函數,對每個任務…

scikit-learn pytorch transformers 區別與聯系

以下是 scikit-learn、PyTorch 和 Transformers 的區別與聯系的表格形式展示: 特性/庫scikit-learnPyTorchTransformers主要用途傳統機器學習算法深度學習框架預訓練語言模型與自然語言處理任務核心功能分類、回歸、聚類、降維、模型選擇等張量計算、自動微分、神經網絡構建與…

【C/C++】從零開始掌握Kafka

文章目錄 從零開始掌握Kafka一、Kafka 基礎知識理解(理論)1. 核心組件與架構2. 重點概念解析 二、Kafka 面試重點知識梳理三、C 使用 Kafka 的實踐(librdkafka)1. librdkafka 簡介2. 安裝 librdkafka 四、實戰:高吞吐生…

Spyglass:目標文件(.spq)的結構

相關閱讀 Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm1001.2014.3001.5482 預備知識 為了方便檢查,Spyglass向用戶提供Guideware作為檢查參考;Guideware又包含各種方法(Methodology),應用于設計的不同階段&…

一些Dify聊天系統組件流程圖架構圖

分享一些有助于深入理解Dify聊天模塊的架構圖 整體組件架構圖 #mermaid-svg-0e2XalGLqrRbH1Jy {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-0e2XalGLqrRbH1Jy .error-icon{fill:#552222;}#mermaid-svg-0e2XalGLq…

地理空間索引:解鎖日志分析中的位置智慧

title: 地理空間索引:解鎖日志分析中的位置智慧 date: 2025/05/24 18:43:06 updated: 2025/05/24 18:43:06 author: cmdragon excerpt: 地理空間索引在日志分析中應用廣泛,涉及用戶登錄IP定位、移動端位置軌跡和物聯網設備位置上報等場景。MongoDB支持2dsphere和2d兩種地理…

分庫分表深度解析

一、為什么要分庫分表? 通常,數據庫性能受到如下幾個限制: 硬件瓶頸:單機的 CPU、內存、磁盤 I/O 等資源總是有限。例如,當單表中的記錄達到上億、甚至更高時,表掃描、索引維護和數據遷移會變得非常慢。單…

QListWidget的函數,信號介紹

前言 Qt版本:6.8.0 該類用于列表模型/視圖 QListWidgetItem函數介紹 作用 QListWidget是Qt框架中用于管理可交互列表項的核心組件,主要作用包括: 列表項管理 支持動態添加/刪除項:addItem(), takeItem()批量操作:addItems()…

ModbusRTU轉profibusDP網關與RAC400通訊報文解析

ModbusRTU轉profibusDP網關與RAC400通訊報文解析 在工業自動化領域,ModbusRTU和ProfibusDP是兩種常見的通信協議。ModbusRTU以其簡單、可靠、易于實現等特點,廣泛應用于各種工業設備之間的通信;而ProfibusDP則是一種高性能的現場總線標準&am…

Python容器

一、容器 1. 列表【】:有序可重復可混裝可修改 [元素1,元素2,元素3,...] ? 可以容納多個元素 ? 可以容納不同類型的元素(混裝) ? 數據是有序存儲的(有下標序號) ? 允許重復數…

webpack面試問題

一、核心概念 Webpack的構建流程是什么? 答案: 初始化:讀取配置,創建Compiler對象編譯:從入口文件開始,遞歸分析依賴關系,生成依賴圖模塊處理:調用Loader轉換模塊(如babel-loader)輸出:將處理后的模塊組合成Chunk,生成最終文件Loader和Plugin的區別? Loader:文件…

uniapp-商城-66-shop(2-品牌信息顯示,數據庫讀取的異步操作 放到vuex actions)

完成頁面的顯示,但是還需要進行修改,這里涉及到修改中的信息同步顯示。也會涉及到數據的讀取,修改和同步。 本文介紹了如何使用Vuex管理品牌數據,實現數據的同步顯示和修改。主要內容包括:1.將獲取品牌數據的異步操作封…

使用Pyinstaller打包python,全過程解析【2025最詳細】

一、如何使用 Pyinstaller 打包 Python 程序 1.打開終端 右鍵點擊文件夾空白處,選擇 打開于 > 打開終端 2.安裝 pyinstaller 在打開的終端中,輸入命令【pip install pyinstaller】 使用 Python 包管理工具 pip 來安裝 Pyinstaller。等待安裝過程結…

GPU加速Kubernetes集群助力音視頻轉碼與AI工作負載擴展

容器編排與GPU計算的結合,為追求性能優化的企業開辟了戰略轉型的新路徑 基于GPU的托管Kubernetes集群不僅是技術選擇,更是徹底改變企業處理高負載任務的戰略部署方式。 隨著人工智能和機器學習項目激增、實時數據處理需求的劇增,以及高性能媒…

LINUX 524 rsync+inotify 調試(問題1:指定端口無法同步/已通過;問題2:rsync.log文件中時間不顯示/已顯示)

怎么把java文件夾給傳過去了 rsync inotify 監控代碼實時傳輸調試 沒看到日志 這里面有了 rsync -e"ssh -p 3712" -av /root/app/java/ code192.168.235.100:/home/code/backup/java_backup/ 文件夾后面的/要加上 [rootlocalhost java]# cat /var/log/rsync.log…

Python入門手冊:條件判斷

條件判斷是編程中不可或缺的一部分,它允許程序根據不同的條件執行不同的代碼塊。Python提供了if、elif和else語句來實現條件判斷。通過這些語句,你可以控制程序的流程,使其能夠根據不同的情況做出相應的反應。本文將詳細介紹Python中的條件判…

x-cmd install | cargo-selector:優雅管理 Rust 項目二進制與示例,開發體驗升級

目錄 功能亮點安裝優勢特點適用場景總結 還在為 Rust 項目中眾多的二進制文件和示例而煩惱嗎?cargo-selector 讓你告別繁瑣的命令行,輕松選擇并運行目標程序! 功能亮點 交互式選擇: 在終端中以交互方式瀏覽你的二進制文件和示例&…

Baklib知識中臺高效實踐路徑

知識中臺全周期構建路徑 Baklib在構建知識中臺全周期管理體系時,以知識價值轉化為核心導向,通過三階段遞進實現閉環運作。在知識采集階段,運用智能爬蟲與API接口技術,聚合分散在業務系統、文檔庫及溝通工具中的碎片化知識資產&am…

mapbox進階,手寫放大鏡功能

????? 主頁: gis分享者 ????? 感謝各位大佬 點贊?? 收藏? 留言?? 加關注?! ????? 收錄于專欄:mapbox 從入門到精通 文章目錄 一、??前言1.1 ??mapboxgl.Map 地圖對象1.1 ??mapboxgl.Map style屬性二、??手寫放大鏡功能1. ??實現思路2. ??…

康佳Java開發面試題及參考答案

面向對象三大特性是什么?請舉例說明多態。 面向對象編程(OOP)的三大核心特性是封裝、繼承和多態。封裝是將數據和操作數據的方法綁定在一起,并隱藏對象的內部實現細節;繼承允許一個類繼承另一個類的屬性和方法&#x…