0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-26 08:29:42 -05:00

Improve monitors monitor

This commit is contained in:
Andrey Antukh 2022-02-28 15:25:17 +01:00
parent 1bad233e2f
commit 5d2715dd32
3 changed files with 42 additions and 27 deletions

View file

@ -40,13 +40,14 @@
{:parallelism (cf/get :worker-executor-parallelism 10) {:parallelism (cf/get :worker-executor-parallelism 10)
:prefix :worker} :prefix :worker}
:app.worker/executors-monitor :app.worker/executors
{:executors {:default (ig/ref [::default :app.worker/executor])
{:default (ig/ref [::default :app.worker/executor]) :worker (ig/ref [::worker :app.worker/executor])
:blocking (ig/ref [::blocking :app.worker/executor]) :blocking (ig/ref [::blocking :app.worker/executor])}
:worker (ig/ref [::worker :app.worker/executor])}
:metrics (ig/ref :app.metrics/metrics)} :app.worker/executors-monitor
{:metrics (ig/ref :app.metrics/metrics)
:executors (ig/ref :app.worker/executors)}
:app.migrations/migrations :app.migrations/migrations
{} {}
@ -155,9 +156,7 @@
:msgbus (ig/ref :app.msgbus/msgbus) :msgbus (ig/ref :app.msgbus/msgbus)
:public-uri (cf/get :public-uri) :public-uri (cf/get :public-uri)
:audit (ig/ref :app.loggers.audit/collector) :audit (ig/ref :app.loggers.audit/collector)
:executors :executors (ig/ref :app.worker/executors)}
{:default (ig/ref [::default :app.worker/executor])
:blocking (ig/ref [::blocking :app.worker/executor])}}
:app.worker/worker :app.worker/worker
{:executor (ig/ref [::worker :app.worker/executor]) {:executor (ig/ref [::worker :app.worker/executor])

View file

@ -111,6 +111,12 @@
:labels ["name"] :labels ["name"]
:type :gauge} :type :gauge}
:executors-completed-tasks
{:name "penpot_executors_completed_tasks_total"
:help "Aproximate number of completed tasks by the executor."
:labels ["name"]
:type :counter}
:executors-running-threads :executors-running-threads
{:name "penpot_executors_running_threads" {:name "penpot_executors_running_threads"
:help "Current number of threads with state RUNNING." :help "Current number of threads with state RUNNING."

View file

@ -75,30 +75,40 @@
(s/keys :req-un [::executors ::mtx/metrics])) (s/keys :req-un [::executors ::mtx/metrics]))
(defmethod ig/init-key ::executors-monitor (defmethod ig/init-key ::executors-monitor
[_ {:keys [executors metrics interval] :or {interval 2500}}] [_ {:keys [executors metrics interval] :or {interval 3000}}]
(letfn [(log-stats [scheduler] (letfn [(log-stats [scheduler state]
(doseq [[key ^ForkJoinPool executor] executors] (doseq [[key ^ForkJoinPool executor] executors]
(let [labels (into-array String [(name key)])] (let [labels (into-array String [(name key)])
(mtx/run! metrics {:id :executors-active-threads active (.getActiveThreadCount executor)
:labels labels running (.getRunningThreadCount executor)
:val (.getPoolSize executor)}) queued (.getQueuedSubmissionCount executor)
(mtx/run! metrics {:id :executors-running-threads steals (.getStealCount executor)
:labels labels steals-increment (- steals (or (get-in @state [key :steals]) 9))
:val (.getRunningThreadCount executor)}) steals-increment (if (neg? steals-increment) 0 steals-increment)]
(mtx/run! metrics {:id :executors-queued-submissions
:labels labels (mtx/run! metrics {:id :executors-active-threads :labels labels :val active})
:val (.getQueuedSubmissionCount executor)}))) (mtx/run! metrics {:id :executors-running-threads :labels labels :val running})
(mtx/run! metrics {:id :executors-queued-submissions :labels labels :val queued})
(mtx/run! metrics {:id :executors-completed-tasks :labels labels :inc steals-increment})
(swap! state update key assoc
:running running
:active active
:queued queued
:steals steals)))
(when-not (.isShutdown scheduler) (when-not (.isShutdown scheduler)
(px/schedule! scheduler interval (partial log-stats scheduler))))] (px/schedule! scheduler interval (partial log-stats scheduler state))))]
(let [scheduler (px/scheduled-pool 1)] (let [scheduler (px/scheduled-pool 1)
(px/schedule! scheduler interval (partial log-stats scheduler)) state (atom {})]
scheduler))) (px/schedule! scheduler interval (partial log-stats scheduler state))
{::scheduler scheduler
::state state})))
(defmethod ig/halt-key! ::executors-monitor (defmethod ig/halt-key! ::executors-monitor
[_ instance] [_ {:keys [::scheduler]}]
(.shutdown ^ExecutorService instance)) (.shutdown ^ExecutorService scheduler))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Worker ;; Worker