如何在输出消息到服务总线的流分析中设置PartitionKey属性?

问题描述

我有以下设置:

  1. 活动中心
  2. 具有单个订阅的服务总线主题,该订阅接受来自该主题的所有消息(对于我的POC)
  3. 设置了以上服务总线订阅并启用了会话
  4. 流分析(SA)作业,用于将事件从事件中心(输入)移动到服务总线主题输出)。这是我的SA查询
    SELECT *,LOWER(source) as Partner
    INTO [sb-output]
    FROM [test-input]
  1. 以上作业还设置了服务总线的分区键。根据{{​​3}}上的文档,在[sb-output]的系统属性中使用了以下json:
    { "PartitionKey" : "Partner" }

我做什么:

  1. 将事件发送到没有分区键的事件中心。成功了。
{
    "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"
    }
}
  1. SA成功将事件从事件中心转移到服务总线。
  2. 服务总线订阅成功收到消息,如下所示:
    {
        "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"
    }
  1. 可以看到,属性Partner在消息末尾。
  2. 但是,服务总线资源管理器工具向我显示PartitionKey属性并未设置为“ abcd”,而是其他随机字符串。

故障排除:

  1. 为确保可以使用特定的PartitionKey键将消息发送到服务总线主题,我编写了一个示例代码,通过在消息上显式设置会话ID属性,将该消息提交到服务总线主题。服务总线浏览器向我展示了SessionId以及PartitionKey属性都设置为正确的值。

  2. 在ASA输出配置中,尝试设置以下系统属性json。都不起作用。

{ "SessionId" : "Partner" }

{ "PartitionKey" : "Partner","SessionId" : "Partner" }

  1. 在ASA输出配置中,尝试同时设置属性列(至Partner)和系统属性列(至{ "PartitionKey" : "Partner" })。那没用。

问题:

  1. 我正在避开从我的自定义字段到服务总线消息的PartitionKey值传播的ASA输出配置错误
  2. 还有原因为什么系统属性不显示保存后输入的json文本吗?

解决方法

根据原始海报的评论共享答案:

当前,Microsoft正在研究修复程序。

在此之前,您可以使用以下建议的解决方法:系统属性中的{ "PartitionKey" : "Partner","SessionId" : "Partner","Label": "Partner" }