Pods

在上一篇也说明了,pods是kubernetes的最小部署单元,并且所有在pods中的container共享namespaces

那么为什么需要pods这样的概念?

因为在实际中,我们有一种需求,某些进程需要部署在一台机器上,通过IPC或者本地文件来通信,比如因为他们之间数据传输比较大

那么现在我们用容器技术,我们的container就表示一个虚拟的机器,如果我们把多个进程都放在一个container里面可以吗?

肯定可以,但是问题在于,你使用容器的目的就是要平台来帮你管理和监控容器,那么容器就应该是最小的failover单元,如果你在容器里面加上很多process,那么这些process的管理和监控谁来做,又回到了原来的问题,所以一个container比较好的用法是只有一个process

这里如果每个容器一个process,那么容器的namespaces是隔离的,通信会比较麻烦,而且按容器调度也无法保证local

所以自然需要pods这样的higher-level概念,来便于容器的编排,把多个容器变成一个single unit

Pods内部因为共享namesapces,就和一台机器上一样,用IPC就可以简单的通信;那么Pods之间如何通信,Pods之间也可以通过ip直接通信,无论这些Pods被部署在什么地方,但他们都像一个local area network (LAN)一样,可以随意访问对方。

那么我们应该怎么使用pods?怎么把container分配到不同的pods中?

我的理解,没有充分的理由,那就应该一个pod对应于一个container;只有有充分的理由要把多个container绑定在一起的时候,才把他们放到一个pod中

创建Pod

首先创建yaml文件,里面包含这个pod的metadata和spec信息,其中的containerPort只是说明性的

docker和kubernetes中所有组件的配置都是类似这种yaml格式,

如果不清楚具体的格式,可以用explain来查看各个字段的解释

kubectl explain pods

kubectl explain pod.spec

根据Yaml创建Pods,

kubectl create -f kubia-manual.yaml

查看运行Pods的完整定义,


kubectl get po kubia-manual -o yaml

kubectl get po kubia-manual -o json

查看所有Pods,

kubectl get pods

当Pods和Container跑起来后,怎么查看他们的log?

对于docker容器,日志会被输出到标准输出,然后docker runtime会把这些日志重定向到文件,你需要登录到Pod所在的机器,用命令查看

docker logs <container id>

这样很麻烦,Kubernetes提供更简单的方法,

kubectl logs kubia-manual

看某个container

kubectl logs kubia-manual -c kubia

之前看到,可以创建service去把Pods的服务提供出去,但在之前想debug或测试,有没有其他更简单的访问方式


kubectl port-forward kubia-manual 8888:8080

Kubernetes allows you to configure port forwarding to the pod.
This is done through the kubectl port-forward command. The command will forward your machine’s local port 8888 to port 8080 of your kubiamanualpod

Pods标签

labels,干啥用的?

当Pods很多的时候,我们需要去组织和管理pods,组织和管理的标准方法,是分类
lables类似tags,被打上标签的Pods,就被分到各种类别中

如下图,我们可以按照app,rel两个维度的lables来组织各种服务

相关的命令如下,

label可以在创建pods的时候带上,

你可以查看所有pods的label,

或某些特定的label,

当然你可以动态的改label,新增或覆盖修改

kubectl label po kubia-manual creation_method=manual

kubectl label po kubia-manual-v2 env=debug --overwrite

当然有了label,你可以通过label来筛选所有的Pods,

有label的不光是Pods,其实我们也可以给work node加上labels,这样就可以做到按label来schedule Pods,

比如有些Pods需要GPU,那么就需要把他调度到有GPU的work node上,

具体做法,

先给worknode加上label,

kubectl label node gke-kubia-85f6-node-0rrx gpu=true

然后在创建Pod的Yaml指定nodeselector,

Pods Annotation

大段的注释,不具备功能性,说明性文字,最大到256kb

$ kubectl annotate pod kubia-manual mycompany.com/someannotation="foo bar"

pod "kubia-manual" annotated

$ kubectl describe pod kubia-manual

...

Annotations: mycompany.com/someannotation=foo bar

Namespaces

这个和label容易混淆,Namespaces是用户把集群划分的,是non-overlapping的分类;而label是可以overlapping的

比如把系统分成几个部分,以给多个用户使用,或是把系统分成产品,开发,QA环境

可见命名空间是一种管理和组织的方式,把一个整体的资源,划分成多块,用于不同的用途或用户,但并不会去真正隔离

Although namespaces allow you to isolate objects into distinct groups,
which allows you to operate only on those belonging to the specified namespace, they don’t provide any kind of isolation of running objects

可以列存所有Namespaces,正常情况下,都是默认在default命名空间

你可以看某个ns下的pods,

创建ns

$ kubectl create namespace custom-namespace

namespace "custom-namespace" created

在ns下创建资源

$ kubectl create -f kubia-manual.yaml -n custom-namespace

pod "kubia-manual" created

删除Pods

$ kubectl delete po kubia-gpu

pod "kubia-gpu" deleted

