Kubernetes 相关基础知识点

两个应用在物理意义上的隔离需要满足

  1. PID 进程号
  2. NET 网络设备、网络协议栈、端口等
  3. IPC 信号量、消息队列,共享内存
  4. MOUNT 文件系统,挂载点
  5. UTS 主机名和主机域
  6. USER 操作进程的用户和用户组

Docker 封装应用程序的的优点

  1. Docker 引擎统一了基础设施环境,应用程序跑在docker容器内,不用再关系基础的硬件配置,操作系统版本等。
  2. Docker 引擎统一了程序的打包方式。所有程序,不管是java程序还是python程序,都可以做成docker镜像。
  3. Docker 引擎统一了程序的运行方式。如java程序需要执行 java -jar …,python程序需要执行 python sss.py runserver,而将程序放在docker镜像中,执行docker run 指令,就可以执行任何程序。

Docker 的缺点

  1. 单机使用,无法有效集群
  2. 没有有效的容灾、自愈机制
  3. 没有预设编排模板,无法实现快速、大规模容器调度
  4. 没有统一的配置管理中心
  5. 没有容器生命周期管理的工具
  6. 没有图形化运维工具

容器编排工具

  1. docker compose:docker公司发布的基于docker的单机容器编排引擎。
  2. docker swarm:容器编排引擎
  3. Kubernetes:Google开源的容器编排工具,目前最流行的容器编排工具。

Kubernetes 的优点

Docker 的缺点,Kubernetes都解决了。

  1. 自动装箱,水平扩展,自我修复
  2. 服务发现和负载均衡
  3. 自动发布(默认滚动发布模式)和回滚
  4. 集中化配置管理和密钥管理
  5. 存储编排
  6. 任务批处理等

Kubernetes 相关概念

  1. Pod
    • Pod是K8S里能够被运行的最小的逻辑单元
    • 一个Pod里面可用运行多个容器,它们共享UTS + NET + IPC名称空间
  2. Pod控制器
    • Pod控制器时Pod启动的一种模板,用来保证在K8S里启动的Pod应始终按照人们的预期运行(副本数、生命周期、监控状态…)
    • K8S内提供了众多的Pod控制器,常用的有以下几种:Deployment、DaemonSet、ReplicaSet、StatefulSet、Job、Cronjob
  3. Name
    • 给K8S内部的资源一个名字,就用Name
    • K8S在资源有 apiVersion,Kind、metadata、spec、status等配置信息,而Name一般定义在资源的metadata中
  4. Namespace
    • 随着项目增多、人员增加、集群规模的扩大,需要一种能够隔离K8S内各种“资源”的方法,这个就是Namespace
    • 不同名称空间内的资源名称可用相同;相同名称空间下,资源不同同名。
    • K8S中默认的名称空间有:default、kube-system、kube-public
  5. Label
    • 标签是K8S特色的管理资源的方式,便于分类管理资源对象。
    • 一个标签可以对应多个资源,一个资源也可以有多个标签,它们是多对多关系。
    • 一个资源拥有多个标签,可以实现不同维度的管理。
  6. Label 标签选择器
    • 给资源打上标签后,可以使用标签选择器过滤指定的标签
    • 标签选择器目前有两个:基于等值关系(等于、不等于)和基于集合关系(属于、不属于、存在)
  7. Service
    • 在K8S中,虽然每隔Pod都会被分配一个单独的IP地址,但这个IP地址会随着Pod的销毁个消失。
    • 一个Service可以看作是一组提供相同服务的Pod的对外访问接口
    • Service作用于哪些Pod通过标签选择器来定义。
  8. Ingress

