2021-05-25 09:27:45 -04:00
|
|
|
let listenInBackground, sendPings
|
|
|
|
const redis = require('@overleaf/redis-wrapper')
|
|
|
|
const rclient1 = redis.createClient({
|
|
|
|
cluster: [
|
|
|
|
{
|
|
|
|
port: '7000',
|
|
|
|
host: 'localhost'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
2017-05-04 06:14:17 -04:00
|
|
|
|
2021-05-25 09:27:45 -04:00
|
|
|
const rclient2 = redis.createClient({
|
|
|
|
cluster: [
|
|
|
|
{
|
|
|
|
port: '7000',
|
|
|
|
host: 'localhost'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
2017-05-04 06:14:17 -04:00
|
|
|
|
2021-05-25 09:27:45 -04:00
|
|
|
let counter = 0
|
|
|
|
const sendPing = function (cb) {
|
|
|
|
if (cb == null) {
|
|
|
|
cb = function () {}
|
|
|
|
}
|
|
|
|
return rclient1.rpush('test-blpop', counter, (error) => {
|
|
|
|
if (error != null) {
|
|
|
|
console.error('[SENDING ERROR]', error.message)
|
|
|
|
}
|
|
|
|
if (error == null) {
|
|
|
|
counter += 1
|
|
|
|
}
|
|
|
|
return cb()
|
|
|
|
})
|
|
|
|
}
|
2017-05-04 06:14:17 -04:00
|
|
|
|
2021-05-25 09:27:45 -04:00
|
|
|
let previous = null
|
|
|
|
const listenForPing = (cb) =>
|
|
|
|
rclient2.blpop('test-blpop', 200, (error, result) => {
|
|
|
|
if (error != null) {
|
|
|
|
return cb(error)
|
|
|
|
}
|
2021-05-25 09:32:03 -04:00
|
|
|
let [, value] = Array.from(result)
|
2021-05-25 09:27:45 -04:00
|
|
|
value = parseInt(value, 10)
|
|
|
|
if (value % 10 === 0) {
|
|
|
|
console.log('.')
|
|
|
|
}
|
|
|
|
if (previous != null && value !== previous + 1) {
|
|
|
|
error = new Error(
|
|
|
|
`Counter not in order. Got ${value}, expected ${previous + 1}`
|
|
|
|
)
|
|
|
|
}
|
|
|
|
previous = value
|
|
|
|
return cb(error, value)
|
|
|
|
})
|
2017-05-04 06:14:17 -04:00
|
|
|
|
2021-05-25 09:27:45 -04:00
|
|
|
const PING_DELAY = 100
|
|
|
|
;(sendPings = () => sendPing(() => setTimeout(sendPings, PING_DELAY)))()
|
|
|
|
;(listenInBackground = () =>
|
2021-05-25 09:32:03 -04:00
|
|
|
listenForPing((error) => {
|
2021-05-25 09:27:45 -04:00
|
|
|
if (error) {
|
|
|
|
console.error('[RECEIVING ERROR]', error.message)
|
|
|
|
}
|
|
|
|
return setTimeout(listenInBackground)
|
|
|
|
}))()
|