kubernetes组件介绍
MESOS APACHE 分布式资源管理框架 2019-5 Twitter 》 Kuberneets
Dcocker Swarm 2019-07 阿里云宣布 Docker Swarm 剔除
Kubernetes Google 10年容器化基础架构 borg GO 语言 Borg
特点:
轻量级:消耗资源小
开源
弹性伸缩
负载均衡:IPVS
 
适合人群: 软件工程师 测试工程师 运维工程师 软件架构师 项目经理
 
基础感念:
什么是Pod 控制器类型 K8s网络通讯模式
Kubernetes: 构建K8s集群
资源清单: 资源 掌握资源清单的语法 编写Pod 掌握 Pod的生命周期***
Pod 控制器: 掌握各种控制器的特点以及使用定义方式
服务发现:掌握SVC原理及其构建方式
存储: 掌握多种存储类型的特点 并且能够在不同环境中选择合适的存储方案(有自己的见解)
调度器: 掌握调度器原理 能够根据要求把Pod 定义到想要的节点运行
安全: 集群的认证 鉴权 访问控制 原理及其流程
KELM: Linux yum 掌握HELM原理 HELM模板自定义 HELM部署一些常用插件
运维: 修改Kudeadm 达到证书可用期限为10年 能够构建高可用的Kubernetes集群
 
服务分类:
有状态服务:DBMS
无状态服务:LVS APACHE
高可用集群副本数据最好是 >= 3奇数个
 
集群服务组件: 
apiserver:    所有服务访问统一入口
CrontrollerManger:    维持副本期望数目
Scheduler:    复制介绍任务,选择合适的节点进行分配任务
etcd:    键值对数据库 储存K8s集群所有重要信息(持久化)
kubelet:    直接跟容器引擎交互实现容器的生命周期管理
kube-proxy:    负责写入规则至iptebles、IPVS实现服务映射访问的
COREDNS:    可以为集群中的SVC插件一个域名IP的对应关系解析
DASHBOARD:    给K8s集群提供一个B/S结构访问体系
INGRESS CONTROLLER:    官方只能实现四层代理,INGRESS可以实现七层代理
FEDERATION:    提供一个可以跨集群中心多K8s统一管理功能
prometheus:    提供k8s集群的监控能力
ELK:    提供k8s集群日志统一分析介入平台
 
 
1、Kubernetes Service概念:
Service是Kubernetes最核心的概念,通过创建Service,可以为一组具有相同功能的POD应用提供统一的访问入口,并且将请求进行负载分发到后端的各个容器应用上。
在Kubernetes中,在受到RC调控的时候,Pod副本是变化的,对于的虚拟IP也是变化的,比如发生迁移或者伸缩的时候。这对于Pod的访问者来说是不可接受的。
Kubernetes中的Service是一种抽象概念,它定义了一个Pod逻辑集合以及访问它们的策略,Service同Pod的关联同样是居于Label来完成的。Service的目标是提供一种桥梁,它会为访问者提供一个固定访问地址,用于在访问时重定向到相应的后端,这使得非Kubernetes原生应用程序,在无须为Kubemces编写特定代码得前提下,轻松访问后端。
Service同RC一样,都是通过Label来关联Pod的,当你在Service的yaml文件中定义了该service的selector中的label为app:my-web,那么这个service会将Pod-->metadata-->labels中label为app:my-web的Pod作为分发请求的后端。
当Pod发生变化时(增加、减少、重建等),service会及时更新。这样一来,service就可以作为Pod的访问入口,起到代理服务器的作用,而对于访问者来说,通过service进行访问,无需直接感知Pod.
 
2、Kubernetes Service实现方式:
Kubernetes分配给service的固定IP是一个虚拟IP,并不是一个真实的IP,在外部是无法寻址的。在真实的系统上,kubernetes是通过Kube-proxy组件来实现的虚拟IP路由及转发。 所以在之前集群部署的环节上,我们在每个Node上均部署了Proxy这个组件,从而实现了Kubernetes层次的虚拟转发网络。
Kubernetes通过为每个service分配一个唯一的ClusterIP,所以当使用CIusterIP:port的组合访问一个service的时候,不管port是什么,这个组合是一定不会发生重复的。另一方面,kube-proxy为每个service真正打开的是一个绝对不会重复的随机端口,用户在service描述文件中指定的访问端口会被映射到这个随机端口上,这就是问什么用户可以在创建service时随意指定访问端口。
K8S集群中,Pod的IP是docker0网段动态分配的,当发生重启,扩容等操作时,IP地址会随之变化。当某个Pod(frontend)需要去访问其依赖的另一组Pod(backend)时,如果backend的IP发生变化时,如何保证fronted到backend的正常通信变得非常重要,此时需要借助service实现统一访问。
Service的Virtual VIP是由Kubernetes虚拟出来的内部网络,外部时无法寻址到的。但是有些服务及需要被外部访问到,例如web前端。这时候就需要加一层网络转发(nginx、LVS),即外网带内网的转发。Kubernetes提供了NodePort、LoadBalancer、lngress三种方式:
 
NodePort,原理是Kubernetes会在每一个Node上暴露出一个端口:nodePort,外部网络可以通过(任一个Node)[NodeIP]:[NodePort]访问到后端的service。
 
LoadBalancer,在NodePort基础上,Kubernetes可以请求底层云平台创建一个负载均衡器,将每个Node作为后端,进行服务分发。该模式需要底层云平台(例如GCE)支持。
 
lngress,是一种HTTP方式的路由转发机制,由lngress Controller和HTTP代理服务器组合而成。lngress Controller实现监控Kubernetes API,实时更新HTTP代理服务器的转发规则。HTTP代理服务器有GCE Load-Balancer、Haproxy、Nginx等开源方案。

