使用 kind 快速搭建 kubernetes 環境

来源:https://www.cnblogs.com/weihanli/archive/2020/05/06/12831225.html

使用 kind 快速搭建 Kubernetes 環境 Intro kind(Kubernetes IN Docker) 是一個基於 docker 構建 Kubernetes 集群的工具,非常適合用來在本地搭建基於 Kubernetes 的開發/測試環境。 想寫一篇 kind 的文章很久了,但是之前的 ...


使用 kind 快速搭建 Kubernetes 環境

Intro

kind(Kubernetes IN Docker) 是一個基於 docker 構建 Kubernetes 集群的工具,非常適合用來在本地搭建基於 Kubernetes 的開發/測試環境。

想寫一篇 kind 的文章很久了,但是之前的 kind 都會有一個問題,每次系統重啟或 docker daemon 重啟的時候會導致原來的創建的集群不可用,需要重新創建才可以,從 0.8 版本開始,kind 不再需要重新創建集群了,基於這個集群的資源部署也會自動重啟,無需再手動重新部署了,具體可以參考 Issue https://github.com/kubernetes-sigs/kind/issues/148,就在前幾天 kind 0.8 版本發佈了於是打算寫一篇介紹 kind 的文章

Install

Kind 的安裝不包括 kubectl,你需要獨立安裝 kubectl 來通過命令行來操作 kubernetes 集群,kubectl 的安裝可以參考: https://kubernetes.io/docs/tasks/tools/install-kubectl/

通過 https://github.com/kubernetes-sigs/kind/releases/latest 獲取最新的 release,根據自己的系統類型選擇相應的系統 release,下載 release 之後重命名為 kind(Windows 系統 release 重命名為 kind.exe),然後將其放在某一個目錄下,並要確保這個目錄在系統 PATH 中以方便的使用,linux 系統中可能需要配置文件許可權

sudo chmod +x kind

操作 Kuberneters 集群

使用 kind 創建 Kubernetes 集群非常的方便,只需要一行命令即可

kind create cluster

刪除集群

kind delete cluster

預設集群名稱是 "kind",如果要創建多個或者指定集群名稱,可以指定 name 參數:

kind create cluster --name=k8s-cluster1

刪除集群

kind delete cluster --name=k8s-cluster1

創建集群成功之後,就可以使用 kubectl 來操作 k8s 集群了

獲取 k8s 集群所有資源示例:

既然說是基於 docker 的,那麼我們再來看下 docker 資源,來驗證一下是否真的是基於 docker 的

docker ps

可以看到 docker 里有一個 container,而 kind 創建的集群就是基於這個 container 的,如果你直接刪掉了這個 container,通過 kind 創建的 k8s 集群也會有問題,

再來看一下 network,運行 docker network ls

可以看到有一個名稱為 kind 的 network

我們可以進一步探究 kind-control-plane(就是上面的 docker container)

通過 docker exec kind-control-plane crictl ps 獲取這個容器內部的運行容器列表,這個容器內部通過 crictl 來操作容器,可以參考 https://github.com/kubernetes-sigs/cri-tools

More

除了搭建開發測試環境之外,kind 也支持創建高可用的 kuberneters 集群,具體可以參考官方文檔

kind 創建集群成功之後,就可以向 kubernetes 集群部署資源了,開始你的 Kubernetes 之旅吧~

Reference


您的分享是我們最大的動力!

