# Memory action
updatable
The action is used to flush the result into an in-memory topic so that it can be consumed by the memory source. The topic is like pubsub topic such as mqtt, so that there could be multiple memory sinks which publish to the same topic and multiple memory sources which subscribe to the same topic. The typical usage for memory action is to form rule pipelines.
Property name | Optional | Description |
---|---|---|
topic | false | The in-memory topic, such as analysis/result |
rowkindField | true | Specify which field represents the action like insert or update. If not specified, all rows are default to insert. |
Below is a sample memory action configuration:
{
"memory": {
"topic": "devices/result"
}
}
2
3
4
5
Below is another sample for dynamic topic action:
{
"memory": {
"topic": "{{.topic}}"
}
}
2
3
4
5
# Data Templates
The data transfer between the memory action and the memory source is in internal format and is not coded or decoded for efficiency. Therefore, the format-related configuration items of the memory action are ignored, except for the data template. The memory action can support data templates to vary the result format, but the result of the data template must be in the object form of a JSON string, e.g. "{\"key\":\"{{.key}}\"}"
. JSON strings in the form of arrays or non-JSON strings are not supported.
# Updatable Sink
The memory sink support updatable. It is used to update the lookup table which subscribes to the same topic as the sink. A typical usage is to create a rule that use the updatable sink to accumulate the memory table. In below example, the data from stream alertStream will update the memory topic alertVal
. The action verb is specified by the action
field in the ingested data.
{
"id": "ruleUpdateAlert",
"sql":"SELECT * FROM alertStream",
"actions":[
{
"memory": {
"keyField": "id",
"rowkindField": "action",
"topic": "alertVal",
"sendSingle": true
}
}
]
}
2
3
4
5
6
7
8
9
10
11
12
13
14