背景:
从18年迷迷糊糊开始接触kubernetes(k8s),到现在入门了一段时间。总结一下,用自己的理解将k8s尽量生动的展现出来。大神就忽略吧。文中会结合到一些生活的场景中,可能表达会有所欠缺,可以帮助你快速的入门,但是要深入的学习,还是推荐去看专业点的文档。
必备功课
看到这篇文档,默认说明你已经熟练掌握以下知识
docker
docker registry (docker镜像仓库)
docker compose (单机docker的管理)
(可选)docker swarm(docker 集群的)
(可选)ansible
docker 与 Kubernetes 的关系
疑问
很多小伙伴估计和我一开始同时接触 docker 和 kubernetes 一样,有很多的疑问,比如:
1.docker是什么;
2.我要搭建的是kubernetes,为什么要先去了解dockr呢;
3.kubernetes里提到的pod,Deployment,services,pv,pvc等等名词是什么,他们之间有何关系;
当然还有很多的疑问,那就带着这些问题咱们慢慢了解。
释疑
docker 就是你,kubernetes 就是你的公司。你是干活的,公司是管你的,他俩就是这样的关系。你一个人做同一个项目的好多活,一会儿要在公司,一会儿要去机房,一会儿还要去出差,公司就是管着你做这些事情的。
用官方点的说辞就是:
Docker是一个开源的应用容器引擎,开发人员可以非常容易地打包已经开发好的应用,同时将应用相关的依赖包也打包到这样一个可移植的容器中,然后发布到任意的Linux主机系统上。简单说就是,你是一块砖,哪里需要哪里搬。
Kubernetes一个用于容器集群的自动化部署、扩容以及运维的开源平台。通过Kubernetes,你可以快速有效地响应用户需求;快速而有预期地部署你的应用;极速地扩展你的应用;无缝对接新应用功能;节省资源,优化硬件资源的使用。为容器编排管理提供了完整的开源方案。简单说就是,公司可以随意的调用人员去做事情。
让我们一起干活吧
1、大概找kubernetes的相关文章看看,了解一下都有哪些知识和内容,有一个模糊的认识
2、kubernetes的搭建。很多人可能认为搭建比较难,kubernetes官方提供了几种搭建方式,我最常用的还是采用二进制的方式进行搭建,这里推荐两个二进制部署的方案:
- 采用ansible部署:https://github.com/lizhenliang/ansible-install-k8s ,在纯净的centos7上可以直接安装使用,里面包含了安装kubernetes所需的所有软件,会顺便安装三个常用的组件,分别是dashboard,ingress-nginx,coredns
- 纯手动部署:https://github.com/opsnull/follow-me-install-kubernetes-cluster,提供了详细安装步骤,要有耐心,仔细的去部署,更加直观的感受kubernetes的安装。你要是熟练shell了,可以把他的脚本自己再处理一下,更加方便你自己使用。(顺利的话部署也快)
部署就不展开讲了,网上好多现成的方案,咱们先别纠结太多,让集群先跑起来,然后咱们再一步一步去了解它。