forked from zhaochenyang20/sglang-diffusion-routing
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
127 lines (108 loc) · 3.52 KB
/
main.py
File metadata and controls
127 lines (108 loc) · 3.52 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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# This module is derived from radixark/miles#544.
# See README.md for full acknowledgment.
from __future__ import annotations
import argparse
import sys
from sglang_diffusion_routing import DiffusionRouter
def _run_router_server(
args: argparse.Namespace,
worker_urls: list[str] | None = None,
log_prefix: str = "[router]",
) -> None:
try:
import uvicorn # type: ignore[import-not-found]
except ImportError as exc:
raise RuntimeError(
"uvicorn is required to run router. Install with: pip install uvicorn"
) from exc
worker_urls = list(
worker_urls if worker_urls is not None else args.worker_urls or []
)
router = DiffusionRouter(args, verbose=args.verbose)
for url in worker_urls:
normalized_url = router.normalize_worker_url(url)
router.register_worker(normalized_url)
print(f"{log_prefix} starting router on {args.host}:{args.port}", flush=True)
print(
f"{log_prefix} workers: {list(router.worker_request_counts.keys()) or '(none - add via POST /add_worker)'}",
flush=True,
)
uvicorn.run(
router.app,
host=args.host,
port=args.port,
log_level=getattr(args, "log_level", "info"),
)
def _add_router_args(parser: argparse.ArgumentParser) -> None:
parser.add_argument(
"--host", type=str, default="0.0.0.0", help="Router bind address."
)
parser.add_argument("--port", type=int, default=30080, help="Router port.")
parser.add_argument(
"--worker-urls", nargs="*", default=[], help="Initial diffusion worker URLs."
)
parser.add_argument(
"--max-connections",
type=int,
default=100,
help="Max concurrent connections to workers.",
)
parser.add_argument(
"--timeout",
type=float,
default=120.0,
help="Router-to-worker request timeout in seconds.",
)
parser.add_argument(
"--health-check-interval",
type=int,
default=10,
help="Seconds between health checks.",
)
parser.add_argument(
"--health-check-failure-threshold",
type=int,
default=3,
help="Consecutive failures before quarantine.",
)
parser.add_argument(
"--routing-algorithm",
type=str,
default="least-request",
choices=["least-request", "round-robin", "random"],
help="Load-balancing algorithm.",
)
parser.add_argument(
"--verbose", action="store_true", help="Enable verbose logging."
)
parser.add_argument(
"--log-level", type=str, default="info", help="Uvicorn log level."
)
def _handle_router(args: argparse.Namespace) -> int:
_run_router_server(
args, worker_urls=list(args.worker_urls), log_prefix="[sglang-d-router]"
)
return 0
def build_parser() -> argparse.ArgumentParser:
parser = argparse.ArgumentParser(
prog="sglang-d-router",
description="SGLang diffusion router CLI.",
)
_add_router_args(parser)
parser.set_defaults(handler=_handle_router)
return parser
def run_cli(argv: list[str] | None = None) -> int:
parser = build_parser()
args = parser.parse_args(argv)
handler = args.handler
return handler(args)
def main(argv: list[str] | None = None) -> int:
try:
return run_cli(argv)
except KeyboardInterrupt:
return 130
except Exception as exc:
print(f"[sglang-d-router] error: {exc}", file=sys.stderr)
return 1
if __name__ == "__main__":
raise SystemExit(main())