Reputation: 768
I'm using elasticsearch and kibana for storing my logs. Now what I want is to extract a number from a field and store it a new field.
So for instance, having this:
accountExist execution time: 1046 ms
I would like to extract the number (1046) and see it in a new field in kibana.
Is it possible? how? Thanks for the help
Upvotes: 19
Views: 16176
Reputation: 5242
While not performant, if you must avoid reindexing, you could use scripted fields in kibana.
Introduction here: https://www.elastic.co/blog/using-painless-kibana-scripted-fields
script.painless.regex.enabled: true
def logMsg = params['_source']['log_message']; if(logMsg == null) { return -10000; } def m = /.*accountExist execution time: ([0-9]+) ms.*$/.matcher(params['_source']['log_message']); if ( m.matches() ) { return Integer.parseInt(m.group(1)) } else { return -10000 }
While I do understand, that it is not performant to script fields for millions of log entries, my usecase is a very specific log entry, that is logged 10 times a day in total and I only use the resulting fields to create a visualization or in analysis where I reduce the candidates through regular queries in advance.
Would be interesing if it is possible to have those fields only be calculated in situations where you need them (or they make sense & are computable to begin with; i.e. to make the "return -1000" unnecessary). Currently they will be applied and show up for every log entry.
You can generate scripted fields inside of queries like this: https://www.elastic.co/guide/en/elasticsearch/reference/current/search-request-script-fields.html but that seems a bit too much of burried under the hood, to maintain easily :/
Upvotes: 4
Reputation: 3209
You'll need to do this before/during indexing.
Within Elasticsearch, you can get what you need during indexing:
The Analyze API can be helpful for testing purposes.
Upvotes: 10