kubernetes组件介绍-service概念的更多相关文章

  1. Kubernetes组件介绍

    一.api-server   基本概念 该端口默认值为6443,可通过启动参数"--secure-port"的值来修改默认值. 默认IP地址为非本地(Non-Localhost)网 ...

  2. k8s功能、各组件介绍以及pod创建流程

    一.什么是Kubernetes Kubernetes(k跟s中间隔了8个字母又称k8s) 是谷歌开源的容器集群管理系统,是 Google 多年大规模容器管理技术Borg 的开源版本,主要功能包括: 基 ...

  3. 三十一、kubernetes网络介绍

    Kubernetes 网络介绍 Service是Kubernetes的核心概念,通过创建Service,可以为一组具有相同功能的容器应用提供一个统一的入口地址,并且将请求负载分发到后端的各个容器应用上 ...

  4. 【九】Kubernetes 之 Service 概念图文讲解及功能演示

    Service 概念 Kubernetes Service 定义了这样一种抽象:逻辑上的一组 Pod,一种可以访问它们的策略 -- 通常称为微服务. Service 通常是通过 Label Selec ...

  5. Kubernetes组件与架构

    转载请标明出处: 文章首发于>https://www.fangzhipeng.com/kubernetes/2018/09/30/k8s-basic1/ 本文出自方志朋的博客 Kubernete ...

  6. Android四大基本组件介绍与生命周期

    Android四大基本组件介绍与生命周期 Android四大基本组件分别是Activity,Service服务,Content Provider内容提供者,BroadcastReceiver广播接收器 ...

  7. Android四大组件之Service

    Android四大组件之Service Android支持服务的概念,服务是在后台运行的组件,没有用户界面,Android服务可用有与活动独立的生命周期.Android支持两种类型的服务: 本地服务: ...

  8. Android四大组件:Service

    前言 Service作为Android四大组件之一,应用非常广泛 本文将介绍对Service进行全面介绍(基础认识.生命周期.使用和应用场景) 目录 目录 1. 基础知识 定义:服务,属于Androi ...

  9. Kubernetes【K8S】(一):Kubernetes组件

    什么是Kubernetes ​ Kubernetes 是一个可移植的.可扩展的开源平台,用于管理容器化的工作负载和服务,可促进声明式配置和自动化.Kubernetes拥有一个庞大且快速增长的生态系统. ...

  10. 7. 丈母娘嫌我不懂K8s的Service概念,让我去面壁

    文章目录 怎么跟你说 Service的出现,就是 解决ip不固定的问题 ,怎么解决呢 ? 听小刘慢慢道来 当Pod宕机后重新生成时,其IP等状态信息可能会变动,Service会根据Pod的Label对 ...

随机推荐

  1. 使用Locust进行性能测试

    当涉及到评估应用程序或服务的性能时,Locust是一个功能强大且易于使用的开源工具.本文将介绍Locust的基本概念和使用方法. 什么是Locust? Locust是一个用于编写.运行和分析负载测试的 ...

  2. wireshark 怎么过滤字符串 和 复制data中的可读文本

    设置 首先点击,[捕获]下面的小放大镜 选择 分组字节流 - 窄(UTF-8/ASCII)- 字符串 (注意,要向选择字符串) 效果 复制报文中的可读数据 右键报文,复制,...as Printabl ...

  3. Linux 命令:find/grep/sed/awk/du/df

    目录 find grep sed awk du/df find # find 属于全部匹配,如输入abc,不能查到abcd # find 默认采用递归搜索 # 按时间 find . -atime -1 ...

  4. DevOps|研发效能治理:进化史、规模化与治理复杂性

    麻广广@码猿外 研发效能这个词近几年火遍全网,各大企业都加入了研发效能治理的行列,开始梳理企业内部各个团队的研发流程,以期望找到企业降本增效的方向. 抛开政治因素,研发效能治理我们到底是在谈什么呢?从 ...

  5. 更快的训练和推理: 对比 Habana Gaudi®2 和英伟达 A100 80GB

    通过本文,你将学习如何使用 Habana Gaudi2 加速模型训练和推理,以及如何使用 Optimum Habana 训练更大的模型.然后,我们展示了几个基准测例,包括 BERT 预训练.Stabl ...

  6. 【go笔记】标准库-strconv

    前言 标准库strconv提供了字符串类型与其他常用数据类型之间的转换. strconv.FormatX()用于X类型转字符串,如strconv.FormatFloat()用于浮点型转字符串. str ...

  7. 《CUDA编程:基础与实践》读书笔记(1):CUDA编程基础

    1. GPU简介 GPU与CPU的主要区别在于: CPU拥有少数几个快速的计算核心,而GPU拥有成百上千个不那么快速的计算核心. CPU中有更多的晶体管用于数据缓存和流程控制,而GPU中有更多的晶体管 ...

  8. JDK中动态库加载路径问题,一文讲清

    前言 本周协助测试同事对一套测试环境进行扩容,我们扩容很原始,就是新申请一台机器,直接把jdk.resin容器(一款servlet容器).容器中web应用所在的目录,全拷贝到新机器上,servlet容 ...

  9. MIT6.s081/6.828 lectrue07:Page faults 以及 Lab5 心得

    本篇博客主要是复习 MIT6.s081/6.828 lectrue07:Page faults 以及记录 Lab5 :COW fork 的心得 值得一提的是,2020 年之前的版本第 5 个 lab ...

  10. MySQL到SelectDB的实时同步策略

    随着数据分析在业务决策中变得日益重要,数据实时同步和分析成为企业提升竞争力的关键.MySQL 作为广泛使用的关系型数据库,其数据存储丰富,但无法满足大规模数据分析和高并发查询的需求.而 SelectD ...