diff options
author | Michael Mair-Keimberger (asterix) <m.mairkeimberger@gmail.com> | 2017-02-07 17:43:42 +0100 |
---|---|---|
committer | David Seifert <soap@gentoo.org> | 2017-02-09 23:37:11 +0100 |
commit | 29e972873bc1172272482c7579ac1a0c2ffbad5a (patch) | |
tree | 00bd9679a4881a08ca2e48fe2d60e7fa670efc2b /sys-cluster | |
parent | sys-cluster/heat: remove unused patch (diff) | |
download | gentoo-29e972873bc1172272482c7579ac1a0c2ffbad5a.tar.gz gentoo-29e972873bc1172272482c7579ac1a0c2ffbad5a.tar.bz2 gentoo-29e972873bc1172272482c7579ac1a0c2ffbad5a.zip |
sys-cluster/swift: remove unused patch
Closes: https://github.com/gentoo/gentoo/pull/3870
Diffstat (limited to 'sys-cluster')
-rw-r--r-- | sys-cluster/swift/files/cve-2016-0738-stable-liberty.patch | 167 |
1 files changed, 0 insertions, 167 deletions
diff --git a/sys-cluster/swift/files/cve-2016-0738-stable-liberty.patch b/sys-cluster/swift/files/cve-2016-0738-stable-liberty.patch deleted file mode 100644 index 4d2ccbaa521b..000000000000 --- a/sys-cluster/swift/files/cve-2016-0738-stable-liberty.patch +++ /dev/null @@ -1,167 +0,0 @@ -From fc1376b356894f39dfab1e71c1fcb87a943461aa Mon Sep 17 00:00:00 2001 -From: Samuel Merritt <sam@swiftstack.com> -Date: Tue, 8 Dec 2015 16:36:05 -0800 -Subject: [PATCH] Fix memory/socket leak in proxy on truncated SLO/DLO GET - -When a client disconnected while consuming an SLO or DLO GET response, -the proxy would leak a socket. This could be observed via strace as a -socket that had shutdown() called on it, but was never closed. It -could also be observed by counting entries in /proc/<pid>/fd, where -<pid> is the pid of a proxy server worker process. - -This is due to a memory leak in SegmentedIterable. A SegmentedIterable -has an 'app_iter' attribute, which is a generator. That generator -references 'self' (the SegmentedIterable object). This creates a -cyclic reference: the generator refers to the SegmentedIterable, and -the SegmentedIterable refers to the generator. - -Python can normally handle cyclic garbage; reference counting won't -reclaim it, but the garbage collector will. However, objects with -finalizers will stop the garbage collector from collecting them* and -the cycle of which they are part. - -For most objects, "has finalizer" is synonymous with "has a __del__ -method". However, a generator has a finalizer once it's started -running and before it finishes: basically, while it has stack frames -associated with it**. - -When a client disconnects mid-stream, we get a memory leak. We have -our SegmentedIterable object (call it "si"), and its associated -generator. si.app_iter is the generator, and the generator closes over -si, so we have a cycle; and the generator has started but not yet -finished, so the generator needs finalization; hence, the garbage -collector won't ever clean it up. - -The socket leak comes in because the generator *also* refers to the -request's WSGI environment, which contains wsgi.input, which -ultimately refers to a _socket object from the standard -library. Python's _socket objects only close their underlying file -descriptor when their reference counts fall to 0***. - -This commit makes SegmentedIterable.close() call -self.app_iter.close(), thereby unwinding its generator's stack and -making it eligible for garbage collection. - -* in Python < 3.4, at least. See PEP 442. - -** see PyGen_NeedsFinalizing() in Objects/genobject.c and also - has_finalizer() in Modules/gcmodule.c in Python. - -*** see sock_dealloc() in Modules/socketmodule.c in Python. See - sock_close() in the same file for the other half of the sad story. - -Change-Id: I74ea49eaa7d5c372cdc2399148d5495d3007dbd0 -Co-Authored-By: Kota Tsuyuzaki <tsuyuzaki.kota@lab.ntt.co.jp> ---- - swift/common/request_helpers.py | 6 ++- - test/unit/common/middleware/test_slo.py | 65 ++++++++++++++++++++++++++++++++- - 2 files changed, 68 insertions(+), 3 deletions(-) - -diff --git a/swift/common/request_helpers.py b/swift/common/request_helpers.py -index a533087..922240a 100644 ---- a/swift/common/request_helpers.py -+++ b/swift/common/request_helpers.py -@@ -435,6 +435,9 @@ class SegmentedIterable(object): - self.logger.exception(_('ERROR: An error occurred ' - 'while retrieving segments')) - raise -+ finally: -+ if self.current_resp: -+ close_if_possible(self.current_resp.app_iter) - - def app_iter_range(self, *a, **kw): - """ -@@ -477,5 +480,4 @@ class SegmentedIterable(object): - Called when the client disconnect. Ensure that the connection to the - backend server is closed. - """ -- if self.current_resp: -- close_if_possible(self.current_resp.app_iter) -+ close_if_possible(self.app_iter) -diff --git a/test/unit/common/middleware/test_slo.py b/test/unit/common/middleware/test_slo.py -index b131240..ee0ce0f 100644 ---- a/test/unit/common/middleware/test_slo.py -+++ b/test/unit/common/middleware/test_slo.py -@@ -26,7 +26,8 @@ from swift.common import swob, utils - from swift.common.exceptions import ListingIterError, SegmentError - from swift.common.middleware import slo - from swift.common.swob import Request, Response, HTTPException --from swift.common.utils import quote, json, closing_if_possible -+from swift.common.utils import quote, json, closing_if_possible, \ -+ close_if_possible - from test.unit.common.middleware.helpers import FakeSwift - - -@@ -1765,6 +1766,68 @@ class TestSloGetManifest(SloTestCase): - self.assertEqual(headers['X-Object-Meta-Fish'], 'Bass') - self.assertEqual(body, '') - -+ def test_generator_closure(self): -+ # Test that the SLO WSGI iterable closes its internal .app_iter when -+ # it receives a close() message. -+ # -+ # This is sufficient to fix a memory leak. The memory leak arises -+ # due to cyclic references involving a running generator; a running -+ # generator sometimes preventes the GC from collecting it in the -+ # same way that an object with a defined __del__ does. -+ # -+ # There are other ways to break the cycle and fix the memory leak as -+ # well; calling .close() on the generator is sufficient, but not -+ # necessary. However, having this test is better than nothing for -+ # preventing regressions. -+ leaks = [0] -+ -+ class LeakTracker(object): -+ def __init__(self, inner_iter): -+ leaks[0] += 1 -+ self.inner_iter = iter(inner_iter) -+ -+ def __iter__(self): -+ return self -+ -+ def next(self): -+ return next(self.inner_iter) -+ -+ def close(self): -+ leaks[0] -= 1 -+ close_if_possible(self.inner_iter) -+ -+ class LeakTrackingSegmentedIterable(slo.SegmentedIterable): -+ def _internal_iter(self, *a, **kw): -+ it = super( -+ LeakTrackingSegmentedIterable, self)._internal_iter( -+ *a, **kw) -+ return LeakTracker(it) -+ -+ status = [None] -+ headers = [None] -+ -+ def start_response(s, h, ei=None): -+ status[0] = s -+ headers[0] = h -+ -+ req = Request.blank( -+ '/v1/AUTH_test/gettest/manifest-abcd', -+ environ={'REQUEST_METHOD': 'GET', -+ 'HTTP_ACCEPT': 'application/json'}) -+ -+ # can't self.call_slo() here since we don't want to consume the -+ # whole body -+ with patch.object(slo, 'SegmentedIterable', -+ LeakTrackingSegmentedIterable): -+ app_resp = self.slo(req.environ, start_response) -+ self.assertEqual(status[0], '200 OK') # sanity check -+ body_iter = iter(app_resp) -+ chunk = next(body_iter) -+ self.assertEqual(chunk, 'aaaaa') # sanity check -+ -+ app_resp.close() -+ self.assertEqual(0, leaks[0]) -+ - def test_head_manifest_is_efficient(self): - req = Request.blank( - '/v1/AUTH_test/gettest/manifest-abcd', --- -2.7.0 - - |