| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| import logging |
| import os |
| import signal |
| import sys |
| import time |
| import traceback |
| from concurrent.futures import ThreadPoolExecutor |
|
|
| from werkzeug.serving import run_simple |
| from api.apps import app |
| from api.db.runtime_config import RuntimeConfig |
| from api.db.services.document_service import DocumentService |
| from api.settings import ( |
| HOST, HTTP_PORT, access_logger, database_logger, stat_logger, |
| ) |
| from api import utils |
|
|
| from api.db.db_models import init_database_tables as init_web_db |
| from api.db.init_data import init_web_data |
| from api.versions import get_versions |
|
|
|
|
| def update_progress(): |
| while True: |
| time.sleep(1) |
| try: |
| DocumentService.update_progress() |
| except Exception as e: |
| stat_logger.error("update_progress exception:" + str(e)) |
|
|
|
|
| if __name__ == '__main__': |
| print(""" |
| ____ ______ __ |
| / __ \ ____ _ ____ _ / ____// /____ _ __ |
| / /_/ // __ `// __ `// /_ / // __ \| | /| / / |
| / _, _// /_/ // /_/ // __/ / // /_/ /| |/ |/ / |
| /_/ |_| \__,_/ \__, //_/ /_/ \____/ |__/|__/ |
| /____/ |
| |
| """, flush=True) |
| stat_logger.info( |
| f'project base: {utils.file_utils.get_project_base_directory()}' |
| ) |
|
|
| |
| init_web_db() |
| init_web_data() |
| |
| import argparse |
| parser = argparse.ArgumentParser() |
| parser.add_argument('--version', default=False, help="rag flow version", action='store_true') |
| parser.add_argument('--debug', default=False, help="debug mode", action='store_true') |
| args = parser.parse_args() |
| if args.version: |
| print(get_versions()) |
| sys.exit(0) |
|
|
| RuntimeConfig.DEBUG = args.debug |
| if RuntimeConfig.DEBUG: |
| stat_logger.info("run on debug mode") |
|
|
| RuntimeConfig.init_env() |
| RuntimeConfig.init_config(JOB_SERVER_HOST=HOST, HTTP_PORT=HTTP_PORT) |
|
|
| peewee_logger = logging.getLogger('peewee') |
| peewee_logger.propagate = False |
| |
| peewee_logger.addHandler(database_logger.handlers[0]) |
| peewee_logger.setLevel(database_logger.level) |
|
|
| thr = ThreadPoolExecutor(max_workers=1) |
| thr.submit(update_progress) |
|
|
| |
| try: |
| stat_logger.info("RAG Flow http server start...") |
| werkzeug_logger = logging.getLogger("werkzeug") |
| for h in access_logger.handlers: |
| werkzeug_logger.addHandler(h) |
| run_simple(hostname=HOST, port=HTTP_PORT, application=app, threaded=True, use_reloader=RuntimeConfig.DEBUG, use_debugger=RuntimeConfig.DEBUG) |
| except Exception: |
| traceback.print_exc() |
| os.kill(os.getpid(), signal.SIGKILL) |