在Docker中,容器是最小的处理单元,增删改查的对象是容器,容器是一种虚拟化技术,容器之间是隔离的,隔离是基于Linux Namespace 实现的。而在Kubernetes中,Pod包含一个或者多个相关的容器,Pod可以认为是容器的一种延伸扩展,一个Pod也是一个隔离体,而Pod内部包含的一组容器又是共享的(包括PID、Network、IPC、UTS)除此之外,Pod中的容器可以访问共同的数据卷来实现文件系统的共享。
apiVersion: v1 # 指定api版本,此值必须在kubectl apiversion中 kind: Pod # 指定创建资源的角色/类型 metadata: # 资源的元数据/属性 name: web01-pod # 资源名字,在同一个namespace中必须唯一 labels: # 设定资源的标签 k8s-app: apache version: v1 kubernetes.io/cluster-service: "true" annotainons: # 自定义注解列表 - name: String # 自定义注解名字 spec: # specification of the resource content 指定该资源的内容 restartPolicy: Always # 表明该容器一直运行,默认k8s策略,在此容器退出后,会立即创建一个相同的容器 nodeSelector: # 节点选择 zone: node1 containers: - name: web01-pod # 容器的名字 image: web:apache # 容器使用的镜像地址 imagePullPolicy: Never # 容器启动时检查仓库的策略,Always每次都检查,Never从不检查(不管本地是否有),IfNotPresent,如果本地有就不检查,没有就拉取 command: ['sh'] # 启动容器的运行命令,将覆盖容器的Entrypoint,对应Dockefile中的ENTRYPOINT args: ["$(str)"] # 启动容器的命令参数,对应Dockerfile中的CMD参数 env: # 指定容器中的环境变量 - name: str # 变量的名字 value: "/etc/run.sh" # 变量的值 resources: # 资源管理 requests: # 容器运行时的最低资源需求 cpu: 0.1 # CPU资源(核数),最少值为0.001核(1m) memory: 32Mi # 内存资源 limits: # 资源限制 cpu: 0.5 memory: 32Mi ports: - containerPort: 80 # 容器开放对外的端口 name: httpd # 名称 protocol: TCP livenessProbe: # pod内容器健康检查的设置 httpGet: # 通过httpget检查健康,200-399之间的容器正常 path: / # URI地址 port: 80 #host: 127.0.0.1 # 主机地址 scheme: HTTP initialDelaySeconds: 180 # 表明第一次检测在容器启动后多次时间后开始 timeoutSeconds: 5 # 检测的超时时间 periodSeconds: 15 # 检查间隔时间 #方法2 #exec: 执行命令的发法进行监测,如果其退出码不为0,则认为容器正常 #command: #- cat #- /tmp/health #方法3 #tcpSocket: //通过tcpSocket检查健康 #port: number lifecycle: # 声明周期管理 postStart: # 容器创建之后,运行之前运行的任务 exec: command: - 'sh' - 'yum upgrade -y' preStop: # 容器关闭之前运行的任务 exec: command: ['service httpd stop'] volumeMounts: # 永久存储挂载 - name: volume # 挂载设备名字,与volumes[*].name 需要对应 mountPath: /data # 挂载到容器的某个路径下 readOnly: True volumes: # 定义一组挂载设备 - name: volume # 定义一个挂载设备的名字 #meptyDir:{} hostPath: path:/opt # 挂载设备类型为hostpath,路径为宿主下的/opt
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/128143.html
摘要:前言我们一起回顾上一篇文章平台的微服务架构和,一共通过构建了三个镜像数据库,部署前端页面的,和接口。最近阿里云产品春节大促销,我一时没忍住又买了一台服务器,打完折扣还是很贵。是一个非常稳定的,可移植的网络文件系统。 前言 我们一起回顾上一篇文章《Bees平台的微服务架构(1)docker和docker-compose》,一共通过Dockerfile构建了三个docker镜像:mysql...
摘要:简称,是在年发布的一个开源项目。网络要能够通信,必须部署网络,是其中一个可选方案。最常使用,可以管理多个副本,并确保按照期望的状态运行,底层调用。用于每个最多只运行一个副本的场景。 Kubernetes 简称 k8s,是 google 在 2014 年发布的一个开源项目。 Kubernetes 解决了哪些问题? 真实的生产环境应用会包含多个容器,而这些容器还很可能会跨越多个服务器主机部...
摘要:扩展性好当集群的资源严重不足而导致排队等待时,可以很容易的添加一个到集群中,从而实现扩展。用法,选择尽可能使用这个节点镜像,填写,这个容器镜像是我们的运行环境。更新文件,这里我们只是将中的镜像更换成最新构建出的镜像。基于Jenkins的CI/CD实践[TOC]一、概要提到K8S环境下的CI/CD,可以使用的工具有很多,比如Jenkins、Gitlab CI、新兴的drone等,考虑到大多公司...
摘要:基于年底或年初没有推广的现状,唯品会部门目前已经做了两年的时间。唯品会现状唯品会目前线上有一千多个域,每个域之间相互的依赖比较复杂,每次的部署发布困难。这是唯品会的架构,主要包含持续集成和持续部署。 数人云上海&深圳两地容器之Mesos/K8S/Swarm三国演义的嘉宾精彩实录第三更来啦。唯品会是数人云Meetup的老朋友,去年曾做过RPC服务框架和Mesos容器化的分享。本次分享中,...
阅读 1187·2023-02-24 11:21
阅读 1378·2023-02-24 10:55
阅读 2359·2023-02-24 10:47
阅读 3059·2023-02-24 10:44
阅读 791·2023-02-24 10:38
阅读 588·2022-12-25 19:44
阅读 733·2022-12-25 19:39
阅读 835·2022-12-25 19:36