mirror of
https://github.com/hibiken/asynqmon.git
synced 2025-01-19 03:05:53 +08:00
Add API endpoint for listing running servers
This commit is contained in:
parent
1f3897c570
commit
d78abcf584
@ -285,3 +285,57 @@ func toSchedulerEnqueueEvents(in []*asynq.SchedulerEnqueueEvent) []*SchedulerEnq
|
|||||||
}
|
}
|
||||||
return out
|
return out
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ServerInfo struct {
|
||||||
|
ID string `json:"id"`
|
||||||
|
Host string `json:"host"`
|
||||||
|
PID int `json:"pid"`
|
||||||
|
Concurrency int `json:"concurrency"`
|
||||||
|
Queues map[string]int `json:"queue_priorities"`
|
||||||
|
StrictPriority bool `json:"strict_priority_enabled"`
|
||||||
|
Started string `json:"start_time"`
|
||||||
|
Status string `json:"status"`
|
||||||
|
ActiveWorkers []*WorkerInfo `json:"active_workers"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func toServerInfo(info *asynq.ServerInfo) *ServerInfo {
|
||||||
|
return &ServerInfo{
|
||||||
|
ID: info.ID,
|
||||||
|
Host: info.Host,
|
||||||
|
PID: info.PID,
|
||||||
|
Concurrency: info.Concurrency,
|
||||||
|
Queues: info.Queues,
|
||||||
|
StrictPriority: info.StrictPriority,
|
||||||
|
Started: info.Started.Format(time.RFC3339),
|
||||||
|
Status: info.Status,
|
||||||
|
ActiveWorkers: toWorkerInfoList(info.ActiveWorkers),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func toServerInfoList(in []*asynq.ServerInfo) []*ServerInfo {
|
||||||
|
out := make([]*ServerInfo, len(in))
|
||||||
|
for i, s := range in {
|
||||||
|
out[i] = toServerInfo(s)
|
||||||
|
}
|
||||||
|
return out
|
||||||
|
}
|
||||||
|
|
||||||
|
type WorkerInfo struct {
|
||||||
|
Task *ActiveTask `json:"task"`
|
||||||
|
Started string `json:"start_time"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func toWorkerInfo(info *asynq.WorkerInfo) *WorkerInfo {
|
||||||
|
return &WorkerInfo{
|
||||||
|
Task: toActiveTask(info.Task),
|
||||||
|
Started: info.Started.Format(time.RFC3339),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func toWorkerInfoList(in []*asynq.WorkerInfo) []*WorkerInfo {
|
||||||
|
out := make([]*WorkerInfo, len(in))
|
||||||
|
for i, w := range in {
|
||||||
|
out[i] = toWorkerInfo(w)
|
||||||
|
}
|
||||||
|
return out
|
||||||
|
}
|
||||||
|
3
main.go
3
main.go
@ -112,6 +112,9 @@ func main() {
|
|||||||
api.HandleFunc("/queues/{qname}/dead_tasks:run_all", newRunAllDeadTasksHandlerFunc(inspector)).Methods("POST")
|
api.HandleFunc("/queues/{qname}/dead_tasks:run_all", newRunAllDeadTasksHandlerFunc(inspector)).Methods("POST")
|
||||||
api.HandleFunc("/queues/{qname}/dead_tasks:batch_run", newBatchRunTasksHandlerFunc(inspector)).Methods("POST")
|
api.HandleFunc("/queues/{qname}/dead_tasks:batch_run", newBatchRunTasksHandlerFunc(inspector)).Methods("POST")
|
||||||
|
|
||||||
|
// Servers endpoints.
|
||||||
|
api.HandleFunc("/servers", newListServersHandlerFunc(inspector)).Methods("GET")
|
||||||
|
|
||||||
// Scheduler Entry endpoints.
|
// Scheduler Entry endpoints.
|
||||||
api.HandleFunc("/scheduler_entries", newListSchedulerEntriesHandlerFunc(inspector)).Methods("GET")
|
api.HandleFunc("/scheduler_entries", newListSchedulerEntriesHandlerFunc(inspector)).Methods("GET")
|
||||||
api.HandleFunc("/scheduler_entries/{entry_id}/enqueue_events", newListSchedulerEnqueueEventsHandlerFunc(inspector)).Methods("GET")
|
api.HandleFunc("/scheduler_entries/{entry_id}/enqueue_events", newListSchedulerEnqueueEventsHandlerFunc(inspector)).Methods("GET")
|
||||||
|
34
server_handlers.go
Normal file
34
server_handlers.go
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/hibiken/asynq"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ****************************************************************************
|
||||||
|
// This file defines:
|
||||||
|
// - http.Handler(s) for server related endpoints
|
||||||
|
// ****************************************************************************
|
||||||
|
|
||||||
|
type ListServersResponse struct {
|
||||||
|
Servers []*ServerInfo `json:"servers"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func newListServersHandlerFunc(inspector *asynq.Inspector) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
srvs, err := inspector.Servers()
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
resp := ListServersResponse{
|
||||||
|
Servers: toServerInfoList(srvs),
|
||||||
|
}
|
||||||
|
if err := json.NewEncoder(w).Encode(resp); err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user