mirror of https://github.com/status-im/timbre.git
Merge branch 'mongo' of github.com:emlyn/timbre into emlyn-mongo
This commit is contained in:
commit
634223bdbc
12
README.md
12
README.md
|
@ -171,6 +171,18 @@ netcat localhost 9000
|
||||||
(timbre/set-config! [:shared-appender-config :socket]
|
(timbre/set-config! [:shared-appender-config :socket]
|
||||||
{:listen-addr :all
|
{:listen-addr :all
|
||||||
:port 9000})
|
:port 9000})
|
||||||
|
|
||||||
|
#### MongoDB ([congomongo](https://github.com/aboekhoff/congomongo)) appender
|
||||||
|
|
||||||
|
```clojure
|
||||||
|
;; [congomongo "0.4.1"] ; Add to project.clj dependencies
|
||||||
|
;; (:require [taoensso.timbre.appenders (mongo :as mongo-appender)]) ; Add to ns
|
||||||
|
|
||||||
|
(timbre/set-config! [:appenders :mongo] mongo-appender/mongo-appender)
|
||||||
|
(timbre/set-config! [:shared-appender-config :mongo]
|
||||||
|
{:db "logs"
|
||||||
|
:collection "myapp"
|
||||||
|
:server {:host "127.0.0.1" :port 27017}})
|
||||||
```
|
```
|
||||||
|
|
||||||
### Custom appenders
|
### Custom appenders
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
(ns taoensso.timbre.appenders.mongo
|
||||||
|
"MongoDB appender. Depends on https://github.com/aboekhoff/congomongo."
|
||||||
|
{:author "Emlyn Corrin"}
|
||||||
|
(:require [somnium.congomongo :as mongo]))
|
||||||
|
|
||||||
|
(def conn (atom nil))
|
||||||
|
|
||||||
|
(def default-args {:host "127.0.0.1" :port 27017})
|
||||||
|
|
||||||
|
(defn connect [{:keys [db server write-concern]}]
|
||||||
|
(let [args (merge default-args server)
|
||||||
|
c (mongo/make-connection db args)]
|
||||||
|
(when write-concern
|
||||||
|
(mongo/set-write-concern c write-concern))
|
||||||
|
c))
|
||||||
|
|
||||||
|
(defn ensure-conn [config]
|
||||||
|
(swap! conn #(or % (connect config))))
|
||||||
|
|
||||||
|
(defn log-message [params {:keys [collection logged-keys]
|
||||||
|
:as config}]
|
||||||
|
(let [selected-params (if logged-keys
|
||||||
|
(select-keys params logged-keys)
|
||||||
|
(dissoc params :ap-config))
|
||||||
|
logged-params (if-let [t (:throwable selected-params)]
|
||||||
|
(assoc selected-params :throwable (str t))
|
||||||
|
selected-params)]
|
||||||
|
(mongo/with-mongo (ensure-conn config)
|
||||||
|
(mongo/insert! collection logged-params))))
|
||||||
|
|
||||||
|
(defn appender-fn [{:keys [ap-config] :as params}]
|
||||||
|
(when-let [mongo-config (:mongo ap-config)]
|
||||||
|
(log-message params mongo-config)))
|
||||||
|
|
||||||
|
(def mongo-appender
|
||||||
|
{:doc (str "Logs to MongoDB using congomongo.\n"
|
||||||
|
"Needs :mongo config map in :shared-appender-config, e.g.:
|
||||||
|
{:db \"logs\"
|
||||||
|
:collection \"myapp\"
|
||||||
|
:logged-keys [:instant :level :message]
|
||||||
|
:write-concern :acknowledged
|
||||||
|
:server {:host \"127.0.0.1\"
|
||||||
|
:port 27017}}")
|
||||||
|
:min-level :warn :enabled? true :async? true
|
||||||
|
:max-message-per-msecs 1000 ; 1 entry / sec
|
||||||
|
:fn appender-fn})
|
Loading…
Reference in New Issue