更多相關文章
  • 當面試官問道你高度塌陷時,人們第一想到的方法一定是 .clearfix::after { content: ''; display: block; clear: both; visibility: hidden; height: 0; } 對,沒錯,這是一個完美的解決方案,但是我們有考慮過這個方案的 ...
  • 一、函數參數的解構賦值 二、函數預設參數 2.1 基本方式 2.2 可以預設實參 2.3 預設實參的覆蓋 但如果傳入實參,那麼就會把預設的覆蓋。 2.4 預設值可以是函數 三、箭頭函數 語法:參數= 函數體 單行語句可以省略花括弧,如果還是return語句,還可以省略return關鍵字。 多行語句不 ...
  • 登高遠眺 天高地迥,覺宇宙之無窮 基礎技術 "使用 JavaScript 框架的代價" 作者從 JavaScript 下載時間、解析時間、執行時間、記憶體占用四個角度評測了 jQuery、Angular、React、Vue 四個框架,最終得出結論:「框架不值得」,應該選擇原生 JavaScript 或 ...
  • 在實際工作或面試中,我們經常會遇到“數組去重”問題,接下來就是使用js實現的數組去重的多種方法: 1.將數組的每一個元素依次與其他元素做比較,發現重覆元素,刪除 var arr = [1,23,1,1,1,3,23,5,6,7,9,9,8,5,5,5,5]; console.log(arr); // ...
  • 一、什麼是json? json的全稱為:JavaScript Object Notation,是一種輕量級的數據交互格式。它基於 ECMAScript (歐洲電腦協會制定的js規範)的一個子集,採用完全獨立於編程語言的文本格式來存儲和表示數據。【以上來自於百度百科】 簡單來說:json就是一種在各 ...
  • hello,我是愛學編程的小圓子。好久沒更新了呢,emmmmmmm....... 今天我們來學function function_name(...) {} function是觸發事件的時候觸發{}裡面的代碼的代碼 廢話不多說,上模板 <!DOCTYPE html> <html> <head> <me ...
  • 結合個人經歷總結的前端入門方法,總結從零基礎到具備前端基本技能的道路、學習方法、資料。由於能力有限,不能保證面面俱到,只是作為入門參考,面向初學者,讓初學者少走彎路。 互聯網的快速發展和激烈競爭,用戶體驗成為一個重要的關註點,導致專業前端工程師成為熱門職業,各大公司對前端工程師的需求量都很大,要求也 ...
  • 上一篇文章,介紹了這個架構中,WebServer的選擇,以及整個架構中擴展時的思路。 原文地址:15分鐘從零開始搭建支持10w+用戶的生產環境(三) 五、架構實踐 前邊用了三篇文章,詳細介紹了這個架構的各個部分的選擇以及安裝。 這篇文章,我會用一個Demo項目,從開發到部署,包括MongoDB數據的 ...
一周排行
  • 文章篇幅較長,閱讀完大概20min,建議收藏閱讀, 讀完會有收穫。歡迎點贊關註 原文鏈接:https://www.softwaretestinghelp.com/types-of-software-testing/ 有多少軟體測試類型呢? 我們作為測試人員瞭解很多種不同的軟體測試類型,例如功能測試( ...
  • 過場CG: 接到公司領導的文件指示,“小熊”需要在6月底去海外執行一個行動代號為【定時任務】的營救計劃,這個計劃關係到公司某個項目的生死(數據安全漏洞),作戰部擬定兩個作戰方案: 方案一:使用務定時任務框架quartz; 方案二:使用windows Service服務。 最終的作戰方案為:兩者配套使 ...
  • 為什麼編寫TaskSchedulerEx類? 因為.NET預設線程池只有一個線程池,如果某個批量任務一直占著大量線程,甚至耗盡預設線程池,則會嚴重影響應用程式域中其它任務或批量任務的性能。 特點: 1、使用獨立線程池,線程池中線程分為核心線程和輔助線程,輔助線程會動態增加和釋放,且匯流排程數不大於參數 ...
  • 前幾天,公眾號後臺有朋友在問Core的中間件,所以專門抽時間整理了這樣一篇文章。 一、前言 中間件(Middleware)最初是一個機械上的概念,說的是兩個不同的運動結構中間的連接件。後來這個概念延伸到軟體行業,大家把應用操作系統和電腦硬體之間過渡的軟體或系統稱之為中間件,比方驅動程式,就是一個典型 ...
  • 參考文檔: https://www.cnblogs.com/liaods/p/10101513.html https://www.cnblogs.com/zyz-Notes/p/12030281.html 本示例使用MVC項目做演示(不推薦,推薦直接用WebAPI),框架版本使用 4.6.2 為了支 ...
  • 引用NModbus 在NuGet搜索NModbus,添加引用。 封裝ModbusTcp類 public class ModbusTCP { private ModbusFactory modbusFactory; private IModbusMaster master; private TcpCl ...
  • 系列文章 基於 abp vNext 和 .NET Core 開發博客項目 - 使用 abp cli 搭建項目 基於 abp vNext 和 .NET Core 開發博客項目 - 給項目瘦身,讓它跑起來 基於 abp vNext 和 .NET Core 開發博客項目 - 完善與美化,Swagger登場 ...
  • Microsoft.AspNetCore.Mvc.Versioning //引入程式集 .net core 下麵api的版本控製作用不需要多說,可以查閱https://www.cnblogs.com/dc20181010/p/11313738.html 普通的版本控制一般是通過鏈接、header此類 ...
  • 結合 AOP 輕鬆處理事件發佈處理日誌 Intro 前段時間,實現了 EventBus 以及 EventQueue 基於 Event 的事件處理,但是沒有做日誌(EventLog)相關的部分,原本想增加兩個介面, 處理事件發佈日誌和事件處理日誌,最近用了 AOP 的思想處理了 EntityFrame ...
  • 什麼是sam 轉換 Single Abstract Method 實際上這是java8中提出的概念,你就把他理解為是一個方法的介面的就可以了 看一下我們每天都在使用的線程池 ExecutorService executorService= Executors.newScheduledThreadPo ...