# exometer_statix

StatsD reporter backend for exometer_core Edit

## Installation

If [available in Hex](, the package can be installed
by adding `exometer_statix` to your list of dependencies in `mix.exs`:

def deps do
  [{:exometer_statix, "~> 0.1.0"}]

## How to use

prefix           = :myapp
polling_interval = 1_000
memory_stats     = ~w(atom binary ets processes total)a
reporter         = Elixir.ExometerStatix
reporter_opts    = [port: 9125, prefix: prefix]

config :exometer_core,
  predefined: [
    {~w(erlang memory)a, {:function, :erlang, :memory, [], :proplist, memory_stats}, []},
    {~w(erlang statistics)a, {:function, :erlang, :statistics, [:'$dp'], :value, [:run_queue]}, []},
  report: [
    reporters: [{reporter, reporter_opts}],
    subscribers: [
      {reporter, [:erlang, :memory], memory_stats, polling_interval, true},
      {reporter, [:erlang, :statistics], :run_queue, polling_interval, true},

config :elixometer,
  reporter: reporter,
  update_frequency: polling_interval,
  env: Mix.env,
  metric_prefix: prefix

### Logger setting

Exometer depends on lager. To unify logging in a elixir project, you can use [lagger_logger]( or [logger_lager_backend](

config :logger, :console,
  format: "$time $metadata[$level] $message\n",
  metadata: [:request_id, :application, :module, :function, :file, :line]

config :lager, :error_logger_redirect, false
config :lager, :error_logger_whitelist, [Logger.ErrorHandler]
config :lager, :crash_log, false
config :lager, :handlers, [{LagerLogger, [level: :info]}]

Documentation can be generated with [ExDoc](
and published on [HexDocs]( Once published, the docs can
be found at [](