почему мой fastapi или uvicorn выключается?

Я пытаюсь запустить службу, которая использует простую модель трансформаторов Роберты для классификации. сам сценарий / функция логического вывода работает должным образом при тестировании. когда я включаю это с быстрым API, он выключает сервер.

      uvicorn==0.11.8
fastapi==0.61.1
simpletransformers==0.51.6
cmd : uvicorn --host 0.0.0.0 --port 5000 src.main:app

      @app.get("/article_classify")
def classification(text:str):
    """function to classify article using a deep learning model.
    Returns:
        [type]: [description]
    """

    _,_,result = inference(text)
    return result

ошибка :

      INFO:     Started server process [8262]
INFO:     Waiting for application startup.
INFO:     Application startup complete.
INFO:     Uvicorn running on http://0.0.0.0:5000 (Press CTRL+C to quit)
INFO:     127.0.0.1:36454 - "GET / HTTP/1.1" 200 OK
INFO:     127.0.0.1:36454 - "GET /favicon.ico HTTP/1.1" 404 Not Found
INFO:     127.0.0.1:36454 - "GET /docs HTTP/1.1" 200 OK
INFO:     127.0.0.1:36454 - "GET /openapi.json HTTP/1.1" 200 OK
before
100%|████████████████████████████████████████████████████████████████████████████| 1/1 [00:00<00:00, 17.85it/s]
INFO:     Shutting down
INFO:     Finished server process [8262]

сценарий вывода:

      model_name = "checkpoint-3380-epoch-20"
model = MultiLabelClassificationModel("roberta","src/outputs/"+model_name)
def inference(input_text,model_name="checkpoint-3380-epoch-20"):
    """Function to run inverence on one sample text"""
    #model = MultiLabelClassificationModel("roberta","src/outputs/"+model_name)
    all_tags =[]
    if isinstance(input_text,str):
        print("before")
        result ,output = model.predict([input_text])
        print(result)
        tags=[]
        for idx,each in enumerate(result[0]):
            if each==1:
                tags.append(classes[idx])
        all_tags.append(tags)
    elif isinstance(input_text,list):
        result ,output = model.predict(input_text)
        tags=[]
        for res in result : 
            for idx,each in enumerate(res):
                if each==1:
                    tags.append(classes[idx])
            all_tags.append(tags)

    return result,output,all_tags

обновление: пробовал с флягой, и служба работает, но при добавлении uvicorn поверх фляги он застревает в цикле перезапуска.

5 ответов

Решение

Я решил эту проблему, запустив пул процессов с явным использованием многопроцессорности.

      from multiprocessing import set_start_method
from multiprocessing import Process, Manager
try:
    set_start_method('spawn')
except RuntimeError:
    pass
@app.get("/article_classify")
def classification(text:str):
    """function to classify article using a deep learning model.
    Returns:
        [type]: [description]
    """
    manager = Manager()

    return_result = manager.dict()
    # as the inference is failing 
    p = Process(target = inference,args=(text,return_result,))
    p.start()
    p.join()
    # print(return_result)
    result = return_result['all_tags']
    return result

Хотя принятое решение работает, я хотел бы предложить менее хакерское решение, которое использует uvicronвместо них рабочие.

Вы можете попробовать добавить --workers 4на ваш CMDтак он читает:

      uvicorn --host 0.0.0.0 --port 5000 --workers 4 src.main:app

Согласно https://github.com/ThilinaRajapakse/simpletransformers/issues/761 , это связано с многопроцессорностью.

Я установил args={'use_multiprocessing': False}, и веб-сервер больше не выключается.

Недавно я столкнулся с подобной проблемой. Моя ситуация может быть немного другой, но я хочу предоставить ее в качестве справки. Я использовал преобразователь предложений, который требует загрузки файла большого веса, процесс загрузки занимает o (10) секунд. Однако у единорога по умолчанию есть настройка timeout_notify=30. При чтении исходного кода кажется, что это причина, по которой сервер продолжает перезагружаться, поскольку загрузка занимает много времени (около 30 секунд).

Позже я использую другой способ ускорить загрузку, и проблема перезапуска исчезнет.

поместите всю функцию под try-except заблокировать и показать результат, чтобы мы могли исследовать реальную проблему.

      import logging

@app.get("/article_classify")
def classification(text:str):
    """function to classify article using a deep learning model.
    Returns:
        [type]: [description]
    """
    try:
    _,_,result = inference(text)
    except:
        logging.exception("something bad happened")  # automatically print exception info

    return result
Другие вопросы по тегам