为了解决多应用联合运行的问题,同时还要不破坏容器的隔离,就要再对多个容器进行打包。Pod就是对容器的打包,里面的容器可以看成是一个整体,总是能一起调度、一起运行,绝不会出现分离的情况,而Pod属于Kubernetes,可以在不触碰下层容器的情况下任意定制和修改,Kubernetes让Pod去编排容器,然后将Pod作为应用调度部署的最小单位

概括起来,Pod是Kubernetes的调度单位,代表一个或一组容器,所有的Kubernetes功能都必须通过Pod来实现

使用YAML描述Pod

因为Pod是API对象,所以必然也有apiVersion、kind、metadata、spec这四个基本组成部分,对Pod来说apiVersion、kind固定为v1和Pod,而一般来说,metadata里应该有name和labels这两个字段。使用Docker创建容器时,可以不给容器起名字,但在Kubernetes里,Pod必须要有一个名字,这也是Kubernetes里所有资源对象的一个约定

apiVersion: v1da
kind: Pod
metadata:
name: busy-pod
labels:
owner: test
env: demo
region: north
tier: back

metadata写上name和labels即可,而spec需要管理,维护Pod,其中有许多关键信息,containers是其中最重要的信息

containers是一个数组,其中的每一个元素是一个container对象,也就是容器,同时必须要有一个name表示名字,然后还要有一个image字段来说明它使用的镜像,name和image是必须要指定的

如下编写一段spec

spec:
containers:
-image: busybox:latest
name: busy
imagePullPolicy: IfNotPresent
env:
- name: os
value: "ubuntu"
- name: debug
value: "on"
command:
- /bin/echo
args:
- "$(os),$(debug)"

image指定使用镜像busybox:latest,imagePullPolicy拉取策略是IfNotPresent,然后定义了os和debug两个环境变量,command启动命令是/bin/echo,参数中输出刚才定义的环境变量

使用kubectl操作Pod

一系列操作Pod的kubectl命令

创建、删除和输出

applydelete可以创建和删除Pod,使用-f指定YAML文件,也可以直接使用YAML用name字段定义的名称,Kubernetes的Pod在后台运行,所以看不到输出信息,可以使用logs来展示Pod的标准输出信息

$ minikube kubectl -- apply -f busy-pod.yml
$ minikube kubectl -- delete -f busy-pod.yml
$ minikube kubectl -- delete pod busy-pod # 指定名字删除

使用logs会将Pod的标准输出信息流展示,展示了command中写入的echo命令的输出:

$ minikube kubectl -- logs busy-pod
ubuntu,on

检查状态

使用get pod可以查看Pod列表和运行状态:

$ minikube kubectl -- get pod
NAME READY STATUS RESTARTS AGE
busy-pod 0/1 CrashLoopBackOff 3 (31s ago) 71s
ngx 1/1 Running 3 (43m ago) 47h

这个busy-pod节点运行的状态是CrashLoopBackOff,可以使用describe来检查它的详细状态:

 minikube kubectl -- describe pod busy-pod
Name: busy-pod
Namespace: default
Priority: 0
Node: minikube/192.168.59.100
Start Time: Sun, 24 Jul 2022 21:11:30 +0800
Labels: env=demo
owner=test
region=north
tier=back
Annotations: <none>
Status: Running
IP: 172.17.0.6
IPs:
IP: 172.17.0.6
....
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal Scheduled 6m47s default-scheduler Successfully assigned default/busy-pod to minikube
Normal Pulled 5m25s (x5 over 6m46s) kubelet Container image "busybox:latest" already present on machine
Normal Created 5m25s (x5 over 6m46s) kubelet Created container busy
Normal Started 5m25s (x5 over 6m46s) kubelet Started container busy
Warning BackOff 105s (x25 over 6m44s) kubelet Back-off restarting failed container

在末尾的Events部分,显示的是Pod运行过程中的一些关键节点事件,对于这个busy-pod,因为只执行了一条echo命令则退出,而Kubernetes默认重启Pod,所以就会进入一个反复启动停止的状态

交互

cp命令可以将文件拷贝进Pod中,如下将test.txt拷贝进Pod的tmp目录中:

$ echo 'aaa' > test.txt
$ minikube kubectl -- cp test.txt ngx:/tmp

也可以打开一个shell进行命令交互:

$ minikube kubectl -- exec -it ngx -- sh
/ # ls
bin etc mnt run tmp
dev home opt sbin usr
docker-entrypoint.d lib proc srv var
docker-entrypoint.sh media root sys

