centos7下kubernetes(2。kubernetes---start,重要概念)
Cluster
cluster是计算,存储和网络资源的集合,kubernetes是利用这些资源运行各种基于容器的应用
Master
Master是cluster的大脑,他的主要职责是调度,即决定应用在哪里运行。master运行linux操作系统,可以是物理机或者虚拟机。为了实现高可用,可以运行多个master。
Node
Node的职责是运行容器应用。Node有master管理,Node负责监控并汇报容器的状态,并根据master的要求管理容器的生命周期。Node运行在linux操作系统,可以是物理机或者虚拟机。
上一节交互式的教程中我们创建的clusyer只有一个主机host01.它既是master也是node
Pod
pod是kubernetes的最小工作单元。每个pod包含一个或者多个容器。pod中的容器会作为一个整体被master调度到一个node上运行
kubernetes引入pod主要基于下面两个方面
1.可管理性
有些容器本来就是需要紧密联系,一起工作。pod提供了比容器更高层次的抽象,将他们封装到一个部署单元中。kubernetes以pod为最小单位进行调度,扩展,共享资源,管理生命周期
2.通信和资源共享
pod中的所有容器使用同一个网络namespace,即相同的IP地址和port空间。他们之间通过localhost通信。同样的,这些容器可以共享存储,当kubernet挂载volume到pod,本质上是将volume挂载到pod中的每一个容器
pods两种使用方法:
1.运行单一容器。
one-container-per-pod是kubernetes最常见的模型,这种情况下,只是将单个容器简单封装成pod。即使只有一个容器,kubernetes管理的也是pod,而不是直接管理容器
2.运行多个容器
哪些容器应该放到一个pod中?
答案是:这些容器联系必须非常紧密,而且需要直接共享资源
举个例子:
下面这个pod包含两个容器:file puller和web server
file puller会定期从外部的content manager中拉取最新的文件,将其存放在共享的volume中。web serverv从volume读取文件,响应consumer的请求。
这两个容器是紧密协作得,他们一起为consumer提供最新得数据;同时他们也通过volume共享数据。所以放到一个pod是合适得
再看一个反例:是否需要将tomcat和mysql放到一个pod中?
tomcat从mysql中读取数据,他们之间需要协作,但还不至于需要放到一个pod中一起部署,一起启动,一起停止。他们之间是通过JDBC交换数据,并不是直接共享存储,所以放到各自得pod中更合适。
Controller
kubernetes通常不会直接创建pod,而是通过contorller来管理pod。controller中定义了pod得部署特性,比如有几个副本,在什么样得node上运行等。为了满足不同得业务场景,kubernetes提供了多种controller,包括deployment,replicaset,daemonset,statefuleset,job等。
Deployment
是最常用的controller,比如前面的教程中就是通过创建deployment来部署应用的。deployment可以管理POd的多个副本,并确保Pod按照期望的状态运行。
Replicaset
实现了pod多副本管理。使用dployment时会自动创建replicaset,也就是说deployment是通过replicaset来管理pod的多个副本的,我们通常不需要直接使用replicaset
daemonset
用于每个node最多只运行一个pod副本的场景。正如其名称所揭示,daemonset用于daemon
statefuleset
能够保证pod的每个副本在整个生命周期中名称是不变的。而其他controller不提供这个功能,当某个pod发生故障需要删除并重启的时候,pod的名称会发生变化。同事statuefulset会保证副本按照固定顺序启动,更新或者删除。
job
用于运行结束就删除的应用,而其他controller中的pod通常是长期运行的状态
service
定义外界访问一组特定的pod的方式。service有自己的端口和IP。service为pod提供了负载均衡
Namespace
可以将一个物理的cluster逻辑上划分成多个虚拟的cluster,每个cluster就是一个namespace。不同的namespace里的资源是完全隔离的