Kubernetes 核心组件

  1. 存储配置中心etcd服务,存储集群数据
  2. 主控节点 master
    • kube-apiserver:提供了集群管理的REST API接口(包括鉴权、数据校验以及集群状态变更);负责其它模块之间的数据交互,承担通信枢纽功能;资源配额控制的入口;提供完备的集群安全机制。
    • kube-controller-manager:由一系列控制器(Node Controller、Deployment Controller、Service Controller、Volume Controller、Endpoint Controller、Garbage Controller、Namespace Controller、Job Controller、Resource quta Controller…)组成,通过apiserver监控整个集群的状态,并确保集群处于预期的工作状态。
    • kube-scheduler:主要功能是通过预算策略或优选策略调度pod到合适的运算节点上。
  3. 运算节点 node
    • kube-kubelet:a. 简单地说,kubelet的主要功能就是定时从某个地方获取节点上pod的期望状态(运行什么容器、运行的副本数量、网络或者存储如何配置),并调用对应的容器平台接口达到这个状态;b. 定时汇报当前节点的状态给apiserver,以供调度的时候使用;c. 镜像和容器的清理工作,保证节点上镜像不会占满磁盘空间,退出的容器不会占用太多的资源。
    • kube-proxy:a. 是K8S在每隔节点上运行网络代理、service资源的载体;b. 建立了pod网络和集群网络的关系;c. 负责建立、删除、更新调度规则、通知apiserver更新。

