-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
47 lines (40 loc) · 1004 Bytes
/
index.js
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
import {Counter} from 'prom-client'
import {createMetricsServer, register} from './lib/metrics.js'
import {createLogger} from './lib/logger.js'
import {connectToNats} from './lib/nats.js'
import {runGtfsMatching} from './lib/match.js'
import {withSoftExit} from './lib/soft-exit.js'
const logger = createLogger('service')
const abortWithError = (err) => {
logger.error(err)
process.exit(1)
}
const natsLogger = createLogger('nats')
const {
natsClient,
natsJetstreamClient,
natsJetstreamManager,
} = await connectToNats({
logger: natsLogger,
})
const metricsServer = createMetricsServer()
metricsServer.start()
.then(() => {
logger.info(`serving Prometheus metrics on port ${metricsServer.address().port}`)
}, abortWithError)
// todo: expose health check!
// - check if DB looks good
try {
await runGtfsMatching({
logger,
natsClient,
natsJetstreamClient,
natsJetstreamManager,
})
withSoftExit(() => {
natsClient.drain()
})
} catch (err) {
logger.error(err)
process.exit(1)
}