我正在尝试从 Azure 函数 EventHub 触发器向 Azure SignalR 服务发送消息。
我没有得到异常,甚至没有关于输出窗口的信息,我做错了什么?
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.Azure.EventHubs;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.SignalRService;
using Microsoft.Extensions.Logging;
namespace AzureFunction_EventHubToSignalR
{
public static class Function1
{
[FunctionName("Function1")]
public static async Task Run([EventHubTrigger("dio", Connection = "EventHubSharedAccessPolicyConnectionString")] EventData[] events,
[SignalR(HubName = "%AzureSignalRHubName%")] IAsyncCollector<SignalRMessage> signalRMessages,
ILogger log)
{
var exceptions = new List<Exception>();
foreach (EventData eventData in events)
{
try
{
string messageBody = Encoding.UTF8.GetString(eventData.Body.Array, eventData.Body.Offset, eventData.Body.Count);
await signalRMessages.AddAsync(
new SignalRMessage
{
Target = "BroadcastMessage",
Arguments = new[] { messageBody }
});
await signalRMessages.FlushAsync();
// Replace these two lines with your processing logic.
log.LogInformation($"C# Event Hub trigger function processed a message: {messageBody}");
await Task.Yield();
}
catch (Exception e)
{
log.LogError($"Event Hub trigger failed to process or send a message: {e}");
// We need to keep processing the rest of the batch - capture this exception and continue.
// Also, consider capturing details of the message that failed processing so it can be processed again later.
exceptions.Add(e);
}
}
// Once processing of the batch is complete, if any messages in the batch failed processing throw an exception so that there is a record of the failure.
if (exceptions.Count > 1)
throw new AggregateException(exceptions);
if (exceptions.Count == 1)
throw exceptions.Single();
}
}
}