-
Notifications
You must be signed in to change notification settings - Fork 712
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
no connections between containers when probe.processes=false
#2586
Comments
Possible fixes:
In either case we need to be mindful of the fact that pods typically have two containers - a pause container and the "real" container - which would trip over our "if two containers have the same IP we can't use that IP for determining connectivity" logic. So we'd have to special-case the pause container, perhaps, e.g. only associate IPs with that or filter it out. And obviously if a pod has more than one "real" container then all bets are off. |
This issue won't manifest in some pod networks, e.g.
|
@rade, additionally with |
That is already happening; probes annotate pause containers with |
In #2943 (comment) @bboreham suggested that the probes could obtain container IPs in a similar fashion how they determine weave IPs. If we can get that to work it would become less debilitating for users to disable process tracking in the interest of performance. |
|
That raises the question of how to know You could simplify to just report any IP address in any namespace, without checking what bridge it belongs to. |
Although #3207 enables some connections to be shown, lots are not. Believed to include: containers in host namespace. |
The problem with host netns connections is that we cannot tie them to a container based on IP. Instead we use the pid. Specifically, we tag nodes in the process topology with a container node id based on looking up the pid in a pid->container map produced by the docker reporter. Crucially this also deals with situations where the process is a child of the primary container pid. We could instead associate a set of pids with a container - the primary pid an all its children (recursively) - and in the renderer use that info to associate connections - which do carry pids - with containers. This does still require some proc walking, to find the child pids. |
In a kubernetes cluster, containers do not have an associated IP address, as far as docker is concerned. We rely purely on connection tracking at the process level to determine connectivity for containers, so when such tracking is disabled with
probe.processes=false
, no container connections are show, which is unfortunate and surprising.Note that we do track pod IPs and use those to figure out connections at the pod level.
NB: this is all based on my reading of the code and some scope reports from a k8s cluster. TODO: verify by running probes in such a cluster with
probe.processes=false
.The text was updated successfully, but these errors were encountered: