This repository was archived by the owner on Dec 6, 2021. It is now read-only.
forked from XciD/k8s-rmq-autoscaler
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrmq.go
79 lines (64 loc) · 1.91 KB
/
rmq.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package main
import (
"encoding/json"
"errors"
"fmt"
"net/http"
)
type rmq struct {
URL string
User string
Password string
}
type queueStatSample struct {
Timestamp int32 `json:"timestamp"`
Sample int32 `json:"sample"`
}
type queueStatDetails struct {
Samples []queueStatSample `json:"samples"`
}
type queueMessageStats struct {
PublishDetails queueStatDetails `json:"publish_details"`
}
type queueResponse struct {
Consumers int32 `json:"consumers"`
Messages int32 `json:"messages"`
MessageStats queueMessageStats `json:"message_stats"`
}
func newRmq(rmqURL string, rmqUser string, rmqPassword string) (*rmq, error) {
if len(rmqURL) == 0 || len(rmqUser) == 0 || len(rmqPassword) == 0 {
return nil, errors.New("missing rmq information")
}
return &rmq{
URL: rmqURL,
User: rmqUser,
Password: rmqPassword,
}, nil
}
func (rmq *rmq) getQueueInformation(queue string, vhost string, cooldown int32) (int32, int32, int32, error) {
client := &http.Client{}
var statsAge int32
statsAge = max(cooldown, 1)
req, err := http.NewRequest("GET", fmt.Sprintf("%s/api/queues/%s/%s?columns=messages,consumers,message_stats.publish_details&msg_rates_age=%d&msg_rates_incr=%d", rmq.URL, vhost, queue, statsAge, statsAge), nil)
if err != nil {
return 0, 0, 0, err
}
req.SetBasicAuth(rmq.User, rmq.Password)
resp, err := client.Do(req)
if err != nil {
return 0, 0, 0, err
}
if resp.StatusCode != 200 {
return 0, 0, 0, errors.New(resp.Status)
}
defer resp.Body.Close()
var data queueResponse
json.NewDecoder(resp.Body).Decode(&data)
var messagesPublished int32
if cooldown == 0 || len(data.MessageStats.PublishDetails.Samples) < 2 {
messagesPublished = 0
} else {
messagesPublished = data.MessageStats.PublishDetails.Samples[0].Sample - data.MessageStats.PublishDetails.Samples[1].Sample
}
return data.Consumers, data.Messages, messagesPublished, nil
}