问题描述
我有以下设置:
- 活动中心
- 具有单个订阅的服务总线主题,该订阅接受来自该主题的所有消息(对于我的POC)
- 设置了以上服务总线订阅并启用了会话
- 流分析(SA)作业,用于将事件从事件中心(输入)移动到服务总线主题(输出)。这是我的SA查询:
SELECT *,LOWER(source) as Partner
INTO [sb-output]
FROM [test-input]
- 以上作业还设置了服务总线的分区键。根据{{3}}上的文档,在[sb-output]的系统属性中使用了以下json:
{ "PartitionKey" : "Partner" }
我做什么:
- 将事件发送到没有分区键的事件中心。成功了。
{
"specversion": "1.0","id": "c8c4faad-9f53-4e43-95ca-c318d673660a","type": "CustomerChanged","time": "2020-09-09T22:25:40.0148301Z","source": "ABCD","subject": "system-1","datacontenttype": "application/json","dataschema": "1.0","data": {
"customerNumber": "7879875212123","firstName": "John","lastName" : "Kennedy"
}
}
- SA成功将事件从事件中心转移到服务总线。
- 服务总线订阅成功收到消息,如下所示:
{
"specversion": "1.0","time": "2020-09-09T23:22:13.3647825Z","data": {
"customerNumber": "7879875212123","lastName": "Kennedy"
},"EventProcessedUtcTime": "2020-09-09T23:22:14.3776603Z","PartitionId": 0,"EventEnqueuedUtcTime": "2020-09-09T23:22:14.3080000Z","Partner": "abcd"
}
故障排除:
-
为确保可以使用特定的PartitionKey键将消息发送到服务总线主题,我编写了一个示例代码,通过在消息上显式设置会话ID属性,将该消息提交到服务总线主题。服务总线浏览器向我展示了SessionId以及PartitionKey属性都设置为正确的值。
{ "SessionId" : "Partner" }
{ "PartitionKey" : "Partner","SessionId" : "Partner" }
问题:
解决方法
根据原始海报的评论共享答案:
当前,Microsoft正在研究修复程序。
在此之前,您可以使用以下建议的解决方法:系统属性中的{ "PartitionKey" : "Partner","SessionId" : "Partner","Label": "Partner" }
。