У меня есть конфигурация наблюдателя следующим образом:
{
"trigger": {
"schedule": {
"interval": "5s"
}
},
"input" : {
"search" : {
"request" : {
"indices" : [ "my_index" ],
"types" : [ "my_type" ],
"body" : {
"query" : {
"match_all" : {}
}
}
}
}
},
"transform" : {
"script" : "return [ body: groovy.json.JsonOutput.toJson(ctx.payload.hits.hits)]"
},
"actions" : {
"hbase_webhook" : {
"webhook" : {
"method" : "POST",
"host" : "<some_ip>",
"port" : <some_port>,
"path": "/v0.1/_events",
"body" : "data: {{ctx.payload.body}}"
}
}
}
}
Данные, размещенные в теле, не являются допустимым JSON: что-то вроде:
{ 'data: ': { '{"_index":"my_index","_type":"my_type","_source":{"key":"val"}},"_id":"<some_id>","_score":1.0}': '' } }
Я не знаю, как анализировать этот вывод, поскольку JSON.parse в Node.js все равно не будет правильно анализировать его.
{ '{"_index":"<some_index>","_type":"<some_type>","_source":{"<some_key>":"<some_value>", ...},"_id":"<doc_id>","_score":1.0}': '' }
, где данные — это ключ, а значение —''
. Если ни один документ не соответствует, это{ '0': '' }
. Какие-нибудь мысли? Я думаю, что я приближаюсь, хотя :) - person Hasan Can Saral   schedule 28.05.2016