2023-04-05 16:23:25 -04:00
|
|
|
"""Example FastAPI server for llama.cpp.
|
|
|
|
|
|
|
|
To run this example:
|
|
|
|
|
|
|
|
```bash
|
2023-07-07 21:38:46 -04:00
|
|
|
pip install fastapi uvicorn sse-starlette pydantic-settings
|
2023-04-05 16:23:25 -04:00
|
|
|
export MODEL=../models/7B/...
|
|
|
|
```
|
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
Then run:
|
|
|
|
```
|
2023-12-22 11:51:25 +01:00
|
|
|
uvicorn llama_cpp.server.app:create_app --reload
|
2023-04-28 22:43:37 -07:00
|
|
|
```
|
2023-04-05 16:23:25 -04:00
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
or
|
2023-04-05 16:23:25 -04:00
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
```
|
|
|
|
python3 -m llama_cpp.server
|
|
|
|
```
|
2023-04-05 16:23:25 -04:00
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
Then visit http://localhost:8000/docs to see the interactive API docs.
|
2023-04-05 16:23:25 -04:00
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
"""
|
2023-12-22 11:51:25 +01:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
import os
|
2023-12-22 11:51:25 +01:00
|
|
|
import sys
|
2023-05-05 12:08:28 -04:00
|
|
|
import argparse
|
|
|
|
|
2023-04-28 22:43:37 -07:00
|
|
|
import uvicorn
|
2023-04-05 16:23:25 -04:00
|
|
|
|
2023-12-22 11:51:25 +01:00
|
|
|
from llama_cpp.server.app import create_app
|
|
|
|
from llama_cpp.server.settings import (
|
|
|
|
Settings,
|
|
|
|
ServerSettings,
|
|
|
|
ModelSettings,
|
|
|
|
ConfigFileSettings,
|
|
|
|
)
|
|
|
|
from llama_cpp.server.cli import add_args_from_model, parse_model_from_args
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
description = "🦙 Llama.cpp python server. Host your own LLMs!🚀"
|
|
|
|
parser = argparse.ArgumentParser(description=description)
|
|
|
|
|
|
|
|
add_args_from_model(parser, Settings)
|
|
|
|
parser.add_argument(
|
|
|
|
"--config_file",
|
|
|
|
type=str,
|
|
|
|
help="Path to a config file to load.",
|
|
|
|
)
|
|
|
|
server_settings: ServerSettings | None = None
|
|
|
|
model_settings: list[ModelSettings] = []
|
2023-05-05 12:08:28 -04:00
|
|
|
args = parser.parse_args()
|
2023-12-22 11:51:25 +01:00
|
|
|
try:
|
|
|
|
# Load server settings from config_file if provided
|
|
|
|
config_file = os.environ.get("CONFIG_FILE", args.config_file)
|
|
|
|
if config_file:
|
|
|
|
if not os.path.exists(config_file):
|
|
|
|
raise ValueError(f"Config file {config_file} not found!")
|
|
|
|
with open(config_file, "rb") as f:
|
2024-04-10 02:47:01 -04:00
|
|
|
# Check if yaml file
|
|
|
|
if config_file.endswith(".yaml") or config_file.endswith(".yml"):
|
|
|
|
import yaml
|
|
|
|
import json
|
|
|
|
|
|
|
|
config_file_settings = ConfigFileSettings.model_validate_json(
|
|
|
|
json.dumps(yaml.safe_load(f))
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
config_file_settings = ConfigFileSettings.model_validate_json(f.read())
|
2023-12-22 11:51:25 +01:00
|
|
|
server_settings = ServerSettings.model_validate(config_file_settings)
|
|
|
|
model_settings = config_file_settings.models
|
|
|
|
else:
|
|
|
|
server_settings = parse_model_from_args(ServerSettings, args)
|
|
|
|
model_settings = [parse_model_from_args(ModelSettings, args)]
|
|
|
|
except Exception as e:
|
|
|
|
print(e, file=sys.stderr)
|
|
|
|
parser.print_help()
|
|
|
|
sys.exit(1)
|
|
|
|
assert server_settings is not None
|
|
|
|
assert model_settings is not None
|
|
|
|
app = create_app(
|
|
|
|
server_settings=server_settings,
|
|
|
|
model_settings=model_settings,
|
|
|
|
)
|
2023-04-06 21:07:35 -04:00
|
|
|
uvicorn.run(
|
2023-12-22 11:51:25 +01:00
|
|
|
app,
|
|
|
|
host=os.getenv("HOST", server_settings.host),
|
|
|
|
port=int(os.getenv("PORT", server_settings.port)),
|
|
|
|
ssl_keyfile=server_settings.ssl_keyfile,
|
|
|
|
ssl_certfile=server_settings.ssl_certfile,
|
2023-04-06 21:07:35 -04:00
|
|
|
)
|
2023-12-22 11:51:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|