K8S 安装部署方式

  1. Minikube 单节点微型K8S(仅供学习、预览使用),直接在网页上可以使用 https://kubernetes.io/docs/tutorials/hello-minikube/
  2. 二进制部署方式
  3. 使用kubeadmin进行部署,K8S的部署工具,跑在K8S里
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: k8s(Kubernetes)是一个开源的容器编排平台,用于自动化容器部署、扩展和管理。下面是一些与k8s相关的重要知识点运维笔记。 1. 容器化技术:k8s基于容器化技术,可以将应用程序及其依赖项封装到容器中,实现隔离和轻量级部署。熟悉Docker等容器化工具是使用k8s的先决条件。 2. 集群架构:k8s由Master和Worker节点组成,Master节点负责管理和控制集群,而Worker节点负责承载应用程序容器。了解集群架构和组件的功能是进行k8s运维的重要基础。 3. 资源管理:k8s通过Pod、Deployment、ReplicaSet等资源对象实现应用程序的管理。Pod是最小的可部署单元,可以包含一个或多个容器。Deployment用于定义和控制Pod的副本数和版本更新等。 4. 服务发现和负载均衡:k8s提供了Service对象用于服务发现和负载均衡。Service定义了一组Pod的访问入口,并通过ClusterIP、NodePort或LoadBalancer等方式实现内部和外部的访问。 5. 存储管理:k8s支持各种存储卷插件,包括本地存储、NFS、AWS EBS等。使用存储卷可以将应用程序中的数据持久化,并实现数据的共享和迁移。 6. 配置管理:k8s提供了ConfigMap和Secret等对象用于管理应用程序的配置和敏感信息。ConfigMap用于存储配置数据,而Secret用于存储敏感信息如密码和API密钥。 7. 监控和日志:k8s集成了多种监控和日志工具,如Prometheus、Grafana和EFK(Elasticsearch、Fluentd、Kibana)等。通过这些工具可以实时监控和分析应用程序的性能和日志信息。 8. 自动扩展:k8s可以根据应用程序的负载情况自动进行扩展。通过Horizontal Pod Autoscaler(HPA)等机制,可以根据CPU利用率或其他指标自动调整Pod的副本数。 9. 更新和回滚:k8s支持应用程序的版本更新和回滚。通过Deployment的滚动升级策略,可以实现应用程序的无缝更新,并在出现问题时快速回滚到之前的版本。 10. 故障排除和调试:k8s提供了一些工具和命令行工具,如kubectl、kubectl logs等,用于进行故障排查和调试。掌握这些工具的使用方法对于运维k8s集群是必要的。 以上是一些与k8s相关的重要知识点和运维笔记,对于熟练掌握k8s的运维人员来说,这些知识点是必备的。当然,k8s是一个非常广泛且庞大的平台,还有很多其他方面的知识和技能需要进一步学习和掌握。 ### 回答2: Kubernetes(简称K8s)是一种用于自动化容器化应用程序部署、扩展和管理的开源容器编排工具。以下是关于Kubernetes相关重要知识点的运维笔记: 1. 集群架构:Kubernetes由Master和Node组成。Master负责集群管理,包括调度、监控、管理配置等,而Node是运行容器的主机。 2. Pod:Pod是Kubernetes最小的可调度和管理的单元,它可以包含一个或多个容器。Pod共享网络和存储资源,可以通过共享文件和通信进行协作。 3. 命名空间(Namespace):命名空间用于将集群内的资源进行隔离,可以避免不同应用程序之间的冲突。 4. 控制器(Controller):控制器用于实现自动化操作和管理,如应用部署、副本数监控、故障恢复等。常见的控制器包括ReplicaSet、Deployment、StatefulSet等。 5. 服务(Service):Service是一种抽象,用于定义一组Pod的访问方式。它为一组Pod分配固定的虚拟IP,并提供负载均衡和服务发现功能。 6. 存储卷(Volume):存储卷用于持久化数据,确保数据在容器重启或迁移时不丢失。Kubernetes支持多种存储类型,如本地存储、网络存储、云存储等。 7. 扩展机制:Kubernetes提供了多种扩展机制,如水平Pod自动伸缩(HPA)、自定义资源定义(CRD)、自定义控制器等,可以根据需求灵活扩展和定制。 8. 监控和日志:Kubernetes提供了丰富的监控和日志功能,可以通过Prometheus、Elasticsearch等工具对集群中的资源和应用进行监视和记录。 9. 网络和服务发现:Kubernetes为容器提供了多种网络模型,并集成了服务发现机制。可以通过Ingress、LoadBalancer等方式将容器暴露到集群外部。 10. 安全和认证授权:Kubernetes提供了多种安全机制,如RBAC、TLS等,用于认证和授权用户的访问权限,确保集群的安全性。 这些是Kubernetes运维中的重要知识点,掌握了这些知识对于有效管理和运维Kubernetes集群至关重要。 ### 回答3: 1. k8s是一种开源的容器编排和管理平台,用于自动化应用程序的部署、扩展和管理。 2. k8s中的基本组件包括Master节点和Worker节点。Master节点负责管理整个集群的状态和配置信息,Worker节点负责运行容器。 3. k8s中的最小调度单位为Pod,一个Pod是一个或多个相关容器的组合,它们共享存储、网络和名称空间。 4. Replication Controller是k8s中用于复制和扩展Pod的机制,它可以确保指定数量的Pod在任何时间都运行在集群中。 5. Service是k8s中用于将Pod组织成服务的机制,提供一个稳定的IP地址和DNS名称,使得其他Pod或外部用户可以访问服务。 6. Volume是k8s中用于持久化数据的机制,允许容器访问与它们的生命周期无关的存储。 7. k8s支持多种网络插件,如Flannel、Calico和Weave等,用于在集群中实现容器之间的网络通信。 8. k8s可以通过Horizontal Pod Autoscaler实现根据负载自动进行Pod的扩缩容。它根据定义的指标监控集群的负载,并在负载过高或过低时自动调整Pod数量。 9. k8s支持滚动更新,可以在不中断服务的情况下逐步更新应用程序的版本。 10. k8s提供了丰富的监控和日志收集机制,如Heapster和ELK Stack等,帮助用户监控和分析集群的状态和性能。 11. k8s还支持命名空间的概念,可以将集群划分为多个逻辑上独立的区域,以实现更好的资源隔离和管理。 12. k8s支持灵活的部署方式,可以在公有云、私有云或裸机上部署,同时支持自建集群和托管集群。 13. k8s有丰富的命令行工具和API,方便用户进行集群的管理和操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值