极简的配置单节点Kubernetes(k8s)集群

简介: 在传统的概念当中,Docker是简单易用的,Kubernetes是复杂强大的。 深入了解之后会发现Docker的简单是因为用户可以从基本功能开始用起, 只需要一台Linux主机,运行一下apt-get install docker-engine 或者yum install docker-engine,立马就可以用docker run启动一个新的容器, 整个过程与用户之前积累的Linux软件使用体验高度一致。

在传统的概念当中,Docker是简单易用的,Kubernetes是复杂强大的。 深入了解 之后会发现Docker的简单是因为用户可以从基本功能开始用起, 只需要一台Linux主机,运行一下apt-get install docker-engine 或者yum install docker-engine,立马就可以用docker run启动一个新的容器, 整个过程与用户之前积累的Linux软件使用体验高度一致。 而Kubernetes则要求用户要分别配置SDN,ssl证书,etcd,kubelet,apiserver, controller-manager,scheduler,proxy,kubectl等多个组件, 刚刚接触对架构还不了解的新人一下就懵了。 过高的早期门槛把许多对Kubernetes感兴趣的用户挡在了外面,给人留下一种难以上手的感觉。

事实上,当整个系统扩展到多个节点,需要通盘考虑身份认证,高可用, 服务发现等高级功能后,Docker Swarm与Kubernetes的复杂度是接近的。 也许我们最初的比较出现了一点偏差, 将位于更高阶的集群管理和调度系统Kubernetes和位于底层的容器引擎Docker Engine直接比较并不恰当。

现在我们了解到Kubernetes的复杂是因为它提供了更多的功能, 但是如果我们无法解决Kubernetes的上手困难问题,始终会有推广上的障碍。 对此,Kubernetes社区做出了许多努力。比如:

  • minikube可以方便的在本机用虚拟机创建一个开箱即用的Kubernetes集群
  • kubeadm可以自动化的将多台Ubuntu或者CentOS主机组建成集群
  • nanokubekid等自动初始化脚本

充分利用已有的工具, 我们可以在单台服务器上把Kubernetes的上手体验简化到与Docker接近的程度, 新用户可以不再纠结于安装和配置,尽快开始使用Kubernetes完成工作, 在业务需求增长时,再扩展集群成为多节点高可用的完整集群。

下图是一张学习曲线的示意图,可以看到当引入单节点Kubernetes作为过渡之后, 整个学习曲线更加平滑,在早期简单环境时更接近Docker, 在后期环境完整时又能够充分利用Kubernetes的优势。

20170204141929

有多种方法可以创建单节点的Kubernetes集群,接下来分享其中一个比较简单方便的。

准备工作

首先准备一台Linux服务器,根据Docker中文文档安装好Docker。

接着下载localkube和kubectl:

$ curl -o localkube https://storage.googleapis.com/minikube/k8sReleases/v1.5.1/localkube-linux-amd64
$ chmod +x localkube
$ curl -O https://storage.googleapis.com/kubernetes-release/release/v1.5.2/bin/linux/amd64/kubectl
$ chmod +x kubectl

localkube将Kubernetes所有的依赖程序全部打包成为了一个独立的可执行文件, 使用它可以省略掉几乎所有的配置流程,直接将Kubernetes跑起来。

目前localkube已经被合并进了minikube,最新的版本需要从minikube中下载。

kubectl是Kubernetes的客户端程序,可以用它控制集群。

启动Kubernetes

使用localkube启动集群非常简单:

$ ./localkube

当不加任何参数时,localkube会使用默认参数启动, 它所监听的localhost:8080将被用于接受控制指令。

这里并没有在后台运行localkube,如果你需要后台运行, 可以自行使用Linux上已有的各种工具完成。

使用kubectl控制集群

接下来的操作与多节点的集群完全一样。我们可以用kubectl来控制集群,比如:

$ ./kubectl run nginx --image nginx

是不是和docker run nginx几乎一样?在这里我们不详细介绍Kubernetes的操作, 请参考官方文档学习Kubernetes的使用方法。

需要指出的是,由于是极简的配置,并没有配置远程控制所需要的证书, 所以不能在本地电脑上控制这个集群,而需要ssh到服务器上进行控制。 这和默认的Docker配置是一致的。

总结

从上面的流程可以看到,Kubernetes也可以变得很简单,仅仅需要将所有组件合并到一起就可以了。 而这也恰恰是Docker选择的策略,在Docker的二进制文件中,被打包进了Docker Engine, 分布式存储,Docker Swarm等功能,使用起来只需要一个docker指令就可以完成全部的操作。 接下来需要思考的问题是,既然合并到一起会更加简单,那为什么Kubernetes会把各个组件拆开呢? 今后在详细介绍Kubernetes架构的时候会再给大家做详细的分析,这里就暂时留给大家下来自己思考了。

在刚接触Kubernetes的时候,使用all in one的localkube是有好处的。 可以把它整个看作Kubernetes,直接上手开始学习PodService,ReplicaSet这些抽象概念, 而不用特别去关注里面的组件划分。虽然暂时只能在一台服务器上运行, 不能完全的展现Kubernetes编排和调度的能力,但是用于学习和测试已经完全足够了。