kubernetes默认创建了两个namespace
default --创建资源时如果不指定,将被放到这个namespace中。
kube-system --kubernetes自己创建的系统资源将放到这个namespace中
centos7下kubernetes(2。kubernetes---start,重要概念)的更多相关文章
- Centos7下yum安装kubernetes
一.前言 Kubernetes 是Google开源的容器集群管理系统,基于Docker构建一个容器的调度服务,提供资源调度.均衡容灾.服务注册.动态扩缩容等功能套件,目前centos yum源上 ...
- [Kubernetes]关于 Kubernetes ,你想要的,都在这儿了
陆陆续续,关于 Kubernetes 写了有 20+ 篇文章了. 今天这篇文章来一个整合,从实践到理论,可以按需查看(我是按照博客发表时间来排序的,如果后续有想要更新的内容,也会及时更新到这篇文章中) ...
- centos7下kubernetes(3。部署kubernetes)
环境:三个centos7 K8s2是Master;K8s1是node1:K8s3是node2 官方文档:https://kubernetes.io/docs/setup/independent/ins ...
- [Kubernetes]CentOS7下Etcd集群搭建
Etcd简要介绍 Etcd是Kubernetes集群中的一个十分重要的组件,用于保存集群所有的网络配置和对象的状态信息 Etcd构建自身高可用集群主要有三种形式: ①静态发现: 预先已知 Etcd 集 ...
- centos7.5下kubeadm安装kubernetes集群安装
文章是按https://blog.csdn.net/Excairun/article/details/88962769,来进行操作并记录相关结果 版本:k8s V14.0,docker-ce 18.0 ...
- [Kubernetes]CentOS7下搭建Harbor仓库
环境依赖: Harbor仓库需要环境:Python 2.7或以上版本,Docker 1.10或以上,Docker Compose 1.6.0或以上. CentOS7自带Python,所以不需要安装. ...
- Centos7 使用 kubeadm 安装Kubernetes 1.13.3
目录 目录 什么是Kubeadm? 什么是容器存储接口(CSI)? 什么是CoreDNS? 1.环境准备 1.1.网络配置 1.2.更改 hostname 1.3.配置 SSH 免密码登录登录 1.4 ...
- centos7使用kubeadm安装kubernetes集群
参考资料:官方文档 一.虚拟机安装 配置说明: windows下使用vbox,centos17.6 min版,kubernetes的版本是1.14.1, 安装如下三台机器: 192.168.56.15 ...
- centos7使用kubeadm搭建kubernetes集群
一.本地实验环境准备 服务器虚拟机准备 IP CPU 内存 hostname 192.168.222.129 >=2c >=2G master 192.168.222.130 >=2 ...
- 从centos7镜像到搭建kubernetes集群(kubeadm方式安装)
在网上看了不少关于Kubernetes的视频,虽然现在还未用上,但是也是时候总结记录一下,父亲常教我的一句话:学到手的东西总有一天会有用!我也相信在将来的某一天会用到现在所学的技术.废话不多扯了... ...
随机推荐
- [android] 测试的相关概念
/********************2016年5月4日 更新********************************/ 知乎:如何专业地进行黑盒测试? 之前遇到过有些黑盒测试人员,感觉他 ...
- linux 下修改mysql下root 权限来允许远程连接
MySQL默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须修改root允许远程连接. 其操作简单,如下所示: 1. 进入mysql: /usr/local/mysql/bin/ ...
- DOM技术
DOM概述 DOM:Document Object Model(文档对象模型)(DOM核心就是 文档变对象,标签也变对象,属性也变对象,反正就是把标记文档拆散) 用来将标记型对象封装成对象,并将标记型 ...
- PHP7.27: pdf
http://www.fpdf.org/ https://github.com/Setasign/FPDF https://www.ntaso.com/fpdf-and-chinese-charact ...
- wamp本地可以访问,远程无法访问,报错:client denied by server configuration
出错原因:配置文件限制非本机访问 对策:修改httpd.conf,选择合适的模式,一般局域网环境的话,可以完全放开,使用 <Directory "..../wamp/www" ...
- CNN中,1X1卷积核到底有什么作用呢?
CNN中,1X1卷积核到底有什么作用呢? https://www.jianshu.com/p/ba51f8c6e348 Question: 从NIN 到Googlenet mrsa net 都是用了这 ...
- IDEA项目搭建十四——Web站点Controller基类及布局页静态资源设计
一.简介 站点搭建完成后,编写页面时一般会有如下几个需求 1.嵌套静态页面时有很大一部分通用代码,如css.js这部分可以使用thymeleaf的局部片段代码块组成 2.这些静态资源默认放在程序中,但 ...
- mac os安装多个版本的chrome
1.下载chrome69安装程序后,双击dmg文件 2.将chrome拖到Application文件夹,如图,选择保留两者,不要替换 打开应用程序,会多出一个Google Chrome2,重命名为Go ...
- Android内存优化(五) Lint代码扫描工具
1.使用 工具栏 -> Analyze -> Inspect Code… 点击 Inspect Code 后会弹出检查范围的对话框: 默认是检查整个项目,我们可以点击 Custom sc ...
- SpringBoot-学习笔记
启动方式 运行main方法 @SpringBootApplication public class BootApplication { public static void main(String[] ...