Delete pods from registry in CNI daemon
Initial implementation of kuryr-daemon was only adding new pods to the in-memory registry and not deleting them. While the amount of data is tiny, it will accumulate over time and in practice be a memory leak. We should aim to prevent that, especially taking into account most recent efforts to base health checks on memory usage. This commit makes kuryr-daemon react to pod deletions with removals of pods from the in-memory registry. Change-Id: I45babc325b7a727d6a973717f6653a40503ad991 Closes-Bug: 1750394
This commit is contained in:
parent
519391fac0
commit
89a8bd08b5
@ -256,7 +256,8 @@ class CNIDaemonWatcherService(cotyledon.Service):
|
|||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
self.pipeline = h_cni.CNIPipeline()
|
self.pipeline = h_cni.CNIPipeline()
|
||||||
self.pipeline.register(h_cni.CallbackHandler(self.on_done))
|
self.pipeline.register(h_cni.CallbackHandler(self.on_done,
|
||||||
|
self.on_deleted))
|
||||||
self.watcher = k_watcher.Watcher(self.pipeline)
|
self.watcher = k_watcher.Watcher(self.pipeline)
|
||||||
self.watcher.add(
|
self.watcher.add(
|
||||||
"%(base)s/pods?fieldSelector=spec.nodeName=%(node_name)s" % {
|
"%(base)s/pods?fieldSelector=spec.nodeName=%(node_name)s" % {
|
||||||
@ -283,6 +284,18 @@ class CNIDaemonWatcherService(cotyledon.Service):
|
|||||||
pod_dict['vif'] = vif_dict
|
pod_dict['vif'] = vif_dict
|
||||||
self.registry[pod_name] = pod_dict
|
self.registry[pod_name] = pod_dict
|
||||||
|
|
||||||
|
def on_deleted(self, pod):
|
||||||
|
pod_name = pod['metadata']['name']
|
||||||
|
try:
|
||||||
|
if pod_name in self.registry:
|
||||||
|
# NOTE(dulek): del on dict is atomic as long as we use standard
|
||||||
|
# types as keys. This is the case, so we don't
|
||||||
|
# need to lock here.
|
||||||
|
del self.registry[pod_name]
|
||||||
|
except KeyError:
|
||||||
|
# This means someone else removed it. It's odd but safe to ignore.
|
||||||
|
pass
|
||||||
|
|
||||||
def terminate(self):
|
def terminate(self):
|
||||||
if self.watcher:
|
if self.watcher:
|
||||||
self.watcher.stop()
|
self.watcher.stop()
|
||||||
|
@ -92,12 +92,18 @@ class DelHandler(CNIHandlerBase):
|
|||||||
|
|
||||||
class CallbackHandler(CNIHandlerBase):
|
class CallbackHandler(CNIHandlerBase):
|
||||||
|
|
||||||
def __init__(self, on_vif):
|
def __init__(self, on_vif, on_del=None):
|
||||||
super(CallbackHandler, self).__init__(None, on_vif)
|
super(CallbackHandler, self).__init__(None, on_vif)
|
||||||
|
self._del_callback = on_del
|
||||||
|
|
||||||
def on_vif(self, pod, vif):
|
def on_vif(self, pod, vif):
|
||||||
self._callback(pod, vif)
|
self._callback(pod, vif)
|
||||||
|
|
||||||
|
def on_deleted(self, pod):
|
||||||
|
LOG.debug("Got pod %s deletion event.", pod['metadata']['name'])
|
||||||
|
if self._del_callback:
|
||||||
|
self._del_callback(pod)
|
||||||
|
|
||||||
|
|
||||||
class CNIPipeline(k_dis.EventPipeline):
|
class CNIPipeline(k_dis.EventPipeline):
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user