mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Adds configuration variable to the inotify debounce timing
This commit is contained in:
parent
c7412deb77
commit
f07cfd4f51
@ -590,6 +590,14 @@ PAPERLESS_CONSUMER_POLLING=<num>
|
|||||||
|
|
||||||
Defaults to 0, which disables polling and uses filesystem notifications.
|
Defaults to 0, which disables polling and uses filesystem notifications.
|
||||||
|
|
||||||
|
PAPERLESS_CONSUMER_INOTIFY_DELAY=<num>
|
||||||
|
Sets the time in seconds the consumer will wait for additional events
|
||||||
|
from inotify before the consumer will consider a file ready and begin consumption.
|
||||||
|
Certain scanners or network setups may generate multiple events for a single file,
|
||||||
|
leading to multiple consumers working on the same file. Configure this to
|
||||||
|
prevent that.
|
||||||
|
|
||||||
|
Defaults to 0.5 seconds.
|
||||||
|
|
||||||
PAPERLESS_CONSUMER_DELETE_DUPLICATES=<bool>
|
PAPERLESS_CONSUMER_DELETE_DUPLICATES=<bool>
|
||||||
When the consumer detects a duplicate document, it will not touch the
|
When the consumer detects a duplicate document, it will not touch the
|
||||||
|
@ -216,7 +216,7 @@ class Command(BaseCommand):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
||||||
inotify_debounce: Final[float] = 0.5
|
inotify_debounce: Final[float] = settings.CONSUMER_INOTIFY_DELAY
|
||||||
notified_files = {}
|
notified_files = {}
|
||||||
|
|
||||||
while not self.stop_flag:
|
while not self.stop_flag:
|
||||||
@ -234,10 +234,23 @@ class Command(BaseCommand):
|
|||||||
for filepath in notified_files:
|
for filepath in notified_files:
|
||||||
# Time of the last inotify event for this file
|
# Time of the last inotify event for this file
|
||||||
last_event_time = notified_files[filepath]
|
last_event_time = notified_files[filepath]
|
||||||
if (monotonic() - last_event_time) > inotify_debounce:
|
|
||||||
|
# Current time - last time over the configured timeout
|
||||||
|
waited_long_enough = (
|
||||||
|
monotonic() - last_event_time
|
||||||
|
) > inotify_debounce
|
||||||
|
|
||||||
|
# Also make sure the file exists still, some scanners might write a
|
||||||
|
# temporary file first
|
||||||
|
file_still_exists = os.path.exists(filepath) and os.path.isfile(
|
||||||
|
filepath,
|
||||||
|
)
|
||||||
|
|
||||||
|
if waited_long_enough and file_still_exists:
|
||||||
_consume(filepath)
|
_consume(filepath)
|
||||||
else:
|
elif file_still_exists:
|
||||||
still_waiting[filepath] = last_event_time
|
still_waiting[filepath] = last_event_time
|
||||||
|
|
||||||
# These files are still waiting to hit the timeout
|
# These files are still waiting to hit the timeout
|
||||||
notified_files = still_waiting
|
notified_files = still_waiting
|
||||||
|
|
||||||
|
@ -98,6 +98,9 @@ class ConsumerMixin:
|
|||||||
print("file completed.")
|
print("file completed.")
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(
|
||||||
|
CONSUMER_INOTIFY_DELAY=0.01,
|
||||||
|
)
|
||||||
class TestConsumer(DirectoriesMixin, ConsumerMixin, TransactionTestCase):
|
class TestConsumer(DirectoriesMixin, ConsumerMixin, TransactionTestCase):
|
||||||
def test_consume_file(self):
|
def test_consume_file(self):
|
||||||
self.t_start()
|
self.t_start()
|
||||||
@ -286,7 +289,7 @@ class TestConsumerPolling(TestConsumer):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
@override_settings(CONSUMER_RECURSIVE=True)
|
@override_settings(CONSUMER_INOTIFY_DELAY=0.01, CONSUMER_RECURSIVE=True)
|
||||||
class TestConsumerRecursive(TestConsumer):
|
class TestConsumerRecursive(TestConsumer):
|
||||||
# just do all the tests with recursive
|
# just do all the tests with recursive
|
||||||
pass
|
pass
|
||||||
|
@ -48,6 +48,13 @@ def __get_int(key: str, default: int) -> int:
|
|||||||
return int(os.getenv(key, default))
|
return int(os.getenv(key, default))
|
||||||
|
|
||||||
|
|
||||||
|
def __get_float(key: str, default: float) -> float:
|
||||||
|
"""
|
||||||
|
Return an integer value based on the environment variable or a default
|
||||||
|
"""
|
||||||
|
return float(os.getenv(key, default))
|
||||||
|
|
||||||
|
|
||||||
# NEVER RUN WITH DEBUG IN PRODUCTION.
|
# NEVER RUN WITH DEBUG IN PRODUCTION.
|
||||||
DEBUG = __get_boolean("PAPERLESS_DEBUG", "NO")
|
DEBUG = __get_boolean("PAPERLESS_DEBUG", "NO")
|
||||||
|
|
||||||
@ -485,6 +492,11 @@ CONSUMER_POLLING_RETRY_COUNT = int(
|
|||||||
os.getenv("PAPERLESS_CONSUMER_POLLING_RETRY_COUNT", 5),
|
os.getenv("PAPERLESS_CONSUMER_POLLING_RETRY_COUNT", 5),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
CONSUMER_INOTIFY_DELAY: Final[float] = __get_float(
|
||||||
|
"PAPERLESS_CONSUMER_INOTIFY_DELAY",
|
||||||
|
0.5,
|
||||||
|
)
|
||||||
|
|
||||||
CONSUMER_DELETE_DUPLICATES = __get_boolean("PAPERLESS_CONSUMER_DELETE_DUPLICATES")
|
CONSUMER_DELETE_DUPLICATES = __get_boolean("PAPERLESS_CONSUMER_DELETE_DUPLICATES")
|
||||||
|
|
||||||
CONSUMER_RECURSIVE = __get_boolean("PAPERLESS_CONSUMER_RECURSIVE")
|
CONSUMER_RECURSIVE = __get_boolean("PAPERLESS_CONSUMER_RECURSIVE")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user