Project

General

Profile

Actions

Feature #1228

closed

Suricata stats.log in JSON format

Added by Andreas Moe about 10 years ago. Updated over 9 years ago.

Status:
Closed
Priority:
Normal
Assignee:
Target version:
Effort:
Difficulty:
Label:

Description

The suggestion is to be able to output the Suricata statistics (stats.log) in a format that is easily processed by other applications. This would make the viewing and use of the statistics easier and faster for the users. There could also be added a way to indicate what format and or level of detail that is wanted (ex: aggregating thread values at "low", write all possible data at "high")

Today:

- stats:
    enabled: yes
    filename: stats.log
    interval: 8
    append: yes/no

Possible future:

- stats:
    enabled: yes
    format: plain/json/bson/csv/...
    details: low/medium/high
    interval: 10
    append: yes/no

Actions #2

Updated by Andreas Moe almost 10 years ago

Started working on a branch for this. Just a simple stats.format key in the yaml file (as shown above), and using the current data available in the counters.c file. Using libjansson for the JSON creation. Any suggestions to JSON-Structure? I was thinking something like:

{
    "metadata": {
        "date": "21/10/2014",
        "uptime": {
            "days": 1,
            "hours": 2,
            "minutes": 3,
            "seconds": 4,
        },
    },
    "Counters": {
        "TM Name": {
            "counter": Value,
            "counter": Value,
            "counter": Value,
            "counter": Value
        },
        "TM Name": {
            "counter": Value,
            "counter": Value,
            "counter": Value,
            "counter": Value
        }
    }
}
Actions #3

Updated by Victor Julien almost 10 years ago

  • Target version set to 3.0RC2

Great that you want to have a look Andreas. However, quite a bit of code already exists here: https://github.com/inliniac/suricata/pull/1010

Actions #4

Updated by Andreas Moe almost 10 years ago

Ahh, didnt see that pull request. Looks like alot has been done. Is the wish for a Stats logger API (as you Victor commented on the pull request) what is stopping it from beeing merged or are there any other missing features / bugs?

Actions #5

Updated by Victor Julien almost 10 years ago

The stats logger api doesn't exist yet, so this will have to be created first.

Actions #6

Updated by Tom DeCanio almost 10 years ago

Andreas. I'd be happy to work with you to finish this. I was hoping that Victor would propose a stats logger api. I ran with what was there. Perhaps Victor can propose something and Andreas can help me implement it on top of what has been done already.

Actions #7

Updated by Victor Julien almost 10 years ago

The stats API implemented in https://github.com/inliniac/suricata/pull/1200 and Tom's JSON output based on that in https://github.com/inliniac/suricata/pull/1202

I'm not happy with the structure though. I've tried both Kibana and Graphite (fed by Logstash), but neither can easily take it in. One of the issues is that the "TM Name" is different for each capture method, capture config and runmode. So having a dashboard that works for all is going to be impossible, while this is normally the strength of our eve output.

When feeding Logstash to Graphite I found that it didn't really like the nesting (e.g. tcp:{syn:10} for counter tcp.syn). But when using the 'fields_are_metrics' option it didn't like the wrapping of it all in 'stats' either.

Minor disappointment was that Kibana 3 couldn't display multiple data series in the historam view (e.g. decoder.pkts and decoder.invalid), although this is likely to be added in Kibana 4.

So I think what we need is either different format that 'just works', or we should supply decent example configs for making good use of this in Kibana and/or Graphite.

Actions #8

Updated by Andreas Moe almost 10 years ago

Feature #490 looks at the issue of non-aggregated stats. Could (with the implementation you have given Victor) this be included now, by say a flag in the YAML (eg. aggregated yes/no) and sum up the similar counter values?

Actions #9

Updated by Victor Julien over 9 years ago

  • Status changed from New to Closed
  • Assignee set to Victor Julien
  • Target version changed from 3.0RC2 to 3.0RC1
  • % Done changed from 0 to 100
Actions

Also available in: Atom PDF