forked from Open-LLM-VTuber/Open-LLM-VTuber
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun_server.py
More file actions
91 lines (76 loc) · 2.79 KB
/
run_server.py
File metadata and controls
91 lines (76 loc) · 2.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import os
import sys
import atexit
import argparse
from pathlib import Path
import tomli
import uvicorn
from loguru import logger
from upgrade import sync_user_config, select_language
from src.open_llm_vtuber.server import WebSocketServer
from src.open_llm_vtuber.config_manager import Config, read_yaml, validate_config
os.environ["HF_HOME"] = str(Path(__file__).parent / "models")
os.environ["MODELSCOPE_CACHE"] = str(Path(__file__).parent / "models")
def get_version() -> str:
with open("pyproject.toml", "rb") as f:
pyproject = tomli.load(f)
return pyproject["project"]["version"]
def init_logger(console_log_level: str = "INFO") -> None:
logger.remove()
# Console output
logger.add(
sys.stderr,
level=console_log_level,
format="<green>{time:YYYY-MM-DD HH:mm:ss}</green> | <level>{level: <8}</level> | <cyan>{name}</cyan>:<cyan>{function}</cyan>:<cyan>{line}</cyan> | {message}",
colorize=True,
)
# File output
logger.add(
"logs/debug_{time:YYYY-MM-DD}.log",
rotation="10 MB",
retention="30 days",
level="DEBUG",
format="{time:YYYY-MM-DD HH:mm:ss.SSS} | {level: <8} | {name}:{function}:{line} | {message} | {extra}",
backtrace=True,
diagnose=True,
)
def parse_args():
parser = argparse.ArgumentParser(description="Open-LLM-VTuber Server")
parser.add_argument("--verbose", action="store_true", help="Enable verbose logging")
parser.add_argument(
"--hf_mirror", action="store_true", help="Use Hugging Face mirror"
)
return parser.parse_args()
@logger.catch
def run(console_log_level: str):
init_logger(console_log_level)
logger.info(f"Open-LLM-VTuber, version v{get_version()}")
# Sync user config with default config
try:
sync_user_config(logger=logger, lang=select_language())
except Exception as e:
logger.error(f"Error syncing user config: {e}")
atexit.register(WebSocketServer.clean_cache)
# Load configurations from yaml file
config: Config = validate_config(read_yaml("conf.yaml"))
server_config = config.system_config
# Initialize and run the WebSocket server
server = WebSocketServer(config=config)
uvicorn.run(
app=server.app,
host=server_config.host,
port=server_config.port,
log_level=console_log_level.lower(),
)
if __name__ == "__main__":
args = parse_args()
console_log_level = "DEBUG" if args.verbose else "INFO"
if args.verbose:
logger.info("Running in verbose mode")
else:
logger.info(
"Running in standard mode. For detailed debug logs, use: uv run run_server.py --verbose"
)
if args.hf_mirror:
os.environ["HF_ENDPOINT"] = "https://hf-mirror.com"
run(console_log_level=console_log_level)