pool isolation
This commit is contained in:
		
							parent
							
								
									46d585c762
								
							
						
					
					
						commit
						da8db42dae
					
				@ -102,7 +102,6 @@ class TransactionRequest(Request):
 | 
				
			|||||||
class DbConnection:
 | 
					class DbConnection:
 | 
				
			||||||
    __mmdb: dict
 | 
					    __mmdb: dict
 | 
				
			||||||
    __loop: asyncio.AbstractEventLoop
 | 
					    __loop: asyncio.AbstractEventLoop
 | 
				
			||||||
    __pool: concurrent.futures.Executor
 | 
					 | 
				
			||||||
    __queue: asyncio.Queue[Request]
 | 
					    __queue: asyncio.Queue[Request]
 | 
				
			||||||
    __file: IO[str]
 | 
					    __file: IO[str]
 | 
				
			||||||
    __buffer: StringIO
 | 
					    __buffer: StringIO
 | 
				
			||||||
@ -181,7 +180,7 @@ class DbConnection:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    async def _dump_compressed_buffer(self):
 | 
					    async def _dump_compressed_buffer(self):
 | 
				
			||||||
        buffer = self._compress_buffer()
 | 
					        buffer = self._compress_buffer()
 | 
				
			||||||
        await self.__loop.run_in_executor(self.__pool, self.__file.write, buffer.getvalue())
 | 
					        await self.__loop.run_in_executor(None, self.__file.write, buffer.getvalue())
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    async def _do_dump_buffer(self):
 | 
					    async def _do_dump_buffer(self):
 | 
				
			||||||
        await self._dump_compressed_buffer()
 | 
					        await self._dump_compressed_buffer()
 | 
				
			||||||
@ -198,7 +197,7 @@ class DbConnection:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    async def _save_error(self, line: str):
 | 
					    async def _save_error(self, line: str):
 | 
				
			||||||
        with open(self.__path_error, 'a') as file:
 | 
					        with open(self.__path_error, 'a') as file:
 | 
				
			||||||
            await self.__loop.run_in_executor(self.__pool, file.write, line.strip() + '\n')
 | 
					            await self.__loop.run_in_executor(None, file.write, line.strip() + '\n')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    async def _handle_request(self, request: Request):
 | 
					    async def _handle_request(self, request: Request):
 | 
				
			||||||
        if isinstance(request, self.factory.kvrequest_type):
 | 
					        if isinstance(request, self.factory.kvrequest_type):
 | 
				
			||||||
@ -227,13 +226,14 @@ class DbConnection:
 | 
				
			|||||||
            await self._background_cycle()
 | 
					            await self._background_cycle()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    async def _finish_recovery(self):
 | 
					    async def _finish_recovery(self):
 | 
				
			||||||
        await self.__loop.run_in_executor(self.__pool, shutil.copy, self.__path_backup, self.__path)
 | 
					        with concurrent.futures.ThreadPoolExecutor() as pool:
 | 
				
			||||||
 | 
					            await self.__loop.run_in_executor(pool, shutil.copy, self.__path_backup, self.__path)
 | 
				
			||||||
        self.__path_recover.unlink()
 | 
					        self.__path_recover.unlink()
 | 
				
			||||||
        self.__path_backup.unlink()
 | 
					        self.__path_backup.unlink()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    async def _build_file(self, db: dict):
 | 
					    async def _build_file(self, db: dict):
 | 
				
			||||||
        with open(self.__path_backup, "w") as file:
 | 
					        with open(self.__path_backup, "w") as file, concurrent.futures.ThreadPoolExecutor() as pool:
 | 
				
			||||||
            self.__initial_size = await self.__loop.run_in_executor(self.__pool, self.db2io, db, file)
 | 
					            self.__initial_size = await self.__loop.run_in_executor(pool, self.db2io, db, file)
 | 
				
			||||||
        self.__path_recover.touch()
 | 
					        self.__path_recover.touch()
 | 
				
			||||||
        await self._finish_recovery()
 | 
					        await self._finish_recovery()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -242,7 +242,7 @@ class DbConnection:
 | 
				
			|||||||
            await self._finish_recovery()
 | 
					            await self._finish_recovery()
 | 
				
			||||||
        self.__path.touch()
 | 
					        self.__path.touch()
 | 
				
			||||||
        with open(self.__path) as file:
 | 
					        with open(self.__path) as file:
 | 
				
			||||||
            await self.__loop.run_in_executor(self.__pool, self.io2db, file, db)
 | 
					            await self.__loop.run_in_executor(None, self.io2db, file, db)
 | 
				
			||||||
        await self._build_file(db)
 | 
					        await self._build_file(db)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    async def _reload(self):
 | 
					    async def _reload(self):
 | 
				
			||||||
@ -268,7 +268,6 @@ class DbConnection:
 | 
				
			|||||||
    async def _initialize(self):
 | 
					    async def _initialize(self):
 | 
				
			||||||
        assert self.not_running
 | 
					        assert self.not_running
 | 
				
			||||||
        self.__loop = asyncio.get_event_loop()
 | 
					        self.__loop = asyncio.get_event_loop()
 | 
				
			||||||
        self.__pool = concurrent.futures.ThreadPoolExecutor()
 | 
					 | 
				
			||||||
        await self._initialize_queue()
 | 
					        await self._initialize_queue()
 | 
				
			||||||
        await self._initialize_mmdb()
 | 
					        await self._initialize_mmdb()
 | 
				
			||||||
        await self._start_task()
 | 
					        await self._start_task()
 | 
				
			||||||
@ -286,14 +285,10 @@ class DbConnection:
 | 
				
			|||||||
            self.__task.cancel()
 | 
					            self.__task.cancel()
 | 
				
			||||||
        await self._dump_buffer()
 | 
					        await self._dump_buffer()
 | 
				
			||||||
        self.__file.close()
 | 
					        self.__file.close()
 | 
				
			||||||
        self.__pool.shutdown()
 | 
					 | 
				
			||||||
        self.__pool = concurrent.futures.ThreadPoolExecutor()
 | 
					 | 
				
			||||||
        await self._build_file(self.__mmdb)
 | 
					        await self._build_file(self.__mmdb)
 | 
				
			||||||
        self.not_running = True
 | 
					        self.not_running = True
 | 
				
			||||||
        self.__pool.shutdown()
 | 
					 | 
				
			||||||
        del self.__mmdb
 | 
					        del self.__mmdb
 | 
				
			||||||
        del self.__loop
 | 
					        del self.__loop
 | 
				
			||||||
        del self.__pool
 | 
					 | 
				
			||||||
        del self.__queue
 | 
					        del self.__queue
 | 
				
			||||||
        del self.__file
 | 
					        del self.__file
 | 
				
			||||||
        del self.__buffer
 | 
					        del self.__buffer
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user