llama.cpp/llama_cpp/server/__main__.py

51 lines
1.2 KiB
Python
Raw Normal View History

2023-04-05 16:23:25 -04:00
"""Example FastAPI server for llama.cpp.
To run this example:
```bash
pip install fastapi uvicorn sse-starlette pydantic-settings
2023-04-05 16:23:25 -04:00
export MODEL=../models/7B/...
```
Then run:
```
uvicorn llama_cpp.server.app:app --reload
```
2023-04-05 16:23:25 -04:00
or
2023-04-05 16:23:25 -04:00
```
python3 -m llama_cpp.server
```
2023-04-05 16:23:25 -04:00
Then visit http://localhost:8000/docs to see the interactive API docs.
2023-04-05 16:23:25 -04:00
"""
import os
2023-05-05 12:08:28 -04:00
import argparse
import uvicorn
2023-04-05 16:23:25 -04:00
2023-05-05 12:08:28 -04:00
from llama_cpp.server.app import create_app, Settings
2023-04-05 16:23:25 -04:00
if __name__ == "__main__":
parser = argparse.ArgumentParser()
for name, field in Settings.model_fields.items():
description = field.description
if field.default is not None and description is not None:
description += f" (default: {field.default})"
2023-05-05 12:08:28 -04:00
parser.add_argument(
f"--{name}",
dest=name,
type=field.annotation if field.annotation is not None else str,
help=description,
2023-05-05 12:08:28 -04:00
)
args = parser.parse_args()
settings = Settings(**{k: v for k, v in vars(args).items() if v is not None})
2023-05-05 12:08:28 -04:00
app = create_app(settings=settings)
2023-04-05 16:23:25 -04:00
2023-04-06 21:07:35 -04:00
uvicorn.run(
app, host=os.getenv("HOST", settings.host), port=int(os.getenv("PORT", settings.port))
2023-04-06 21:07:35 -04:00
)