From c27da7bb9d3f47e6ab9772133a38265646162e3e Mon Sep 17 00:00:00 2001 From: Michael Barton Date: Wed, 13 Oct 2010 21:26:43 +0000 Subject: [PATCH 1/3] Change chunks_per_sync config to mb_per_sync --- etc/object-server.conf-sample | 1 + swift/obj/server.py | 13 +++++-------- test/unit/obj/test_server.py | 2 +- 3 files changed, 7 insertions(+), 9 deletions(-) diff --git a/etc/object-server.conf-sample b/etc/object-server.conf-sample index a72ef879d7..6465332fb8 100644 --- a/etc/object-server.conf-sample +++ b/etc/object-server.conf-sample @@ -20,6 +20,7 @@ use = egg:swift#object # conn_timeout = 0.5 # network_chunk_size = 65536 # disk_chunk_size = 65536 +# mb_per_sync = 512 # max_upload_time = 86400 # slow = 1 diff --git a/swift/obj/server.py b/swift/obj/server.py index fe26eebf20..4e7b52d2b9 100644 --- a/swift/obj/server.py +++ b/swift/obj/server.py @@ -259,7 +259,7 @@ class ObjectController(object): self.log_requests = conf.get('log_requests', 't')[:1].lower() == 't' self.max_upload_time = int(conf.get('max_upload_time', 86400)) self.slow = int(conf.get('slow', 0)) - self.chunks_per_sync = int(conf.get('chunks_per_sync', 8000)) + self.bytes_per_sync = int(conf.get('mb_per_sync', 512) * 1024 * 1024) def container_update(self, op, account, container, obj, headers_in, headers_out, objdevice): @@ -359,11 +359,10 @@ class ObjectController(object): upload_expiration = time.time() + self.max_upload_time etag = md5() upload_size = 0 + last_sync = 0 with file.mkstemp() as (fd, tmppath): if 'content-length' in request.headers: fallocate(fd, int(request.headers['content-length'])) - chunk_count = 0 - dropped_cache = 0 for chunk in iter(lambda: request.body_file.read( self.network_chunk_size), ''): upload_size += len(chunk) @@ -373,13 +372,11 @@ class ObjectController(object): while chunk: written = os.write(fd, chunk) chunk = chunk[written:] - chunk_count += 1 # For large files sync every 512MB (by default) written - if chunk_count % self.chunks_per_sync == 0: + if upload_size - last_sync >= self.bytes_per_sync: os.fdatasync(fd) - drop_buffer_cache(fd, dropped_cache, - upload_size - dropped_cache) - dropped_cache = upload_size + drop_buffer_cache(fd, last_sync, upload_size - last_sync) + last_sync = upload_size if 'content-length' in request.headers and \ int(request.headers['content-length']) != upload_size: diff --git a/test/unit/obj/test_server.py b/test/unit/obj/test_server.py index 048b409c63..94a3b28266 100644 --- a/test/unit/obj/test_server.py +++ b/test/unit/obj/test_server.py @@ -56,7 +56,7 @@ class TestObjectController(unittest.TestCase): mkdirs(os.path.join(self.testdir, 'sda1', 'tmp')) conf = {'devices': self.testdir, 'mount_check': 'false'} self.object_controller = object_server.ObjectController(conf) - self.object_controller.chunks_per_sync = 1 + self.object_controller.bytes_per_sync = 1 def tearDown(self): """ Tear down for testing swift.object_server.ObjectController """ From 9d49aedf0e74a17764ff39528db58245aa935f07 Mon Sep 17 00:00:00 2001 From: Michael Barton Date: Wed, 13 Oct 2010 21:29:58 +0000 Subject: [PATCH 2/3] sample conf update --- etc/object-server.conf-sample | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/etc/object-server.conf-sample b/etc/object-server.conf-sample index 6465332fb8..19344bcdc2 100644 --- a/etc/object-server.conf-sample +++ b/etc/object-server.conf-sample @@ -20,9 +20,10 @@ use = egg:swift#object # conn_timeout = 0.5 # network_chunk_size = 65536 # disk_chunk_size = 65536 -# mb_per_sync = 512 # max_upload_time = 86400 # slow = 1 +# on PUTs, sync data every n MB +# mb_per_sync = 512 [object-replicator] # log_name = object-replicator From 76ce08f8b2a4fe14ec4a8b94874daf8d42a3ec8c Mon Sep 17 00:00:00 2001 From: Michael Barton Date: Fri, 15 Oct 2010 19:15:43 +0000 Subject: [PATCH 3/3] move a paren --- swift/obj/server.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/swift/obj/server.py b/swift/obj/server.py index 4e7b52d2b9..6a15aef35d 100644 --- a/swift/obj/server.py +++ b/swift/obj/server.py @@ -259,7 +259,7 @@ class ObjectController(object): self.log_requests = conf.get('log_requests', 't')[:1].lower() == 't' self.max_upload_time = int(conf.get('max_upload_time', 86400)) self.slow = int(conf.get('slow', 0)) - self.bytes_per_sync = int(conf.get('mb_per_sync', 512) * 1024 * 1024) + self.bytes_per_sync = int(conf.get('mb_per_sync', 512)) * 1024 * 1024 def container_update(self, op, account, container, obj, headers_in, headers_out, objdevice):