]> git.decadent.org.uk Git - dak.git/commitdiff
Provide a way to set Pg's work_mem from dak.
authorTorsten Werner <twerner@debian.org>
Fri, 25 Mar 2011 15:11:46 +0000 (16:11 +0100)
committerTorsten Werner <twerner@debian.org>
Fri, 25 Mar 2011 15:11:46 +0000 (16:11 +0100)
Signed-off-by: Torsten Werner <twerner@debian.org>
daklib/contents.py
daklib/dbconn.py

index f3077aab6487eede63f71341d01ede61fec16525..449fb88e126fdc13038c1fd512edf0631bfff060 100755 (executable)
@@ -285,7 +285,7 @@ def binary_helper(suite_id, arch_id, overridetype_id, component_id = None):
     This function is called in a new subprocess and multiprocessing wants a top
     level function.
     '''
-    session = DBConn().session()
+    session = DBConn().session(work_mem = 1000)
     suite = Suite.get(suite_id, session)
     architecture = Architecture.get(arch_id, session)
     overridetype = OverrideType.get(overridetype_id, session)
@@ -304,7 +304,7 @@ def source_helper(suite_id, component_id):
     This function is called in a new subprocess and multiprocessing wants a top
     level function.
     '''
-    session = DBConn().session()
+    session = DBConn().session(work_mem = 1000)
     suite = Suite.get(suite_id, session)
     component = Component.get(component_id, session)
     log_message = [suite.suite_name, 'source', component.component_name]
index ae5a9e0d21b6583712fcc5d7fd3578cb55479876..9c25f67014562c8b1453f08b2577b670e99978ba 100755 (executable)
@@ -3591,12 +3591,21 @@ class DBConn(object):
         self.__setupmappers()
         self.pid = os.getpid()
 
-    def session(self):
+    def session(self, work_mem = 0):
+        '''
+        Returns a new session object. If a work_mem parameter is provided a new
+        transaction is started and the work_mem parameter is set for this
+        transaction. The work_mem parameter is measured in MB. A default value
+        will be used if the parameter is not set.
+        '''
         # reinitialize DBConn in new processes
         if self.pid != os.getpid():
             clear_mappers()
             self.__createconn()
-        return self.db_smaker()
+        session = self.db_smaker()
+        if work_mem > 0:
+            session.execute("SET LOCAL work_mem TO '%d MB'" % work_mem)
+        return session
 
 __all__.append('DBConn')