本地k8s运行总结

本文涉及的产品
容器服务 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/

image

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. 

image

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 各种系统主要图

image

9 k3s

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

单节点k3s server的架构

image

K3s高可用架构

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

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

image

10 k0s

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

image

image

11 MiniKube

image

12 Kind

image

13 K8s

image

14 Docker Desktop k8s

image

15 OpenShit CRC

image

image


相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
10天前
|
Kubernetes Java 容器
如何获取k8s容器里运行的jar包
如何获取k8s容器里运行的jar包
24 0
|
15天前
|
Kubernetes 应用服务中间件 nginx
解释一下Kubernetes Minikube是什么,以及如何在本地运行一个Minikube集群
步骤1:准备环境 在开始之前,您需要确保本地环境已经具备以下几个关键的工具和组件:
|
15天前
|
Kubernetes 应用服务中间件 nginx
如何在本地使用Docker搭建和运行Kubernetes集群
获取Service的访问地址 运行以下命令来获取Service的访问地址:
|
22天前
|
JSON Kubernetes Docker
k8s 集群中运行 docker registry 镜像仓库
k8s 集群中运行 docker registry 镜像仓库
83 0
|
2月前
|
Kubernetes 流计算 容器
Flink on k8s的话,怎么在容器运行前初始化一些脚本?
Flink on k8s的话,怎么在容器运行前初始化一些脚本?
15 1
|
2月前
|
Kubernetes 监控 Docker
深入解析 Kubernetes 架构:掌握主节点、工作节点和容器运行时
深入解析 Kubernetes 架构:掌握主节点、工作节点和容器运行时
41 0
|
2月前
|
Kubernetes jenkins 持续交付
jenkins结合k8s构建流水线如何提升运行性能和构建效率
jenkins结合k8s构建流水线如何提升运行性能和构建效率
|
5月前
|
弹性计算 Kubernetes Cloud Native
一文搞懂Kubernetes容器运行原理
Hello folks,我是 Luga,今天我们来分享一下与云原生体系有关的话题- 云原生技术-Container。 作为一个“核心”要素之一,容器技术在云原生生态中发挥着重要的意义。
84 0
|
5月前
|
存储 运维 Kubernetes
K8s Clinic:如何安全高效地运行 K8s
随着容器的应用,软件打包越来越左移,这意味着(取决于我们的团队组织)开发人员正在承担应用程序容器化的责任。开发人员可能还负责 Kubernetes 配置的某些部分。随着该流程向左转移,开发人员需要支持才能为组织做出正确的决策,以便安全高效地运行 Kubernetes。
42 0
|
5月前
|
Kubernetes Cloud Native Devops
为什么在Kubernetes上运行虚拟机?
为什么在Kubernetes上运行虚拟机?
40 0
热门文章
最新文章
推荐文章
更多