我一直在尝试基于Austin Sample创建一个示例应用程序。首先,我有一个带样本的404,我通过调整App.Config中的connectionString来修复它(我忘了那个,我的坏)。 现在我已经创建了第二个接收器,它应该将消息发送到服务总线队列而不是Azure表。 启动SampleApplication和EventSourceSimulator时,前两个消息似乎正确传递,但第三个消息显示404错误。 以下是错误和我的接收器类的屏幕截图。如果您需要更多信息来帮助我,请告诉我。 提前谢谢,
public class ServiceBusQueueSink<TEvent>
{
readonly QueueClient _queueClient;
readonly NamespaceManager _namespaceManager;
readonly string _connectionString;
readonly string _queueName = "DeviceErrorsQueue";
readonly string _errorType;
readonly bool _storeCtis;
ServiceBusQueueSink(string errorType, bool storeCtis)
{
_errorType = errorType;
_storeCtis = storeCtis;
// Configure Queue Settings
QueueDescription qd = new QueueDescription(_queueName);
qd.MaxSizeInMegabytes = 2048;
qd.DefaultMessageTimeToLive = new TimeSpan(0, 1, 0);
// Create the queue if it does not exist already
_connectionstring = CloudConfigurationManager.GetSetting("Microsoft.ServiceBus.ConnectionString");
_namespaceManager = NamespaceManager.CreateFromConnectionString(_connectionString);
if (!_namespaceManager.QueueExists(_queueName))
{
_namespaceManager.CreateQueue(_queueName);
}
_queueClient = QueueClient.CreateFromConnectionString(_connectionString, "DeviceErrorsQueue");
}
/// <summary>
/// Write each received event into the service bus queue.
/// </summary>
/// <param name="e">Event to write.</param>
public void OnNext(PointEvent<TEvent> e)
{
bool send = false;
if (e.EventKind == EventKind.Cti)
{
if (_storeCtis)
send = true;
else
send = false;
}
else
send = true;
if (send)
{
BrokeredMessage message = new BrokeredMessage(e);
message.Properties["ErrorType"] = _errorType;
_queueClient.Send(message);
}
}
/// <summary>
/// Static method that returns a new Service Bus Queue sink observer.
/// </summary>
/// <param name="storageConnection">Service Bus Queue connection string.</param>
/// <param name="errorType">Type of error to be saved in properties of brokeredmessage.</param>
/// <param name="storeCtis">Flag specifying whether to also persist CTI events.</param>
/// <returns></returns>
public static IObserver<PointEvent<TEvent>> CreateObserver(string errorType, bool storeCtis)
{
var res = new ServiceBusQueueSink<TEvent>(errorType, storeCtis);
return Observer.Create<PointEvent<TEvent>>(e => res.OnNext(e));
}
更新:我在管理门户网站的服务总线队列中看不到任何内容,所以我想没有任何东西可以实现。
答案 0 :(得分:1)
我想你在(yourservice)/设备上有一个HttpSource,对吗? 问题是,在收到两条消息后,查询中的某些内容中断了,我怀疑输出会下沉。因此,您在此地址收到404,因为整个查询已关闭。请查看StreamInsight存储帐户中的日志表,您应该在那里看到错误/异常信息。
答案 1 :(得分:0)
您似乎找到了问题的原因。通常,如果HTTP端点返回404(可能在几次成功请求之后),则查询管道中的某些内容可能会爆炸,如上面的第一个回复所示。在这种情况下,您可以通过连接调试器并检查查询的诊断来获得抛出的异常。 Austin CTP软件包附带的FAQ(入门文档的一部分)提供了有关该软件包的更多信息。