From: Sage Weil Date: Tue, 4 Sep 2018 16:25:54 +0000 (-0500) Subject: common/util: pass real hostname when running in kubernetes/rook container X-Git-Tag: v12.2.9~83^2~2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=daaa1d33c70ba7f2690c9ab095943f54234f29ff;p=ceph.git common/util: pass real hostname when running in kubernetes/rook container Rook will set up some environment variables to tell us what pod, pod namespace, and physical host we are running on. If we see them, set 'hostname' according to the hardware host, and include the pod info in our metadata. This allows the usual host-based logic on Ceph to work correctly, like placing OSDs automatically in the CRUSH map. Signed-off-by: Sage Weil (cherry picked from commit 44db75462495e8b0b7c4a368e55cffc91b8679d6) # Conflicts: # src/common/util.cc - conflict with APPLE special case in newer code --- diff --git a/src/common/util.cc b/src/common/util.cc index fb67d7ca109e..cf345954c113 100644 --- a/src/common/util.cc +++ b/src/common/util.cc @@ -137,6 +137,18 @@ void collect_sys_info(map *m, CephContext *cct) (*m)["arch"] = u.machine; } + // but wait, am i in a container? + if (const char *pod_name = getenv("POD_NAME")) { + (*m)["pod_name"] = pod_name; + if (const char *node_name = getenv("NODE_NAME")) { + (*m)["container_hostname"] = u.nodename; + (*m)["hostname"] = node_name; + } + } + if (const char *ns = getenv("POD_NAMESPACE")) { + (*m)["pod_namespace"] = ns; + } + // memory FILE *f = fopen(PROCPREFIX "/proc/meminfo", "r"); if (f) {