# Logging conventions

etcd uses the [capnslog][capnslog] library for logging application output categorized into *levels*. A log message's level is determined according to these conventions:

* Error: Data has been lost, a request has failed for a bad reason, or a required resource has been lost
  * Examples:
    * A failure to allocate disk space for WAL

* Warning: (Hopefully) Temporary conditions that may cause errors, but may work fine. A replica disappearing (that may reconnect) is a warning.
  * Examples:
    * Failure to send raft message to a remote peer
    * Failure to receive heartbeat message within the configured election timeout

* Notice: Normal, but important (uncommon) log information.
  * Examples:
    * Add a new node into the cluster
    * Add a new user into auth subsystem

* Info: Normal, working log information, everything is fine, but helpful notices for auditing or common operations.
  * Examples:
    * Startup configuration
    * Start to do snapshot

* Debug: Everything is still fine, but even common operations may be logged, and less helpful but more quantity of notices.
  * Examples:
    * Send a normal message to a remote peer
    * Write a log entry to disk

[capnslog]: https://github.com/coreos/pkg/tree/master/capnslog