首页 > 其他分享 >人人都会Kubernetes(一):告别手写K8s yaml,运维效率提升500%

人人都会Kubernetes(一):告别手写K8s yaml,运维效率提升500%

时间:2024-01-15 12:12:07浏览次数:25  
标签:运维 Kubernetes 可以 YAML 集群 500% KRM 节点

1. Kubernetes的普及和重要性

随着云计算的迅速发展,容器化技术已成为构建和运行分布式应用程序的关键。而Kubernetes作为容器编排领域的佼佼者,已经成为了云原生应用的标准。它不仅简化了应用程序的部署和管理,而且为开发者和运维人员提供了一套全面的工具集,从容器编排、自动扩缩容、服务发现到自修复等,满足了各种复杂的生产需求。无论你是开发人员、运维人员还是企业决策者,理解Kubernetes的重要性并掌握其技术,都将为项目和业务带来巨大的竞争优势。

2. Kubernetes的挑战

Kubernetes创建、更新、删除资源等操作,均是使用json或yaml文件进行管理,更新和删除可以依赖之前的文件进行更改,但是创建具有多变性,往往编辑起来比较复杂,容易出错。而且K8s的配置项实在太多,稍微不注意就会犯错。要写好一个yaml文件,你需要了解yaml的语法,需要掌握K8s的各种配置,对于一个k8s的初学者而言,这将是一件很难的事情。所以Kubernetes YAML文件的编写与维护是一项繁琐且容易出错的工作。

每个应用程序、服务或配置都需要精确的YAML语法,一旦出错,可能会导致资源无法正常创建或运行。此外,随着应用程序的复杂性和规模的增长,所需的YAML文件数量和复杂度也会急剧的增加。如果单靠人力去对文件做增删改查,这不仅增加了出错的可能性,而且管理和维护变得异常的困难。因此,使用一些自动化工具来生成和管理Kubernetes YAML文件成为了迫切的需求,它不仅可以大大提高工作效率,而且可以减少出错的可能性,让管理Kubernetes工作变得更加轻松和高效。

3. Kubernetes YAML文件图形化生成

当我们面临Kubernetes YAML文件编写的困难时,一个自动化的Kubernetes YAML生成工具的出现,就如同云原生时代的一场及时雨。它不仅解放了我们的双手,更提高了工作效率,减少了出错的可能性。

这个工具,就像一位贴心的助手,能够快速、准确地生成我们所需的YAML文件。不论是简单的部署还是复杂的微服务架构,它都能游刃有余地处理。

所以,为什么需要一个自动化的Kubernetes YAML生成工具?答案很简单,为了更高效的工作,更少的错误,以及更多的时间去做真正重要的事情。让我们告别手写Kubernetes YAML的时代,迈向运维效率提升500%的新篇章!

4.Kubernetes YAML在线生成工具KRM

今天给大家介绍一款可以无需安装就可以生成K8s yaml文件的工具————KRM

KRM是一个Kubernetes多集群资源管理平台,基于管理Kubernetes的资源开发,可以管理Kubernetes的Namespace、Deployment、DaemonSet、StatefulSet、Service、Ingress、Pods、Nodes、CronJob等,当然也可以无需安装生成自己想要的yaml文件。

KRM主要实现的是使用图形化界面管理所有的Kubernetes的资源,降低Kubernetes的复杂度。 同时具备了一些常用的功能,比如跨集群资源复制、一键项目迁移、图形化资源编辑、资源一键回滚及更新、多集群资源统计等。

KRM在线演示地址:http://demo.kubeasy.com/#/
登录后即可查看到KRM的首页————集群资源统计,可以所有集群的资源统计,比如节点总数量、Pod总数量等
image.png

5. KRM功能介绍

5.1 集群管理

image.png
在集群管理页面可以看到被KRM管理的集群列表、集群版本、集群状态及集群配置等,当点击集群ID时,可以查看当前集群资源统计信息,比如当前集群节点总数量、Pod总数量、Namespace总数量等
image.png

5.2 节点管理

image.png
节点管理页面可以看到每个集群的节点列表,并且可以展示每个节点的信息,比如主机名、IP地址、角色、节点状态等,同时可以对节点进行一键式操作,比如开启禁止调度和驱逐节点上的Pod等,另外点击操作的编辑可以对节点的标签和污点进行管理,点击操作的Pod按钮,可以查看当前节点运行了哪些Pod
image.png
当点击节点的主机名时,可以看到节点的详细信息
image.png

5.3 命名空间管理

image.png
命名空间管理可以查看每个集群的Namespace的列表,同时可以对命名空间进行简单的管理,比如删除、编辑和资源复制等
点击资源复制可以把某个集群的Namespace里面的资源复制到另外一个集群
image.png
image.png

点击Namespace的名称可以获取当前namespace的资源统计信息,比如Pod数量、Deployment数量等
image.png

5.4 调度资源管理

在调度资源管理页面可以管理Kubernetes常见的调度资源,比如Pod、Deployment、StatefulSet、DaemonSet、CronJob等
image.png
image.png
image.png

5.5 服务发布资源管理

服务发布管理页面可以管理集群中的Service和Ingress资源
image.png
image.png
image.png

5.6 配置管理和存储管理

配置管理和存储管理页面可以管理ConfigMap、Secret、PV、PVC等
image.png
image.png
更多功能可以打开体验网站进行体验:http://demo.kubeasy.com/#/

6.使用KRM图形化生成YAML文件

KRM不仅可以直接生成YAML文件,还可以自行安装进行集群的管理,安装文档:https://github.com/dotbalo/krm/blob/main/deploy.md

