如何解决如何在输出消息到服务总线的流分析中设置PartitionKey属性?
我有以下设置:
- 活动中心
- 具有单个订阅的服务总线主题,该订阅接受来自该主题的所有消息(对于我的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"
}
- 可以看到,属性Partner在消息末尾。
- 但是,服务总线资源管理器工具向我显示PartitionKey属性并未设置为“ abcd”,而是其他随机字符串。
故障排除:
-
为确保可以使用特定的PartitionKey键将消息发送到服务总线主题,我编写了一个示例代码,通过在消息上显式设置会话ID属性,将该消息提交到服务总线主题。服务总线浏览器向我展示了SessionId以及PartitionKey属性都设置为正确的值。
-
在ASA输出配置中,尝试设置以下系统属性json。都不起作用。
{ "SessionId" : "Partner" }
{ "PartitionKey" : "Partner","SessionId" : "Partner" }
- 在ASA输出配置中,尝试同时设置属性列(至
Partner
)和系统属性列(至{ "PartitionKey" : "Partner" }
)。那没用。
问题:
- 我正在避开从我的自定义字段到服务总线消息的PartitionKey值传播的ASA输出配置错误?
- 还有原因为什么系统属性列不显示保存后输入的json文本吗?
解决方法
根据原始海报的评论共享答案:
当前,Microsoft正在研究修复程序。
在此之前,您可以使用以下建议的解决方法:系统属性中的{ "PartitionKey" : "Partner","SessionId" : "Partner","Label": "Partner" }
。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。