# 内存动作

updatable

该动作用于将结果刷新到内存中的主题中,以便 内存源 可以使用它。 该主题类似于 pubsub 主题,例如 mqtt,因此可能有多个内存目标发布到同一主题,也可能有多个内存源订阅同一主题。 内存动作的典型用途是形成规则管道

属性名称是否可选描述
topic内存中的主题,例如 analysis/result, 支持动态属性
rowkindField指定哪个字段表示操作,例如插入或更新。如果不指定,默认所有的数据都是插入操作

下面是一个内存动作配置示例:

{
  "memory": {
    "topic": "devices/result"
  }
}
1
2
3
4
5

下面是动态主题示例:

{
  "memory": {
    "topic": "{{.topic}}"
  }
}
1
2
3
4
5

# 数据模板

内存动作和内存源之间的数据传输采用内部格式,不经过编解码以提高效率。因此,内存动作的格式相关配置项,除了数据模板之外都会被忽略。内存动作可支持数据模板对结果格式进行变化,但是数据模板的结果必须为 JSON 字符串的 object 形式,例如 "{\"key\":\"{{.key}}\"}"。数组形式的 JSON 字符串或者非 JSON 字符串都不支持。

# 更新

内存动作支持更新。可用于更新订阅了与 sink 相同的主题的查询表。一个典型的用法是创建一个规则,使用可更新的 sink 来累积更新内存表。在下面的例子中,来自流alertStream的数据将更新内存主题alertVal。更新动作是由流入的数据中的 action 字段指定的。

{
  "id": "ruleUpdateAlert",
  "sql":"SELECT * FROM alertStream",
  "actions":[
    {
      "memory": {
        "keyField": "id",
        "rowkindField": "action",
        "topic": "alertVal",
        "sendSingle": true
      }
    }
  ]
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14