如果不安装也可以使用
http://demo.kubeasy.com/
在线生成YAML文件

如果想要生产Deployment的YAML文件,可以点击调度资源-Deployment-创建
image.png
快速生成只需要输入Deployment名称及容器的镜像地址点击YAML即可生成YAML文件
image.png
image.png
image.png
之后生成的YAML文件即可去使用。
如果想要更加详细的配置,可以自行添加配置

6.1 存储配置

image.png
image.png
在存储配置中,可以添加一些常用的存储资源,比如EmptyDir、NFS、ConfigMap、Secret、PVC等

6.2 容器配置

image.png
容器配置中可以添加或者删除Pod中的容器,同时可以对容器的端口、健康检查、环境变量、生命周期及存储挂载配置等
image.png
image.png
image.png
image.png
image.png

7. 总结

KRM不仅可以在线生成YAML,还可以安装到自己的集群里面去管理自己的K8s集群,免去手动处理YAML的难度,不仅可以提升管理效率,还可以降低出错率,大家可以自行尝试~

更多功能正在不断完善中,大家可以关注:https://github.com/dotbalo/krm/
如果大家想要深度学习云原生、K8s、容器、DevOps、服务网格、Go、Vue知识可以关注:https://edu.51cto.com/lecturer/11062970.html

标签:运维,Kubernetes,可以,YAML,集群,500%,KRM,节点
From: https://www.cnblogs.com/dukuan/p/17965101

相关文章

  • 快准稳:值得所有运维学习的SRE故障处理经验
    在网络上关于SRE的讨论中,故障相关的内容比比皆是,但关于故障发生时的应急处理过程的详细讨论却寥寥无几。然而面对故障,故障指挥官一定面临着较大的压力,需要快速、正确地处置故障,应对内外部的挑战。在这篇文章中,我们将重点探讨故障指挥官在故障处理过程中的具体行动思路。值得注意......
  • Kubernetes 集群中部署项目
    在Kubernetes集群中部署项目并交付容器,通常涉及以下几个步骤:Docker镜像构建:使用Dockerfile定义应用程序的环境和依赖,然后使用DockerEngine构建出Docker镜像。可以使用一些构建工具如DockerCompose或DockerBuildx来简化构建过程。Docker镜像推送:将构建好的Docker......
  • Kubernetes 持久化存储
    Kubernetes持久化存储(nfs网络存储)Kubernetes提供了一种持久化存储的机制,允许将数据存储在容器之外,以便在容器重启、迁移或重新调度之后仍然可以访问。NFS(NetworkFileSystem)是一种网络存储协议,它允许多台计算机共享存储资源。在Kubernetes中,可以使用NFS作为持久化存储的一种选择......
  • Kubernetes 集群搭建-搭建高可用集群
    Kubernetes 集群搭建-搭建高可用集群(初始化和部署keepalived)要搭建一个高可用的Kubernetes集群,你可以使用Keepalived来实现负载均衡和故障转移。Keepalived是一个开源的高可用解决方案,它可以确保在节点故障时自动切换到备用节点,从而保证服务的连续性。以下是在搭建高可用Kuberne......
  • 人人都会Kubernetes(一):告别手写K8s yaml,运维效率提升500%
    1.Kubernetes的普及和重要性随着云计算的迅速发展,容器化技术已成为构建和运行分布式应用程序的关键。而Kubernetes作为容器编排领域的佼佼者,已经成为了云原生应用的标准。它不仅简化了应用程序的部署和管理,而且为开发者和运维人员提供了一套全面的工具集,从容器编排、自动扩缩容、......
  • 服务器出现500、502、503错误的原因以及解决方法
    服务器我们经常会遇到访问不了的情况有的时候是因为我们服务器被入侵了所以访问不了,有的时候是因为出现了服务器配置问题,或者软硬件出现问题导致的无法访问的问题,这时候会出现500、502、503等错误代码。基于以上问题我们第一步可以先重启服务器,一般重启服务器可以解决大多数问题,如......
  • 【云原生 • Kubernetes】k8s功能特性、k8s集群架构介绍
     序言你只管努力,其他交给时间,时间会证明一切。文章标记颜色说明:黄色:重要标题红色:用来标记结论绿色:用来标记一级论点蓝色:用来标记二级论点Kubernetes(k8s)是一个容器编排平台,允许在容器中运行应用程序和服务。今天学习一下k8s日志查看相关方法希望这篇文章......
  • Kubernetes Headless服务
    1、概述HeadlessServices是一种特殊的service,其spec:clusterIP表示为None,这样在实际运行时就不会被分配ClusterIP,也被称为无头服务,通过DNS解析提供服务发现。与普通服务不同的是HeadlessServices不提供负载均衡功能,每个Pod都有唯一的DNS记录,直接映射到其IP地址,适用于有状态应用......
  • openGauss学习笔记-196 openGauss 数据库运维-常见故障定位案例-强制结束指定的问题会
    openGauss学习笔记-196openGauss数据库运维-常见故障定位案例-强制结束指定的问题会话196.1强制结束指定的问题会话196.1.1问题现象有些情况下,为了使系统继续提供服务,管理员需要强制结束有问题的会话。196.1.2处理办法以操作系统用户omm登录主机。使用如下命令连接......
  • Kubernetes Controller(Deployment)-发布应用
    Kubernetes控制器(Deployment)是一个用于发布和管理应用程序的核心组件。它提供了一种声明式的方式来定义应用程序的期望状态,并确保系统自动地将当前状态与期望状态保持一致。通过使用Deployment,您可以定义应用程序的副本数、应用程序部署的容器镜像、应用程序的依赖关系等等。一旦......