view.py 1.75 KB
Newer Older
wangsen's avatar
wangsen committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
from sanic import response
from src.utils.trace_log import TraceLog
from src.utils import loggers
import traceback
import uuid
import time


async def setup_model(app, loop):
    loggers.get_out_log().info("----------setup model-------------")
    global model
    model = app.modelSortLightGBM
    model.load_model()

    loggers.get_out_log().info("----------done setup model-------------")


async def health_check(request):
    return response.json({"status": "ok"})


async def process_rec_info(request):
    tracelog = TraceLog()
    try:
        data = request.json
        rid = data.get("requestid", uuid.uuid4().hex)
        input_sent = data.get("input")

        # todo: log params
        tracelog.apiVersion(1)
        tracelog.requestId(rid)
        tracelog.inputSent(input_sent)
        tracelog.start_log()

        # 模型推理
        all_start = time.time()
        cost_detail = {}
        finalresult = await model.process(input_sent)
        cost_detail['all_process'] = (time.time() - all_start) * 1000
        tracelog.costDetail(cost_detail)

        tracelog.modelResults(finalresult)
        tracelog.modelResultsLen(len(finalresult))

        ret = {
            "code": 0,
            "requestid": rid,
            "errmsg": "",
            "total": len(finalresult),
            "recResults": finalresult
            }
    except Exception as e:
        loggers.get_error_log().error("error occur in recommand infos {}".format(traceback.format_exc()))
        t = "{}".format(e)
        ret = {
            "code": -1,
            "requestid": rid,
            "errmsg": f"{t}",
            "total": 0,
            "recResults": [{}]
        }
        tracelog.exception(t)

    tracelog.responseEntity(ret)
    tracelog.end_log()
    return response.json(ret)