/
nats.go
53 lines (43 loc) · 1.33 KB
/
nats.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
package infra
import (
"time"
"github.com/nats-io/nats.go"
"github.com/rs/zerolog/log"
"exusiai.dev/backend-next/internal/app/appconfig"
)
func NATS(conf *appconfig.Config) (*nats.Conn, nats.JetStreamContext, error) {
errorHandler := func(conn *nats.Conn, sub *nats.Subscription, err error) {
log.Error().
Str("evt.name", "nats.error").
Err(err).
Str("conn.url", conn.ConnectedUrlRedacted()).
Str("sub.subject", sub.Subject).
Msg("nats error")
}
nc, err := nats.Connect(conf.NatsURL, nats.PingInterval(time.Second*20), nats.ErrorHandler(errorHandler))
if err != nil {
log.Error().Err(err).Msg("infra: nats: failed to connect to NATS")
return nil, nil, err
}
js, err := nc.JetStream(nats.PublishAsyncMaxPending(2 << 11))
if err != nil {
log.Error().Err(err).Msg("infra: nats: failed to initialize NATS JetStream")
return nil, nil, err
}
_, err = js.AddStream(&nats.StreamConfig{
Name: "penguin-reports",
Subjects: []string{
"REPORT.*",
},
Retention: nats.WorkQueuePolicy,
Discard: nats.DiscardOld,
Storage: nats.FileStorage,
Replicas: 1,
Duplicates: time.Minute * 10,
})
// MaxAckPending should equal to (worker count * worker channel buffer size)
if err != nil {
log.Warn().Err(err).Msg("infra: nats: failed to create jetstream stream: is it already created?")
}
return nc, js, nil
}