本地k8s运行总结

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 本机上运行k8s的各种不同软件的对比和结构图

本地k8s运行总结

本机上运行k8s的各种不同软件的对比和结构图

2 运行软件

3 minikube kind k3s

https://www.jambit.com/en/latest-info/toilet-papers/minikube-vs-kind-vs-k3s-which-local-kubernetes-cluster-should-i-use/

4 MicroK8S

https://microk8s.io/compare

 

MICROK8S

K3S

MINIKUBE

CNCF certified

Yes

Yes

Yes

Vanilla Kubernetes

Yes

Yes

Architecture support

x86, ARM64, s390x

x86, ARM64, ARMhf

x86, ARM64, ARMv7, ppc64, s390x

Enterprise support

Yes

Yes

Single-node support

Yes

Yes

Yes

Multi-node cluster support

Yes

Yes

Automatic high availability

Yes

Automatic updates

Yes

Memory requirements

540 MB

512 MB

2 GB

Add-on functionality

Yes

Yes

Container runtime

containerd, kata

CRI-O

Docker, containerd, CRI-O

Networking

Calico, Cilium, CoreDNS, Traefik, NGINX, Ambassador, Multus, MetalLB

Flannel, CoreDNS, Traefik, Canal, Klipper

Calico, Cilium, Flannel, ingress, DNS, Kindnet

Storage

Hostpath storage, OpenEBS, Ceph

Hostpath storage, Longhorn

Hostpath storage

GPU acceleration

Yes

Yes


5 K0S

https://computingforgeeks.com/k0s-vs-k3s-vs-microk8s-kubernetes-distributions-comparison/

Feature

k0s

k3s

microk8s

Licensing

Completely Open Source

Completely Open Source

Completely Open Source

Packaging

k0s is distributed as a single binary with minimal host OS dependencies besides the host OS kernel

Packaged as a single binary.

MicroK8s is a Kubernetes cluster delivered as a single snap package.

Kubernetes Versions

v1.20 and v1.21

Latest release updates Kubernetes to v1.22.1

Kubernetes v1.22, v1.21

Container Runtime

ContainerD (default)

ContainerD (default)

ContainerD is the container runtime used by MicroK8s

Supported Host OS

Linux (kernel v3.10 or newer)          Windows Server 2019 (experimental)

K3s is expected to work on most modern Linux systems

Windows 10, Linux, macOS

Control Plane Storage Options

In-Cluster Elastic Etcd with TLS (default), In-Cluster SQLite (default for single node), External PostgreSQL, External MySQL

sqlite3 is the default storage mechanism. etcd3, MySQL, Postgres also still available

MicroK8s supports high availability using Dqlite as the datastore for cluster state.

Built-In Security Features

RBAC, Support OpenID Providers, Pod Security Policies, Network Policies, Micro VM Runtimes (coming soon), Control Plane Isolation

Secure by default with reasonable defaults for lightweight environments

Secure by default with reasonable defaults for lightweight environments

Supported CNI Providers

Kube-Router (default), Calico or Custom

K3s will run with flannel by default as the CNI, using VXLAN as the default backend. Custom supported as well

Flanneld runs if ha-cluster is not enabled. If ha-cluster is enabled, calico is run instead.

Supported Machine Architectures

x86-64, ARM64, ARMv7

Latest release supports x86_64, ARMv7, and ARM64

x86_64, ARMv7, and ARM64

Backing Company

Mirantis

Rancher

Canonical

Addons

Minimum Addons

Traefik, Helm,LB

Dashboard, Ingress, DNS, and more


6 Docker Desktop

https://docs.docker.com/desktop/kubernetes/

If you have Docker Desktop, go to preferences, go to the Kubernetes tab, and click Enable Kubernetes.

7 OpenShift

CodeReady Containers (CRC) manages a local OpenShift 4.x cluster optimized for testing and development purposes. https://github.com/code-ready/crc

Minishift helps you run OpenShift 3.x clusters locally by running a single-node OpenShift cluster inside a virtual machine (VM). https://github.com/minishift/minishift

8 各种系统主要图

9 k3s

https://docs.rancher.cn/docs/k3s/architecture/_index

单节点k3s server的架构

K3s高可用架构

一个高可用 K3s 集群由以下几个部分组成:

  • K3s Server 节点:两个或更多的server节点将为 Kubernetes API 提供服务并运行其他 control-plane 服务
  • 外部数据库:与单节点 k3s 设置中使用的嵌入式 SQLite 数据存储相反,高可用 K3s 需要挂载一个external database外部数据库作为数据存储的媒介。

10 k0s

https://docs.k0sproject.io/v1.23.5+k0s.0/architecture/

11 MiniKube

12 Kind

13 K8s

14 Docker Desktop k8s

15 OpenShit CRC


相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
26天前
|
JSON Kubernetes Shell
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
|
4月前
|
Kubernetes 搜索推荐 Docker
K8S容器运行时弃用Docker转型Containerd
K8S容器运行时弃用Docker转型Containerd
690 0
|
11月前
|
Kubernetes 流计算 容器
Flink on k8s的话,怎么在容器运行前初始化一些脚本?
Flink on k8s的话,怎么在容器运行前初始化一些脚本?
71 1
|
10月前
|
Kubernetes Java 容器
如何获取k8s容器里运行的jar包
如何获取k8s容器里运行的jar包
257 0
|
10月前
|
JSON Kubernetes Docker
k8s 集群中运行 docker registry 镜像仓库
k8s 集群中运行 docker registry 镜像仓库
1109 0
|
1月前
|
Kubernetes API Perl
在K8S中,如何让Pod运行一次?如何解决一次性任务?
在K8S中,如何让Pod运行一次?如何解决一次性任务?
|
1月前
|
Kubernetes 安全 Serverless
Kubernetes云原生问题之在Serverless Container中,Pod运行如何解决
Kubernetes云原生问题之在Serverless Container中,Pod运行如何解决
61 5
|
1月前
|
Rust Kubernetes 前端开发
在kubernetes上运行WASM负载
在kubernetes上运行WASM负载
31 4
|
1月前
|
Kubernetes 容器 Perl
Kubernetes(K8S) Node NotReady 节点资源不足 Pod无法运行
Kubernetes(K8S) Node NotReady 节点资源不足 Pod无法运行
28 0
|
3月前
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用问题之运行run-application --target kubernetes-application执行,通过进程的返回码来决定作业是否成功,任务返回码都是0,该怎么办
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。