kubernetes入门(05)kubernetes的核心概念(2)
一、使用 kubectl run 创建 pod(容器)
命令 kubectl run类似于 docker run,可以方便的创建一个容器(实际上创建的是一个由deployment来管理的Pod):

等到容器变成Running后,就可以用 kubectl 命令来操作它了,比如
- kubectl get - 类似于 docker ps ,查询资源列表
- kubectl describe - 类似于 docker inspect ,获取资源的详细信息
- kubectl logs - 类似于 docker logs ,获取容器的日志
- kubectl exec - 类似于 docker exec ,在容器内执行一个命令
二、使用 yaml 创建 pod(容器)
前面是通过 kubectl run 来启动了第一个Pod,但是 kubectl run 并不支持所有的功能。
在Kubernetes中,更经常使用yaml文件来定义资源,并通过 kubectl create -f file.yaml 来创建资源。
比如,一个简单的nginx Pod可以定义为:

前面提到, kubectl run 并不是直接创建一个Pod,而是先创建一个Deployment资源
(replicas=1),再由Deployment来自动创建Pod,这等价于这样一个配置:

三、使用volume
Pod的生命周期通常比较短,只要出现了异常,就会创建一个新的Pod来代替它。
容器内的数据会随着Pod消亡而自动消失。
Volume就是为了持久化容器数据而生,比如可以为redis容器指定一个hostPath来存储redis数据:

Kubernetes volume支持非常多的插件,可以根据实际需要来选择:
- emptyDir
- hostPath
- gcePersistentDisk
- awsElasticBlockStore
- nfs
- iscsi
- flocker
- glusterfs
- rbd
- cephfs
- gitRepo
- secret
- persistentVolumeClaim
- downwardAPI
- azureFileVolume
- vsphereVolume
四、使用service
前面虽然创建了Pod,但是在kubernetes中,Pod的IP地址会随着Pod的重启而变化,并不建议直接拿Pod的IP来交互。
那如何来访问这些Pod提供的服务呢?
使用Service。Service为一组Pod(通过labels来选择)提供一个统一的入口,并为它们提供负载均衡和自动服务发现。
比如,可以为前面的 nginx-app 创建一个service:

这样,在cluster内部就可以通过 http://10.0.0.66 和 http://node-ip:30772 来访问nginx-app。
而在cluster外面,则只能通过 http://node-ip:30772 来访问。
个人理解::真正处理处理请求的pod可能在入口node上,也可能被service再次分发到其他的node上。
四、扩展应用
通过修改Deployment中副本的数量(replicas),可以动态扩展或收缩应用,这些自动扩展的容器会自动加入到service中,而收缩回收的容器也会自动从service中删除。
$ kubectl scale --replicas=3 deployment/nginx-app
$ kubectl get deploy

五、滚动升级
滚动升级(Rolling Update)通过逐个容器替代升级的方式来实现无中断的服务升级:
kubectl rolling-update frontend-v1 frontend-v2 --image=image:v2
在滚动升级的过程中,如果发现了失败或者配置错误,还可以随时回滚:
kubectl rolling-update frontend-v1 frontend-v2 --rollback
需要注意的是,rolling-update只针对ReplicationController,不能用在策略不是RollingUpdate的Deployment上(Deployment可以在spec中设置更新策略为RollingUpdate,默认就是RollingUpdate):

而更新应用的话,就可以直接用 kubectl set 命令:
kubectl set image deployment/nginx-app nginx-app=nginx:1.9.1
滚动升级的过程可以用 rollout 命令查看:
kubectl rollout status deployment/nginx-app
Deployment也支持回滚:

六、资源限制
Kubernetes通过cgroups提供容器资源管理的功能,可以限制每个容器的CPU和内存使
用,比如对于刚才创建的deployment,可以通过下面的命令限制nginx容器最多只用
50%的CPU和128MB的内存:

七、健康检查
Kubernetes作为一个面向应用的集群管理工具,需要确保容器在部署后确实处在正常的运行状态。
Kubernetes提供了两种探针(Probe,支持exec、tcp和http方式)来探测容器的状态:
- LivenessProbe:探测应用是否处于健康状态,如果不健康则删除重建改容器
- ReadinessProbe:探测应用是否启动完成并且处于正常服务状态,如果不正常则更
新容器的状态
对于已经部署的deployment,可以通过 kubectl edit deployment/nginx-app 来更新manifest,增加健康检查部分:

八、集群联邦
集群联邦(Federation)用于跨可用区的Kubernetes集群,需要配合云服务商(如GCE、AWS)一起实现。

九、创建kubernetes集群
1、minikube

2、play-with-k8s
Play with Kubernetes提供了一个免费的Kubernets体验环境,直接访问http://play-withk8s.
com就可以使用kubeadm来创建Kubernetes集群。注意,每个创建的集群最长可以
使用4小时。
Play with Kubernetes有个非常方便的功能:自动在页面上显示所有NodePort类型服务
的端口,点解该端口即可访问对应的服务。
详细使用方法可以参考Play-With-Kubernetes。
3、Katacoda playground
Katacoda playground也提供了一个免费的2节点Kuberentes体验环境,网络基于
WeaveNet,并且会自动部署整个集群。但要注意,刚打开Katacoda playground页面时
集群有可能还没初始化完成,可以在master节点上运行 launch.sh 等待集群初始化完
成。
部署并访问kubernetes dashboard的方法:

