summaryrefslogtreecommitdiffstats
path: root/meta-openstack/recipes-devtools/python/python-hp3parclient
diff options
context:
space:
mode:
authorAmy Fong <amy.fong@windriver.com>2014-03-28 15:58:45 -0400
committerBruce Ashfield <bruce.ashfield@windriver.com>2014-03-31 13:14:49 -0400
commit02f129b1bb1fc17f17b2fbca43bd997aa8b28d09 (patch)
treea125ec774f2054684ddd364aeb6caceb8c1bf637 /meta-openstack/recipes-devtools/python/python-hp3parclient
parent984c2d69f51824a4c1e7b3a448fe24759e594026 (diff)
downloadmeta-cloud-services-02f129b1bb1fc17f17b2fbca43bd997aa8b28d09.tar.gz
Memory leak from timings
Memory leak happens when the dynamic list times grows without anything to reset it. In ceilometer and cinder configuration files, the new option is created: [nova_client] max_timing_buffer=<value> In all clients found that uses extends the HTTPClient and uses the times list, we limit the size of the list by popping off the oldest item in the list to maintain a maximum size. A default size of 200 is chosen, configurable by the above configuration option. Signed-off-by: Amy Fong <amy.fong@windriver.com> Signed-off-by: Bruce Ashfield <bruce.ashfield@windriver.com>
Diffstat (limited to 'meta-openstack/recipes-devtools/python/python-hp3parclient')
-rw-r--r--meta-openstack/recipes-devtools/python/python-hp3parclient/fix_hp3parclient_memory_leak.patch37
1 files changed, 37 insertions, 0 deletions
diff --git a/meta-openstack/recipes-devtools/python/python-hp3parclient/fix_hp3parclient_memory_leak.patch b/meta-openstack/recipes-devtools/python/python-hp3parclient/fix_hp3parclient_memory_leak.patch
new file mode 100644
index 0000000..ac196fd
--- /dev/null
+++ b/meta-openstack/recipes-devtools/python/python-hp3parclient/fix_hp3parclient_memory_leak.patch
@@ -0,0 +1,37 @@
1---
2 hp3parclient/http.py | 10 ++++++++++
3 1 file changed, 10 insertions(+)
4
5--- a/hp3parclient/http.py
6+++ b/hp3parclient/http.py
7@@ -61,6 +61,7 @@
8 self.set_debug_flag(http_log_debug)
9
10 self.times = [] # [("item", starttime, endtime), ...]
11+ self.times_max_len = 200
12
13 # httplib2 overrides
14 self.force_exception_to_status_code = True
15@@ -141,6 +142,12 @@
16 """
17 self.times = []
18
19+ def get_timings_max_len(self):
20+ return self.times_max_len
21+
22+ def set_timings_max_len(self, new_len):
23+ self.times_max_len = new_len
24+
25 def _http_log_req(self, args, kwargs):
26 if not self.http_log_debug:
27 return
28@@ -205,6 +212,9 @@
29 resp, body = self.request(url, method, **kwargs)
30 self.times.append(("%s %s" % (method, url),
31 start_time, time.time()))
32+ # remove oldest items until we maintain max length
33+ while len(self.times) > self.times_max_len:
34+ del self.times[0]
35 return resp, body
36
37