Files
MinerU/projects/multi_gpu_v2/_config_endpoint.py
zhanluxianshen 1671e68367 fix error logs for multi_gpu endpoint.
Signed-off-by: zhanluxianshen <zhanluxianshen@163.com>
2025-08-26 10:26:10 +08:00

61 lines
2.2 KiB
Python

import requests
import os
import logging
logging.basicConfig(level=logging.INFO)
# test connection to huggingface
TIMEOUT = 3
def config_endpoint():
"""
Checks for connectivity to Hugging Face and sets the model source accordingly.
If the Hugging Face endpoint is reachable, it sets MINERU_MODEL_SOURCE to 'huggingface'.
Otherwise, it falls back to 'modelscope'.
"""
os.environ.setdefault('MINERU_MODEL_SOURCE', 'huggingface')
model_list_url = f"https://huggingface.co/models"
modelscope_url = f"https://modelscope.cn/models"
# Use a specific check for the Hugging Face source
if os.environ['MINERU_MODEL_SOURCE'] == 'huggingface':
try:
response = requests.head(model_list_url, timeout=TIMEOUT)
# Check for any successful status code (2xx)
if response.ok:
logging.info(f"Successfully connected to Hugging Face. Using 'huggingface' as model source.")
return True
else:
logging.warning(f"Hugging Face endpoint returned a non-200 status code: {response.status_code}")
except requests.exceptions.RequestException as e:
logging.error(f"Failed to connect to Hugging Face at {model_list_url}: {e}")
# If any of the above checks fail, switch to modelscope
logging.info("Falling back to 'modelscope' as model source.")
os.environ['MINERU_MODEL_SOURCE'] = 'modelscope'
elif os.environ['MINERU_MODEL_SOURCE'] == 'modelscope':
try:
response = requests.head(modelscope_url, timeout=TIMEOUT)
if response.ok:
logging.info(f"Successfully connected to ModelScope. Using 'modelscope' as model source.")
return True
except requests.exceptions.RequestException as e:
logging.error(f"Failed to connect to ModelScope at {modelscope_url}: {e}")
elif os.environ['MINERU_MODEL_SOURCE'] == 'local':
logging.info("Using 'local' as model source.")
return True
else:
logging.error(f"Using custom model source: {os.environ['MINERU_MODEL_SOURCE']}")
return True
return False
if __name__ == '__main__':
print(config_endpoint())