• 博客访问: 806947
  • 博文数量: 239
  • 用 户 组: 普通用户
  • 注册时间: 2013-02-05 14:37
  • 认证徽章:
个人简介

走路 行心 修缘(需要交流的请加我的QQ 273936024)

文章分类

全部博文(239)

文章存档

2018年(49)

2017年(63)

2016年(39)

2015年(20)

2014年(29)

2013年(39)

分类: Docker/K8

2018-05-13 14:09:14

一:前言
在某些集群中,集群中的每个节点都需要将自身的标识(ID)及进程绑定的IP等信息事先写入配置文件中,进程启动时读取这些信息,然后发布到某个类似服务注册中心的地方,以实现集群节点的自动发现功能。

此时可以使用Downward API,具体做法是先编写一个预启动脚本或Init Container,通过环境变量或文件方式获取Pod自身的名称,IP地址等信息,然后写入主程序的配置文件中,最后启动主程序。

二:实现方式
Downward API 可以通过以下两种方式将Pod信息注入容器内部。
1.环境变量:用于单个变量,可以将Pod信息和Container信息注入容器内部。
2.Volume挂载: 将数组类信息生成文件,挂载到容器内部。

三: 实例
环境变量方式,将Pod信息注入为环境变量 dapi-test-pod.yaml

点击(此处)折叠或打开

  1. apiVersion: v1
  2. kind: Pod
  3. metadata:
  4.   name: dapi-test-pod
  5.   namespace: default
  6. spec:
  7.   containers:
  8.      - name: test-container
  9.        image: busybox
  10.        command: [ "/bin/sh","-c","env" ]
  11.        env:
  12.           - name: MY_POD_NAME
  13.             valueFrom:
  14.                fieldRef:
  15.                  fieldPath: metadata.name
  16.           - name: MY_POD_NAMESPACE
  17.             valueFrom:
  18.                fieldRef:
  19.                  fieldPath: metadata.namespace
  20.           - name: MY_POD_NAMES
  21.             valueFrom:
  22.                fieldRef:
  23.                  fieldPath: status.podIP
kubectl create -f dapi-test-pod.yaml

kubectl logs dapi-test-pod


阅读(79) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
请登录后评论。

登录 注册