logstasher

package module
v0.0.0-...-2eb915d Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 6, 2014 License: MIT Imports: 6 Imported by: 0

README

logstasher wercker status

GoDoc

logstasher is a Martini middleware that prints logstash-compatible JSON to an io.Writer for each HTTP request.

Here's an example from one of the Go microservices we have at @bikeexchange :

{
  "@timestamp":"2014-03-01T19:08:06+11:00","@version":1,"method":"GET",
  "path":"/locations/slugs/VIC/Williams-Landing","status":200,"size":238,
  "duration":14.059902000000001,"params":{"country":["au"]}
}

Used in conjunction with the rotating file writer it allows for rotatable logs ready to feed directly into logstash with no parsing.

Example
package main

import (
  "log"

  "github.com/codegangsta/martini"
  "github.com/mipearson/logstasher"
  "github.com/mipearson/rfw"
)

func main() {
  m := martini.Classic()

  logstashLogFile, err := rfw.Open("hello.log", 0644)
  if err != nil {
    log.Fatalln(err)
  }
  defer logstashLogFile.Close()
  m.Use(logstasher.Logger(logstashLogFile))

  m.Get("/", func() string {
    return "Hello world!"
  })
  m.Run()
}
## logstash.conf
input {
  file {
    path => ["hello.log"]
    codec => "json"
  }
}

Documentation

Overview

Package logstasher is a Martini middleware that prints logstash-compatiable JSON to a given io.Writer for each HTTP request.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Logger

func Logger(writer io.Writer) martini.Handler

Logger returns a middleware handler prints the request in a Logstash-JSON compatiable format

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL