There’s probably a better way to do everything I’m doing here.
Example config¶
   input {
    syslog {
        port => "2514"
        type => "generic"
    }
    tcp {
        port => "2515"
        type => "squid-access"
    }
}
filter {
    if [type] == 'squid-access' {
        grok {
          match => {
              "message" => "%{POSINT:timestamp}.%{WORD:timestamp_ms}\s+%{NUMBER:response_time} %{IPORHOST:src_ip} %{WORD:squid_request_status}/%{NUMBER:http_status_code} %{NUMBER:reply_size_include_header} %{WORD:http_method} %{NOTSPA
CE:request_url} %{NOTSPACE:user} %{WORD:squid}/%{IP:server_ip} %{NOTSPACE:content_type}"
          }
        }
    }
}
output {
    if [type] == 'generic' {
        elasticsearch {
            index => "logstash-%{+YYYY.MM.dd}"
        }
    }
    if [type] == 'squid-access' {
        elasticsearch {
            index => "squid-access"
        }
    }
}
dead_letter_queue¶
When using the dead_letter_queue input, use the following for the output to see the issue:
output {
  stdout {
    codec => rubydebug { metadata => true }
  }
}