k8s和Docker
Docker是一个开源的应用容器引擎
k8s是一个开源的容器集群管理系统
这里我尽量用比较浅显的方式来说明k8s系统
一、k8s是如何管理的节点的呢:
1、k8s 分master和node
2、master是整个集群的管理中心,在master上可以执行 kubectl get pod 等命令,来干预node
3、node是具体的pod的承载的机器,我们有时候称为node节点
4、master可以有多个,例如:master1,master2,master3, 在任意的master上都可以执行相关的管理命令来干预node节点的行为
行为包括暂停节点、删除节点、查看节点、调度节点等等。
5、node节点理论上是有无限个,node节点在安装完毕后,通过注册的方式向master进行注册,这样master会自动的感应到node节点的
Master负责集群的管理,协调集群中的所有行为/活动。例如,pod应用的运行、修改、更新等。节点(Node)作为Kubernetes集群中的工作节点,可以是VM虚拟机、物理机。每个Node上都需要安装一个Kubelet,docker,kubelet-proxy等。用于管理Node节点与Kubernetes Master 通信。每个Node节点上至少还要运行container runtime (比如Docker或者rkt)
在Kubernetes(k8s)集群上部署应用程序时,会先通知master启动容器中的应用程序,master 调度容器在集群的Node节点上运行,Node节点使用master公开的Kubernetes API与主节点进行通信。最终用户还可以直接使用Kubernetes API与集群进行交互
我们用一个表格来看下一个master、node的关系
| 角色 | ip | 组件 |
| master1 | 192.168.51.21 |
etcd kube-apiserver kube-controller-manager kube-scheduler |
| master2 | 192.168.51.22 |
etcd kube-apiserver kube-controller-manager kube-scheduler |
| node1 | 192.168.51.11 |
kubelet kube-proxy docker |
| node2 | 192.168.51.22 |
kubelet kube-proxy docker |
K8s集群组件如下:
etcd:一个高可用的K/V键值对存储和服务发现系统,节点的注册信息会存贮到etcd。
flannel:实现跨主机的容器网络的通信,当然我们也可以使用类似calico这样的网络组件代替flannel。
这里说白了,是构建了一个内部的pod网络通讯环境,比如:建立虚拟网卡,网桥等。
kube- apiserver:提供Kubernetes集群内的node节点的与master通讯, 前提需要安装通讯所需的网络插件,api-server很重要是master和node进行通讯的必要组件,例如检测node是否存活,node状态等。
kube- controller-manager:确保集群服务。
kube- scheduler:从集群中调度容器,分配到某Node节点,或从集群中驱离或定向调度到某节点等操作。
kubelet:在Node节点上按照配置文件中定义的容器规格启动容器。
kube-proxy:提供网络代理服务。
二、k8s node节点上的一些软件组成
1、包括网络插件、docker引擎、nginx等,它是一个非常复杂的软件系统.
2、操作系统比如:centos系统需要7.2 以上最好,centos6 安装docker 基本安装出现各种问题。
三、k8s和docker关系
可以说docker(类容器),可以说是k8s的基础,必须要安装容器环境,这里拿docker为例,我安装的是二进制k8s,所以每台机器,例如:master,node等都必须要安装
docker
k8s和Docker的更多相关文章
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录
0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之集群部署环境规划(一)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.环境规划 软件 版本 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之自签TLS证书及Etcd集群部署(二)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.服务器设置 1.把每一 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.flanneld介绍 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之部署master/node节点组件(四)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 1.部署master组件 ...
- Kubernetes k8s 基于Docker For Windows
开启和安装Kubernetes k8s 基于Docker For Windows 0.最近发现,Docker For Windows Stable在Enable Kubernetes这个问题上 ...
- k8s部署docker容器
一.环境 需机器已部署好k8s和docker的环境 二.操作步骤 1.将制作好的镜像推送到docker仓库 docker tag nginx:test harbor:test-nginx docker ...
- k8s和Docker关系简单说明
关注「开源Linux」,选择"设为星标" 回复「学习」,有我为您特别筛选的学习资料~ 这篇文章主要介绍了k8s和Docker关系简单说明,本文利用图文讲解的很透彻,有需要的同学可以 ...
- k8s系列~docker mysql
docker封装mysql的一些心得 简介:今天咱们来聊聊容器化mysql的一些心得 版本:Docker version 18.03 mysql 5.7.21考虑条件: 1 选好合适的docker镜 ...
随机推荐
- Java基础—private、this关键字及get/set方法
Java基础-private\this关键字以及get\set方法 1.private关键字 private关键字通常用来修饰成员变量用来保护原有数据的安全,比如在下面学生类中 然后在测试类中调用成员 ...
- Linux安装docker 配置Apache
镜像下载.域名解析.时间同步请点击 阿里云开源镜像站 要求: 安装docker yum install docker -y 将centos镜像导入云主机 将centos镜像导入docker docke ...
- 嵌入式无操作系统下管理内存和队列(类UCOS II思想)
例子:存储日志,最多存128条,每条最大1MB. 内存方面 因为嵌入式不适合用动态内存,会产生碎片.这里我们用 u8 data[LOG_SIZE];开辟固定128MB的内存区,再对其分为128个1MB ...
- CVE-2017-12635(Couchdb垂直权限绕过漏洞)
简介 Apache CouchDB是一个开源数据库,专注于易用性和成为"完全拥抱web的数据库".它是一个使用JSON作为存储格式,JavaScript作为查询语言,MapRedu ...
- Ubuntu- 彻底干净卸载MySQL、Apache2、Php的方法
一.卸载删除 mysql 1 sudo apt-get autoremove --purge mysql-server-5.0 2 sudo apt-get remove mysql-server 3 ...
- AD2019(Altium designer)常用快捷键,使用技巧
测量工具 测量距离:Ctrl+M, 删除测量结果:shift+C, 退出测量:多次右键 设置栅格 G或Ctrl+G 3D查看 按住shift键,再按住鼠标右键移动鼠标,即可在任意角度查看PCB的3D效 ...
- springboot 设定访问项目的根路径
springboot的配置文件application.yml: spring.mvc.view.prefix : / spring.mvc.view.suffix : .html server: po ...
- 面试问题之C++语言:说一说C++中四种cast转换
C++中四种类型转换是:static_cast.dynamic_cast.const_cast.reinterpret_cast 1.const_cast 常量转换,用于将const变量转为非cons ...
- Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?
Redisson.Jedis.lettuce 等等,官方推荐使用 Redisson.
- Java 中,受检查异常 和 不受检查异常的区别?
受检查异常编译器在编译期间检查.对于这种异常,方法强制处理或者通过 throws 子句声明.其中一种情况是 Exception 的子类但不是 RuntimeException 的子类.非受检查是 Ru ...