编程语言
首页 > 编程语言> > c# – Azure Functions – 在另一个线程中运行长操作

c# – Azure Functions – 在另一个线程中运行长操作

作者:互联网

我正在尝试使用Azure Functions解决方案实现文件转换.转换可能需要很长时间.因此,我不希望在呼叫服务器上等待响应.
我编写了立即返回响应的函数(表示服务可用并启动转换)并在单独的线程中运行转换.回调URL用于发送转换结果.

public static async Task<HttpResponseMessage> Run(HttpRequestMessage req, Stream srcBlob, Binder binder, TraceWriter log)
{
    log.Info($"C# HTTP trigger function processed a request. RequestUri={req.RequestUri}");

    // Get request model
    var input = await req.Content.ReadAsAsync<ConvertInputModel>();

    //Run convert in separate thread
    Task.Run( async () => {
        //Read input blob -> convert -> upload output blob
        var convertResult = await ConvertAndUploadFile(input, srcBlob, binder, log);

        //return result using HttpClient
        SendCallback(convertResult, input.CallbackUrl); 
    });

    //Return response immediately
    return req.CreateResponse(HttpStatusCode.OK);
}

新任务破坏绑定的问题.访问params时我遇到异常.那么如何在单独的胎面上进行长时间操作呢?或者这样的解决方案完全错了?

解决方法:

Azure Functions中不推荐(或支持)此模式.特别是在消费计划中运行时,由于运行时将无法准确地管理您的功能的生命周期,并最终将关闭您的服务.

这里推荐(和广泛使用)模式之一是将此工作排队以由另一个函数处理,监听该队列,并立即将响应返回给客户端.

使用这种方法,您可以实现基本相同的事情,即实际处理将以异步方式完成,但是以可靠和有效的方式完成(如果需要,可以从自动扩展中获益,以正确处理增加的负载)

请记住,使用消费计划时,功能超时为5分钟.如果预计处理时间较长,则需要在启用了AlwaysOn的专用计划上运行您的功能.

标签:c,multithreading,azure,azure-functions
来源: https://codeday.me/bug/20190715/1465295.html