ragflow/api/ragflow_init.py

156 lines
5.1 KiB
Python

#
# Copyright 2024 The InfiniFlow Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
import logging
import os
import threading
import uuid
from api.apps import app, smtp_mail_server
from api.db.runtime_config import RuntimeConfig
from api.db.services.document_service import DocumentService
from common.file_utils import get_project_base_directory
from common import settings
from api.db.db_models import init_database_tables as init_web_db
from api.db.init_data import init_web_data
from common.versions import get_ragflow_version
from common.config_utils import show_configs
from plugin import GlobalPluginManager
from rag.utils.redis_conn import RedisDistributedLock
from common.log_utils import init_root_logger
# Shared stop event for background tasks
stop_event = threading.Event()
def update_progress():
"""Background task to update document processing progress"""
lock_value = str(uuid.uuid4())
redis_lock = RedisDistributedLock("update_progress", lock_value=lock_value, timeout=60)
logging.info(f"update_progress lock_value: {lock_value}")
while not stop_event.is_set():
try:
if redis_lock.acquire():
DocumentService.update_progress()
redis_lock.release()
except Exception:
logging.exception("update_progress exception")
finally:
try:
redis_lock.release()
except Exception:
logging.exception("update_progress exception")
stop_event.wait(6)
def init_logging(logger_name="ragflow_server"):
"""Initialize logging system"""
init_root_logger(logger_name)
def print_startup_banner():
"""Print RAGFlow startup banner"""
logging.info(r"""
____ ___ ______ ______ __
/ __ \ / | / ____// ____// /____ _ __
/ /_/ // /| | / / __ / /_ / // __ \| | /| / /
/ _, _// ___ |/ /_/ // __/ / // /_/ /| |/ |/ /
/_/ |_|/_/ |_|\____//_/ /_/ \____/ |__/|__/
""")
logging.info(f"RAGFlow version: {get_ragflow_version()}")
logging.info(f"project base: {get_project_base_directory()}")
def init_debugpy():
"""Initialize debugpy if RAGFLOW_DEBUGPY_LISTEN is set"""
ragflow_debugpy_listen = int(os.environ.get("RAGFLOW_DEBUGPY_LISTEN", "0"))
if ragflow_debugpy_listen > 0:
logging.info(f"debugpy listen on {ragflow_debugpy_listen}")
import debugpy
debugpy.listen(("0.0.0.0", ragflow_debugpy_listen))
def init_smtp():
"""Initialize SMTP mail server configuration"""
if settings.SMTP_CONF:
app.config["MAIL_SERVER"] = settings.MAIL_SERVER
app.config["MAIL_PORT"] = settings.MAIL_PORT
app.config["MAIL_USE_SSL"] = settings.MAIL_USE_SSL
app.config["MAIL_USE_TLS"] = settings.MAIL_USE_TLS
app.config["MAIL_USERNAME"] = settings.MAIL_USERNAME
app.config["MAIL_PASSWORD"] = settings.MAIL_PASSWORD
app.config["MAIL_DEFAULT_SENDER"] = settings.MAIL_DEFAULT_SENDER
smtp_mail_server.init_app(app)
def init_ragflow(debug_mode=False):
"""
Initialize RAGFlow application with all common initialization steps
Args:
debug_mode: Whether to run in debug mode (default: False)
"""
# 1. Initialize Logging
init_logging("ragflow_server")
# 2. Print startup banner and initialize settings
print_startup_banner()
show_configs()
settings.init_settings()
settings.print_rag_settings()
# 3. Check for debugpy
init_debugpy()
# 4. Initialize DB and Data
init_web_db()
init_web_data()
# 5. Initialize Runtime Config
RuntimeConfig.DEBUG = debug_mode
if RuntimeConfig.DEBUG:
logging.info("run on debug mode")
RuntimeConfig.init_env()
RuntimeConfig.init_config(JOB_SERVER_HOST=settings.HOST_IP, HTTP_PORT=settings.HOST_PORT)
# 6. Load Plugins
GlobalPluginManager.load_plugins()
# 7. Initialize SMTP
init_smtp()
def start_update_progress_thread(delayed=False, delay_seconds=1.0):
"""
Start the update_progress background thread
Args:
delayed: Whether to delay the start (default: False)
delay_seconds: Delay in seconds if delayed=True (default: 1.0)
"""
if delayed:
def delayed_start():
logging.info("Starting update_progress thread (delayed)")
t = threading.Thread(target=update_progress, daemon=True)
t.start()
threading.Timer(delay_seconds, delayed_start).start()
else:
logging.info("Starting background tasks (update_progress)...")
t = threading.Thread(target=update_progress, daemon=True)
t.start()