|
|
2 ماه پیش | |
|---|---|---|
| .. | ||
| README.md | 5 ماه پیش | |
| README_zh.md | 5 ماه پیش | |
| _config_endpoint.py | 2 ماه پیش | |
| client.py | 2 ماه پیش | |
| server.py | 4 ماه پیش | |
A streamlined multi-GPU server implementation.
pip install --upgrade pip
pip install uv
uv pip install -U "mineru[core]"
uv pip install litserve aiohttp loguru
python server.py
python client.py
Now, pdf files under folder demo will be processed in parallel. Assuming you have 2 gpus, if you change the workers_per_device to 2, 4 pdf files will be processed at the same time!
Example showing how to start the server with custom settings:
server = ls.LitServer(
MinerUAPI(output_dir='/tmp/mineru_output'),
accelerator='auto', # You can specify 'cuda'
devices='auto', # "auto" uses all available GPUs
workers_per_device=1, # One worker instance per GPU
timeout=False # Disable timeout for long processing
)
server.run(port=8000, generate_client_file=False)
The client supports both synchronous and asynchronous processing:
import asyncio
import aiohttp
from client import mineru_parse_async
async def process_documents():
async with aiohttp.ClientSession() as session:
# Basic usage
result = await mineru_parse_async(session, 'document.pdf')
# With custom options
result = await mineru_parse_async(
session,
'document.pdf',
backend='pipeline',
lang='ch',
formula_enable=True,
table_enable=True
)
# Run async processing
asyncio.run(process_documents())
Process multiple files simultaneously:
async def process_multiple_files():
files = ['doc1.pdf', 'doc2.pdf', 'doc3.pdf']
async with aiohttp.ClientSession() as session:
tasks = [mineru_parse_async(session, file) for file in files]
results = await asyncio.gather(*tasks)
return results