A port of github/statsd-ruby to Haskell.
- IPv4 and IPv6 support
- UDP statsd protocol
- Metric types
- Count
- Gauge
- Timing
- Histogram
- Collector clustering, stats are consistently routed using CRC32
- Packet signing using shared secret HMAC SHA256 signatures
$ irb -rsocket
irb(main):001:0> listener= UDPSocket.new.tap do |s|
irb(main):002:1* s.bind("127.0.0.1", 8126)
irb(main):003:1> end
=> #<UDPSocket:fd 9>
irb(main):004:0> loop do
irb(main):005:1* rd, _ = IO.select([listener])
irb(main):006:1> rd.each { |r| p [r, r.recvmsg] }
irb(main):007:1> end
import Network.Statsd
import Network.URI
-- error handling omitted
client <- (fromURI . fromJust . parseURI) "statsd://127.0.0.1:8126/prefix"
increment client "requests"
histogram client "numOfFilesCreated" 5
-- error handling omitted
client' <- (fromURI . fromJust . parseURI) "statsd://:[email protected]:8126/prefix"
increment client' "requests"
histogram client' "numOfFilesCreated" 5
Will result in these UDP packets being sent and received:
[#<UDPSocket:fd 9>, ["prefix.requests:1|c", #<Addrinfo: 127.0.0.1:64257 UDP>, 0]]
[#<UDPSocket:fd 9>, ["prefix.numOfFilesCreated:5|h", #<Addrinfo: 127.0.0.1:64257 UDP>, 0]]
[#<UDPSocket:fd 9>, ["\xD7\x8D?a9\xCB\xD5H\xFB\xA2?\xFE\x18\xFF9P\xB3\x9EY\e\xD9H\x86H\xEC\x84(N7B\xF7\x85\x04\\mV\x00\x00\x00\x00\x17\xFEq\x90prefix.requests:1|c", #<Addrinfo: 127.0.0.1:56756 UDP>, 0]]
[#<UDPSocket:fd 9>, ["A\x94\a\xBD\x8C9\x00\tU\xD0\x87\x8F\x9A\xCD\xC5\xA2l\xCA&\xA7T7\xEFT8\x9F\\b\xF7\xEB\x10\xD2\x06\\mV\x00\x00\x00\x00j\x86\xCD\xCBprefix.numOfFilesCreated:5|h", #<Addrinfo: 127.0.0.1:56756 UDP>, 0]]