如何在EKS中获取容器主机IP地址和容器名称

时间:2019-05-24 04:05:16

标签: docker kubernetes amazon-eks

我有一个docker文件,并使用该文件构建了映像,然后使用EKS服务启动了容器。现在,在用于记录目的的应用程序中,我将环境变量(例如“ container_instance”和“ ec2_instance_id”)记录下来,以便可以在Elastic Search中查看从哪个容器或主机ec2计算机生成此日志。

在环境变量中启动容器时,如何设置这两个数据?

1 个答案:

答案 0 :(得分:2)

在Kubernetes Pod规范中,您可以使用downward API注入一些此类信息。例如,要获取节点的Kubernetes节点名称,可以设置

env:
  - name: MY_NODE_NAME
    valueFrom:
      fieldRef:
        fieldPath: spec.nodeName

节点名称通常是该节点的主机名(例如this example in the EKS docs显示EC2内部主机名)。您无法轻松地在每个容器级别获得EC2实例ID之类的信息。

您还可以在群集级别全局配置日志记录。 Kubernetes文档包括a packaged setup to route logs to Elasticsearch and Kibana。此处显示的示例仅在日志消息元数据中包含pod名称,但是您应该能够重新配置基础fluentd以包括其他主机级元数据。