From a471e595513a35dc78f66963466130fecbf4eb5b Mon Sep 17 00:00:00 2001 From: Andy Shultz Date: Wed, 3 Jan 2024 09:20:53 -0500 Subject: [PATCH] feat: progress logging when doing a reindex logs total and every 10 items includes a flag to reduce logging level because our normal info logs swamp progress logging. --- .../management/commands/reindex_course.py | 22 ++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/cms/djangoapps/contentstore/management/commands/reindex_course.py b/cms/djangoapps/contentstore/management/commands/reindex_course.py index 2da8d352f197..f5b6b9fadd55 100644 --- a/cms/djangoapps/contentstore/management/commands/reindex_course.py +++ b/cms/djangoapps/contentstore/management/commands/reindex_course.py @@ -3,6 +3,7 @@ import logging from textwrap import dedent +from time import time from django.core.management import BaseCommand, CommandError from elasticsearch import exceptions @@ -24,7 +25,7 @@ class Command(BaseCommand): Examples: ./manage.py reindex_course ... - reindexes courses with provided keys - ./manage.py reindex_course --all - reindexes all available courses + ./manage.py reindex_course --all --warning - reindexes all available courses with quieter logging ./manage.py reindex_course --setup - reindexes all courses for devstack setup """ help = dedent(__doc__) @@ -40,6 +41,10 @@ def add_arguments(self, parser): parser.add_argument('--setup', action='store_true', help='Reindex all courses on developers stack setup') + parser.add_argument('--warning', + action='store_true', + help='Reduce logging to a WARNING level of output for progress tracking' + ) def _parse_course_key(self, raw_value): """ Parses course key from string """ @@ -61,6 +66,7 @@ def handle(self, *args, **options): course_ids = options['course_ids'] all_option = options['all'] setup_option = options['setup'] + readable_option = options['warning'] index_all_courses_option = all_option or setup_option if (not len(course_ids) and not index_all_courses_option) or (len(course_ids) and index_all_courses_option): # lint-amnesty, pylint: disable=len-as-condition @@ -68,6 +74,10 @@ def handle(self, *args, **options): store = modulestore() + if readable_option: + logging.disable(level=logging.INFO) + logging.warning('Reducing logging to WARNING level for easier progress tracking') + if index_all_courses_option: index_names = (CoursewareSearchIndexer.INDEX_NAME, CourseAboutSearchIndexer.INDEX_NAME) if setup_option: @@ -98,8 +108,18 @@ def handle(self, *args, **options): # in case course keys are provided as arguments course_keys = list(map(self._parse_course_key, course_ids)) + total = len(course_keys) + logging.warning(f'Reindexing {total} courses') + reindexed = 0 + start = time() + for course_key in course_keys: try: CoursewareSearchIndexer.do_course_reindex(store, course_key) + reindexed += 1 + if reindexed % 10 == 0 or reindexed == total: + now = time() + t = now - start + logging.warning(f'{reindexed}/{total} reindexed in {t:.1f} seconds') except Exception as exc: # lint-amnesty, pylint: disable=broad-except logging.exception('Error indexing course %s due to the error: %s', course_key, exc)