Exporting statistics via Carbon

Setting up a carbon export

To emit metrics to Graphite, or any other software supporting the Carbon protocol, use:

carbonServer('ip-address-of-carbon-server', 'ourname', 30, 'dnsdist', 'main')

Where ourname can be used to override your hostname, and 30 is the reporting interval in seconds. dnsdist and main are used as namespace and instance variables. For querycount statistics these two variables are currently ignored. The last four arguments can be omitted. The latest version of PowerDNS Metronome comes with attractive graphs for dnsdist by default.

The equivalent yaml configuration:

metrics:
  carbon:
    - address: "ip-address-of-carbon-server"
      name: "ourname"
      interval: "30"
      namespace: "dnsdist"
      instance: "main"

Query counters

In addition to other metrics, it is possible to send per-records statistics of the amount of queries by using setQueryCount(). With query counting enabled, dnsdist will increase a counter for every unique record or the behaviour you define in a custom Lua function by setting setQueryCountFilter(). This filter can decide whether to keep count on a query at all or rewrite for which query the counter will be increased. An example of a QueryCountFilter would be:

function filter(dq)
  qname = dq.qname:toString()

  -- don't count PTRs at all
  if(qname:match('in%-addr.arpa$')) then
    return false, ""
  end

  -- count these queries as if they were queried without leading www.
  if(qname:match('^www.')) then
    qname = qname:gsub('^www.', '')
  end

  -- count queries by default
  return true, qname
end

setQueryCountFilter(filter)

Valid return values for QueryCountFilter functions are:

  • true: count the specified query
  • false: don’t count the query

Note that the query counters are buffered and flushed each time statistics are sent to the carbon server. The current content of the buffer can be inspected with :getQueryCounters(). If you decide to enable query counting without carbonServer(), make sure you implement clearing the log from maintenance() by issuing clearQueryCounters().