我有一个docker文件,并使用该文件构建了映像,然后使用EKS服务启动了容器。现在,在用于记录目的的应用程序中,我将环境变量(例如“ container_instance”和“ ec2_instance_id”)记录下来,以便可以在Elastic Search中查看从哪个容器或主机ec2计算机生成此日志。
在环境变量中启动容器时,如何设置这两个数据?
答案 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以包括其他主机级元数据。