然后点击Terminal Host 1右边的,从弹出的菜单里选择View HTTP port 8080 on Host1,即可打开Kubernetes的API页面。在该网址后面增加 /ui 即可访问dashboard。
kubernetes入门(05)kubernetes的核心概念(2)的更多相关文章
- Kubernetes 入门之Kubernetes 的基本概念和术语
Kubernetes是什么? 他是一个全新的基于容器技术分布式架构领先方案: 他也是一个开放的开发平台: 他也是一个完备的分布式系统支撑平台: Kubernetes的基本慨念和术 ...
- Kubernetes入门(一)——Kubernetes v1.18.5 安装部署
Kubernetes的安装有两种方式:一是使用各个厂商封装的Kubernetes发行版,优点是可以一键安装部署,操作简单,缺点也很明显,若安装过程中某一步骤出现问题,很难定位处理:二是使用官方提供的k ...
- Docker入门——理解Docker的核心概念
1 前言 相信不少人听过这么一句话: 人类的本质是复读机. 在软件开发领域也一样,我们总是想寻找更好地方式复制优秀的逻辑或系统.最核心的方法是抽取通用逻辑和组件,把差异化的东西接口化或配置化,达到复用 ...
- Maven入门-2.Maven一些核心概念介绍
1.Maven仓库2.Maven坐标3.Maven插件和目标4.Maven生命周期4.1 clean:清理项目4.2 default:构建项目(重要)4.3 site:建立项目站点 1.Maven仓库 ...
- 入门大数据---Flink核心概念综述
一.Flink 简介 Apache Flink 诞生于柏林工业大学的一个研究性项目,原名 StratoSphere .2014 年,由 StratoSphere 项目孵化出 Flink,并于同年捐赠 ...
- kubernetes核心概念
摘抄自: https://www.cnblogs.com/zhenyuyaodidiao/p/6500720.html 1.基础架构 1.1 Master Master节点上面主要由四个模块组成:A ...
- Kubernetes核心概念总结
目录贴:Kubernetes学习系列 1.基础架构 1.1 Master Master节点上面主要由四个模块组成:APIServer.scheduler.controller manager.etcd ...
- 第3 章 : Kubernetes 核心概念
Kubernetes 核心概念 本文整理自 CNCF 和阿里巴巴联合举办的云原生技术公开课的课时 3:Kubernetes 核心概念.本次课程中,阿里巴巴资深技术专家.CNCF 9个 TCO 之一 李 ...
- 微服务 + Docker + Kubernetes 入门实践 目录
微服务 + Docker + Kubernetes 入门实践: 微服务概念 微服务的一些基本概念 环境准备 Ubuntu & Docker 本文主要讲解在 Ubuntu 上安装和配置 Dock ...
- 入门 - 复习Kubernetes核心概念 (八)
本文将会简单介绍Kubernetes的核心概念.因为这些定义可以在Kubernetes的文档中找到,所以文章也会避免用大段的枯燥的文字介绍.相反,我们会使用一些图表(其中一些是动画)和示例来解释这些概 ...
随机推荐
- Cesium解决按住滚轮旋转时进入地下的问题
viewer.clock.onTick.addEventListener(function () { setMinCamera()}) var setMinCamera = functi ...
- Linux编辑器篇-分享10个最好的Markdown编辑器
在这篇文章中,兄弟连Linux培训会分享一些可以在 Linux 上安装使用的最好的 Markdown 编辑器.虽然你在 Linux 平台上能找到非常多的 的 Markdown 编辑器,但是在这里我们将 ...
- 使用html元素的getBoundingClientRect来获取dom元素的时时位置和大小
使用: var section = $('.section'):这是jquery包装的dom元素,其他前端框架返回的可能也是一个包装元素, 我们需要获得的是里面的html的dom元素 然后:secti ...
- Bootatrap常用样式
1. 使div固定定位在页面的底部: // 当然, 需要加上自己的样式稍加修饰<div class="navbar navbar-fixed-bottom mobile-view-bo ...
- 笔记:Spring Cloud Feign Ribbon 配置
由于 Spring Cloud Feign 的客户端负载均衡是通过 Spring Cloud Ribbon 实现的,所以我们可以直接通过配置 Ribbon 的客户端的方式来自定义各个服务客户端调用的参 ...
- 排序算法Java实现(冒泡排序)
算法描述:对于给定的n个记录,从第一个记录开始依次对相邻的两个记录进行比较,当前面的记录大于后面的记录时,交换位置,进行一轮比较和交换后,n个记录中的最大记录将位于第n位:然后对前(n-1)个记录进行 ...
- Oracle查询优化改写--------------------单表查询
一.查询表中所有的行与列 二.从表中检索部分行 三.查找空值 四.将空值转化为实际值(coalesce) 五.查找满足多个条件的行(查询部门为10中所有的员工.所有得到提成的员工,以及部门20中工资不 ...
- 02-Python的下载和安装_Python编程之路
原文发布在特克斯博客www.susmote.com 之前给大家讲了关于python的背景知识,还有Python的优点和缺点,相信通过之前的介绍很多人已经清楚自己到底要不要选择学习Python,如果已经 ...
- 随记PC-win7 64位系统网络连接状态一直转圈、等待状态的异常解决方案
各位看官好~ 最近电脑也做了下升级,入手个士必得360G的SSD来玩玩,顺便也下个新系统,看看有什么区别,想想顺便升级下系统也是好的,就开始了装机,装系统的路程~~~~~~ 好了不说废话,直接进入主题 ...
- 定位bug的姿势对吗?
举个例子来说明 WEB页面上数据显示错误,本来应该显示38, 结果显示35,这个时候你怎么去定位这个问题出在哪里? 1.通过fiddler抓包工具(或者其他抓包工具), 分析接口返回的数据是35还是 ...
