file_manager: process copy requests in another thread
The copy methods are blocking and will block the asyncio event loop. Run them in a ThreadPoolExecutor to keep the event loop free. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
43fcca5ffa
commit
93fcd1ae86
|
@ -9,6 +9,7 @@ import shutil
|
||||||
import logging
|
import logging
|
||||||
import json
|
import json
|
||||||
import tempfile
|
import tempfile
|
||||||
|
from concurrent.futures import ThreadPoolExecutor
|
||||||
from tornado.ioloop import IOLoop
|
from tornado.ioloop import IOLoop
|
||||||
from tornado.locks import Event
|
from tornado.locks import Event
|
||||||
from inotify_simple import INotify
|
from inotify_simple import INotify
|
||||||
|
@ -263,6 +264,13 @@ class FileManager:
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
raise self.server.error(str(e))
|
raise self.server.error(str(e))
|
||||||
elif ep == "/server/files/copy":
|
elif ep == "/server/files/copy":
|
||||||
|
ioloop = IOLoop.current()
|
||||||
|
with ThreadPoolExecutor(max_workers=1) as tpe:
|
||||||
|
await ioloop.run_in_executor(
|
||||||
|
tpe, self._do_copy, source_path, dest_path)
|
||||||
|
return "ok"
|
||||||
|
|
||||||
|
def _do_copy(self, source_path, dest_path):
|
||||||
try:
|
try:
|
||||||
if os.path.isdir(source_path):
|
if os.path.isdir(source_path):
|
||||||
shutil.copytree(source_path, dest_path)
|
shutil.copytree(source_path, dest_path)
|
||||||
|
@ -270,7 +278,6 @@ class FileManager:
|
||||||
shutil.copy2(source_path, dest_path)
|
shutil.copy2(source_path, dest_path)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
raise self.server.error(str(e))
|
raise self.server.error(str(e))
|
||||||
return "ok"
|
|
||||||
|
|
||||||
def _list_directory(self, path, is_extended=False):
|
def _list_directory(self, path, is_extended=False):
|
||||||
if not os.path.isdir(path):
|
if not os.path.isdir(path):
|
||||||
|
|
Loading…
Reference in New Issue