$ kubectl delete po -l creation_method=manual

pod "kubia-manual" deleted

pod "kubia-manual-v2" deleted

kubernetes in action - Pods的更多相关文章

  1. Kubernetes工作流之Pods一

    This page provides an overview of Pod, the smallest deployable object in the Kubernetes object model ...

  2. kubernetes in action - Overview

    传统的应用都是“monoliths”,意思就是大应用,即所有逻辑和模块都耦合在一起的 这样明显很挺多问题的,比如只能scale up,升级必须整体升级,扩容 所以我们就想把大应用,broken dow ...

  3. Kubernetes工作流之Pods二

    Init Containers This feature has exited beta in 1.6. Init Containers can be specified in the PodSpec ...

  4. kubernetes in action - Services

    问题,如何将Pod所提供的功能提供给别人用?微服务,是服务,所以关键要把服务提供出去 直接把pod的静态ip提供给用户用,这个会有很多问题,比如failover,扩容,负载均衡等 所以需要servic ...

  5. kubernetes in action - Replication Controller

    理解这个问题,就是pods在Kubernetes中怎么进行failover 在Kubernetes的work node上有kubelet,会负责监控该work node上的pods,如果有contai ...

  6. 读书笔记 | Kubernetes in Action

    1 Kubernetes介绍 Kubernetes(以下简称K8s) 是一个部署和管理容器化应用的软件系统.它将底层基础设施抽象,简化了应用的开发.部署,以及对开发和运维团队的管理. K8s由一个主节 ...

  7. kubernetes in action - Volumes

    Volume解决Kubernetes的存储的问题 对于Pod使用的存储,抽象为volume,volume伴随着Pod的创建而创建,消失而同时消失,不能单独的创建 这样的好处,是存储的塑胶不会因为某个c ...

  8. 三小时学会Kubernetes:容器编排详细指南

    三小时学会Kubernetes:容器编排详细指南 如果谁都可以在三个小时内学会Kubernetes,银行为何要为这么简单的东西付一大笔钱? 如果你心存疑虑,我建议你不妨跟着我试一试!在完成本文的学习后 ...

  9. Kubernetes基础:Service

    本文的试验环境为CentOS 7.3,Kubernetes集群为1.11.2,安装步骤参见kubeadm安装kubernetes V1.11.1 集群 Service 介绍 我们通过Pod.Deplo ...

随机推荐

  1. Mysql中设置指定IP的特定用户及特定权限

    创建用户:格式:grant select on 数据库.* to 用户名@登录主机 identified by '密码' 举例: 例 1:增加一个用户 test1 密码为 abc,让他可以在任何主机上 ...

  2. fiddler抓包工具

    转载: http://www.cr173.com/html/15341_1.html https://www.cnblogs.com/shihaiming/p/5887654.html 软件简介: 数 ...

  3. npm——安装教程、安装vue脚手架

    npm:是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题.比如常用的有: 1)允许用户从NPM服务器下载别人编写的第三方包到本地使用. 2)允许用户从NPM服务器下载并安 ...

  4. linux 系统调用sysconf【总结】

    1.前言 当前计算机都是多核的,linux2.6提供了进程绑定cpu功能,将进程指定到某个core上执行,方便管理进程.linux提供了sysconf系统调用可以获取系统的cpu个数和可用的cpu个数 ...

  5. [Linux]目录x权限对文件操作的影响

    问题 我们常使用linux以下命令 cd 进入目录 ls 列出目录中的文件 或者直接打开目录中的文件 以上操作对于目录权限位的设置来说,是有一定迷惑性的,如表格所示   cd进入该目录 cd进入该目录 ...

  6. python正则表达式--编译正则表达式re.compile

    编译正则表达式-- re.compile 使用re的一般步骤是先将正则表达式的字符串形 式编译为pattern实例,然后使用pattern实例处理文本并获取匹配结果(一个Match实例(值为True) ...

  7. Codeforces 1120D Power Tree [最小生成树]

    洛谷 Codeforces 这题怎么一个中文题解都没有,是不是你们都认为太水了-- 思路 显然可以用dfs序把每个节点变成给一个区间的叶子节点加上某个数. 显然把叶子序列差分一下变为\(a_1,a_2 ...

  8. PID控制器开发笔记之十二:模糊PID控制器的实现

    在现实控制中,被控系统并非是线性时不变的,往往需要动态调整PID的参数,而模糊控制正好能够满足这一需求,所以在接下来的这一节我们将讨论模糊PID控制器的相关问题.模糊PID控制器是将模糊算法与PID控 ...

  9. 【python3 自动化基础之pip】pip常用命令归类

    1.升级pippython -m pip install --upgrade pip(包名) 2.安装pymysql pip install pymysql 3.pip按照到指定目录 python - ...

  10. img标签里的value获取

    简单描述:在img标签里的value存放了需要用到的值,但是在js中获取的时候,我直接写的就是$("#imgStr").val(),结果发现是空,后来查了一下,才知道,img的va ...