Kubernetes入门实践(Pods)的更多相关文章

  1. 微服务 + Docker + Kubernetes 入门实践 目录

    微服务 + Docker + Kubernetes 入门实践: 微服务概念 微服务的一些基本概念 环境准备 Ubuntu & Docker 本文主要讲解在 Ubuntu 上安装和配置 Dock ...

  2. kubernetes入门实践

    k8s中文文档 k8s概念比较多,有什么概念的疑惑的推荐看k8s中文文档. me的环境 操作系统:centos7 docker:1.12.6 环境跟me的不一致?不要慌,基本大部分操作都是行的通的. ...

  3. Kubernetes性能测试实践

    本文由  网易云 发布. 概述 随着容器技术的发展,容器服务已经成为行业主流,然而想要在生产环境中成功部署和操作容器,关键还是容器编排技术.市场上有各种各样的容器编排工具,如Docker原生的Swar ...

  4. kubernetes 入门学习

    kubernetes 学习 kubernetes 简介 Kubernetes这个名字源自希腊语,意思是"舵手",也是"管理者","治理者"等 ...

  5. 第一章 Kubernetes入门

    第一章 Kubernetes入门 kubernetes是基于容器技术的分布式架构领先方案,是一个完备的分布式系统支撑平台. kubernetes带来的好处:1)全面拥抱微服务:2)统可以随时随地整体“ ...

  6. Kubernetes入门(四)——如何在Kubernetes中部署一个可对外服务的Tensorflow机器学习模型

    机器学习模型常用Docker部署,而如何对Docker部署的模型进行管理呢?工业界的解决方案是使用Kubernetes来管理.编排容器.Kubernetes的理论知识不是本文讨论的重点,这里不再赘述, ...

  7. 分布式学习系列【dubbo入门实践】

    分布式学习系列[dubbo入门实践] dubbo架构 组成部分:provider,consumer,registry,monitor: provider,consumer注册,订阅类似于消息队列的注册 ...

  8. sass、less和stylus的安装使用和入门实践

    刚 开始的时候,说实话,我很反感使用css预处理器这种新玩意的,因为其中涉及到了编程的东西,私以为很复杂,而且考虑到项目不是一天能够完成的,也很少是 一个人完成的,对于这种团队的项目开发,前端实践用c ...

  9. Django入门实践(三)

    Django入门实践(三) Django简单应用 前面简单示例说明了views和Template的工作过程,但是Django最核心的是App,涉及到App则会和Model(数据库)打交道.下面举的例子 ...

  10. Django入门实践(二)

    Django入门实践(二) Django模板简单实例 上篇中将html写在了views中,这种混合方式(指Template和views混在一起)不适合大型开发,而且代码不易管理和维护,下面就用Djan ...

随机推荐

  1. 华为服务器修改ibmc账号密码、配置raid5、安装系统

    修改ibmc账号密码 转载自:https://www.cnblogs.com/mtactor/p/2288V5.html  昵称: mtactor 方法一:采用网线直连管理口 1.使用网线直接连接服务 ...

  2. Crypto入门 (六)幂数加密(云影密码)

    前言: 这次题目说的是幂数加密,但是它本身 幂数加密: 题目:8842101220480224404014224202480122 分析一波,只有8.4.2.1.0五种数字,然后先根据提示百度一下幂数 ...

  3. C++11:初始化列表

    在老版本的C++中,我们可以比较方便得对结构体.数组等对象利用{}进行初始化,而类变量的初始化则取决于构造函数的形式,例如: struct A { int a, b, c; }; class Foo ...

  4. Spring Framework学习总结

    一.Spring 概述 Spring 有两个核心部分: IoC 和 AOP. Spring 是一种基于 Bean 的编程技术,它深刻地改变着 Java 开发世界.Spring 使用简单.基本的 Jav ...

  5. 利用网络复制安装额外域控制器、利用介质安装额外域控制器、安装RODC额外域控制器

    一.拥有多台域控制器的优势 1.分担用户身份验证的负担,改善用户登录的效率 2.容错功能:若有域控制器故障,此时仍然可以有其他正常的域控制器来继续提供服务,因此对用户的服务并不会停止 二.系统提供两种 ...

  6. SQL 2019 卸载方法

    一.关闭服务 1.  win+r      services.msc   打开服务,关闭与SQL有关的服务内容. 二.卸载应用 1.win+r  control   打开控制面板---卸载程序---卸 ...

  7. React支持less操作

    React支持less操作 1.执行暴漏命令 npm run eject 2.输入" Y " 确认 这时候发现config文件夹没暴漏出来,是因为git没有暂存,得执行如下命令: ...

  8. asyncio基础用法

    说明:需要Python 3.7+ 1.并发运行两个coroutine,写法一: 用Task import asyncio import time async def say_after(delay, ...

  9. win8 改win7 最全教程(包含可能遇到的所有问题)

    今日,帮一个朋友的把她的系统从win8 优雅降级到了win7,大家都知道win8改win7 不好改啊.......话不多,上本人的总结的教程. 首先 ,win8改win7 需要对系统格盘,这里的原因我 ...

  10. Windows下安装mysql的操作步骤

    免安装版的Mysql MySQL关是一种关系数据库管理系统,所使用的 SQL 语言是用于访问数据库的最常用的 标准化语言,其特点为体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,在 Web 应 ...