待对Kubernetes建立了基本的概念之后,再进行多节点的集群部署, 在那时再来折腾SDN,ssl证书这些更偏重运维的组件时,才会有比较合理的投入产出预期。

还在等什么?快点把你的Docker主机升级为Kubernetes主机吧。就算没有联网形成集群, 使用更高的抽象来构建你的业务,也将为今后的发展打下良好的基础。

本文转自中文社区-极简的配置单节点Kubernetes(k8s)集群

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
4月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
ACK One 的多集群应用分发,可以最小成本地结合您已有的单集群 CD 系统,无需对原先应用资源 YAML 进行修改,即可快速构建成多集群的 CD 系统,并同时获得强大的多集群资源调度和分发的能力。
169 9
|
4月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
本文介绍如何利用阿里云的分布式云容器平台ACK One的多集群应用分发功能,结合云效CD能力,快速将单集群CD系统升级为多集群CD系统。通过增加分发策略(PropagationPolicy)和差异化策略(OverridePolicy),并修改单集群kubeconfig为舰队kubeconfig,可实现无损改造。该方案具备多地域多集群智能资源调度、重调度及故障迁移等能力,帮助用户提升业务效率与可靠性。
|
20天前
|
存储 Kubernetes 网络安全
关于阿里云 Kubernetes 容器服务(ACK)添加镜像仓库的快速说明
本文介绍了在中国大陆地区因网络限制无法正常拉取 Docker 镜像的解决方案。作者所在的阿里云 Kubernetes 集群使用的是较旧版本的 containerd(1.2x),且无法直接通过 SSH 修改节点配置,因此采用了一种无需更改 Kubernetes 配置文件的方法。通过为 `docker.io` 添加 containerd 的镜像源,并使用脚本自动修改 containerd 配置文件中的路径错误(将错误的 `cert.d` 改为 `certs.d`),最终实现了通过多个镜像站点拉取镜像。作者还提供了一个可重复运行的脚本,用于动态配置镜像源。虽然该方案能缓解镜像拉取问题,
168 2
|
2月前
|
人工智能 缓存 Kubernetes
ACK GIE配置建议
Gateway with Inference Extension是基于Kubernetes社区Gateway API及其扩展规范实现的增强型组件,支持四层/七层路由服务,并面向生成式AI推理场景提供负载均衡优化、服务管理简化等能力,适用于AI推理服务的高可用部署与性能优化。在不同的场景使用ACK Gateway with Inference Extension时,可能需要根据业务需求和高可用需要对网关和推理扩展进行不同的配置调整。本文主要介绍在实际业务场景中针对ACK GIE的配置建议,以获得更好的使用效果。
178 24
|
6月前
|
存储 Kubernetes 监控
K8s集群实战:使用kubeadm和kuboard部署Kubernetes集群
总之,使用kubeadm和kuboard部署K8s集群就像回归童年一样,简单又有趣。不要忘记,技术是为人服务的,用K8s集群操控云端资源,我们不过是想在复杂的世界找寻简单。尽管部署过程可能遇到困难,但朝着简化复杂的目标,我们就能找到意义和乐趣。希望你也能利用这些工具,找到你的乐趣,满足你的需求。
630 33
|
6月前
|
Prometheus Kubernetes 监控
Kubernetes监控:Prometheus与AlertManager结合,配置邮件告警。
完成这些步骤之后,您就拥有了一个可以用邮件通知你的Kubernetes监控解决方案了。当然,所有的这些配置都需要相互照应,还要对你的Kubernetes集群状况有深入的了解。希望这份指南能帮助你创建出适合自己场景的监控系统,让你在首次发现问题时就能做出响应。
320 22
|
6月前
|
Kubernetes 开发者 Docker
集群部署:使用Rancher部署Kubernetes集群。
以上就是使用 Rancher 部署 Kubernetes 集群的流程。使用 Rancher 和 Kubernetes,开发者可以受益于灵活性和可扩展性,允许他们在多种环境中运行多种应用,同时利用自动化工具使工作负载更加高效。
364 19
|
6月前
|
人工智能 分布式计算 调度
打破资源边界、告别资源浪费:ACK One 多集群Spark和AI作业调度
ACK One多集群Spark作业调度,可以帮助您在不影响集群中正在运行的在线业务的前提下,打破资源边界,根据各集群实际剩余资源来进行调度,最大化您多集群中闲置资源的利用率。
|
6月前
|
存储 人工智能 Kubernetes
ACK Gateway with AI Extension:面向Kubernetes大模型推理的智能路由实践
本文介绍了如何利用阿里云容器服务ACK推出的ACK Gateway with AI Extension组件,在Kubernetes环境中为大语言模型(LLM)推理服务提供智能路由和负载均衡能力。文章以部署和优化QwQ-32B模型为例,详细展示了从环境准备到性能测试的完整实践过程。
|
8月前
|
存储 运维 Kubernetes
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案
飞轮科技推出了 Doris 的 Kubernetes Operator 开源项目(简称:Doris Operator),并捐赠给 Apache 基金会。该工具集成了原生 Kubernetes 资源的复杂管理能力,并融合了 Doris 组件间的分布式协同、用户集群形态的按需定制等经验,为用户提供了一个更简洁、高效、易用的容器化部署方案。
359 16
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案

推荐镜像

更多