A package for massive serving
Project description
Massive Serve User Guide
One command to download and serve a datastore---that's it ๐.
Installation
pip install massive-serve --upgrade
Usage
To serve a demo datastore (30MB):
massive-serve serve --domain_name demo
To serve a wikipedia datastore (60GB):
massive-serve serve --domain_name dpr_wiki_contriever
To avoid manually specifying the data storage location, set the DATASTORE_PATH environment variable to your desired data directory.
List of currently supported datastores (check the latest update in massive-serve collection):
- dpr_wiki_contriever
- dpr_wiki_e5_base_v2
More domains and retriever combinations coming soon!
It will then download and serve the index and print the API and one example request in the terminal, e.g.,
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ MASSIVE SERVE SERVER โ
โ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฃ
โ Domain: demo โ
โ Server: XXX โ
โ Port: XXX โ
โ Endpoint: XXX@XXX:XXX/search โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Test your server with this curl command:
curl -X POST XXX@XXX:XXX/search -H "Content-Type: application/json" -d '{"query": "Tell me more about the stories of Einstein.", "n_docs": 1, "domains": "demo"}'
Send Requests
If the API has been served, you can either send single or bulk query requests to it.
Bash Examples.
# single-query request
curl -X POST <user>@<address>:<port>/search -H "Content-Type: application/json" -d '{"query": "Where was Marie Curie born?", "n_docs": 1, "domains": "dpr_wiki_contriever"}'
# multi-query request
curl -X POST <user>@<address>:<port>/search -H "Content-Type: application/json" -d '{"query": ["Where was Marie Curie born?", "What is the capital of France?", "Who invented the telephone?"], "n_docs": 2, "dpr_wiki_contriever": "MassiveDS"}'
Python Example.
import requests
json_data = {
'query': 'Where was Marie Curie born?',
"n_docs": 20,
"domains": "dpr_wiki_contriever"
}
headers = {"Content-Type": "application/json"}
# Add 'http://' to the URL if it is not SSL/TLS secured, otherwise use 'https://'
response = requests.post('http://<user>@<address>:<port>/search', json=json_data, headers=headers)
print(response.status_code)
print(response.json())
Example output of a multi-query request:
{
"message": "Search completed for '['Where was Marie Curie born?', 'What is the capital of France?', 'Who invented the telephone?']' from MassiveDS",
"n_docs": 2,
"query": [
"Where was Marie Curie born?",
"What is the capital of France?",
"Who invented the telephone?"
],
"results": {
"n_docs": 2,
"query": [
"Where was Marie Curie born?",
"What is the capital of France?",
"Who invented the telephone?"
],
"results": {
"IDs": [
[
[3, 3893807],
[17, 11728753]
],
[
[14, 12939685],
[22, 1070951]
],
[
[28, 18823956],
[22, 10406782]
]
],
"passages": [
[
"Marie Skลodowska Curie (November 7, 1867 โ July 4, 1934) was a physicist and chemist of Polish upbringing and, subsequently, French citizenship. ...",
"=> Maria Skลodowska, better known as Marie Curie, was born on 7 November in Warsaw, Poland. ..."
],
[
"Paris is the capital and most populous city in France, as well as the administrative capital of the region of รle-de-France. ...",
"[paสi] ( listen)) is the capital and largest city of France. ..."
],
[
"Antonio Meucci (Florence, April 13, 1808 โ October 18, 1889) was an Italian inventor. ...",
"The telephone or phone is a telecommunications device that transmits speech by means of electric signals. ..."
]
],
"scores": [
[
1.8422218561172485,
1.8394594192504883
],
[
1.5528039932250977,
1.5502511262893677
],
[
1.714379906654358,
1.706493854522705
]
]
}
}
}
Massive Serve Developer Guide
Environment Setup
Using Conda (Recommended for GPU support)
- Create a new conda environment:
git clone https://github.com/RulinShao/massive-serve.git
cd massive-serve
conda env create -f conda-env.yml
conda activate massive-serve
To update the existing environment:
conda env update -n massive-serve -f conda-env.yml
Upload new index
python -m massive_serve.cli upload-data --domain_name demo
Test serving the index:
python -m massive_serve.cli serve --domain_name demo
Update package
Make sure the version in the setup.py has been updated to a different version. Then run:
rm -rf dist/ build/ massive_serve.egg-info/
pip install build twine
python -m build
python -m twine upload dist/*
Users can refresh their installed repo via:
pip install --upgrade massive-serve
License
This project is licensed under the MIT License - see the LICENSE file for details.
Citation
If you find our package helpful, please cite:
@article{shao2024scaling,
title={Scaling retrieval-based language models with a trillion-token datastore},
author={Shao, Rulin and He, Jacqueline and Asai, Akari and Shi, Weijia and Dettmers, Tim and Min, Sewon and Zettlemoyer, Luke and Koh, Pang Wei W},
journal={Advances in Neural Information Processing Systems},
volume={37},
pages={91260--91299},
year={2024}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file massive_serve-0.1.13.tar.gz.
File metadata
- Download URL: massive_serve-0.1.13.tar.gz
- Upload date:
- Size: 23.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
19575d9712cbcf7510933a41b31dd9a16a35595d45b3bae6cd442c0137ee1ce4
|
|
| MD5 |
3731f3b6b7a678da76c3e6d667d020a4
|
|
| BLAKE2b-256 |
6248a57f6e3f5c83204dfacfab9fe468abc2189d18ce0737b01da4d1132aa74a
|
File details
Details for the file massive_serve-0.1.13-py3-none-any.whl.
File metadata
- Download URL: massive_serve-0.1.13-py3-none-any.whl
- Upload date:
- Size: 28.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc19b6a107b71ae565f319ca0e5f709a06f5e5f0122980d8086b6b633005b539
|
|
| MD5 |
14c168a2bc436396fd001b395791ea5c
|
|
| BLAKE2b-256 |
fc62793ac1e006b3f3a6e23812281092d567c2338da29a5c5885cf5e1ee81e09
|