Уже лучше, теперь дальше - как выглядит коннектор к реббиту?

если он из переменных окружения берет реквизиты - то покажите их

25 ответов

82 просмотра

async waitForConnection(interval = 1000, maxRetry) { console.log('... connecting to Queue ...') if (maxRetry > 0) { if (this.retry > maxRetry) { throw new Error('Exceeded Max Retry. Exiting ...') } this.retry++ } try { await this.connect() console.log('... connected to Queue ...') } catch (err) { console.log('Could not connect to Queue, retrying...') await this.wait(interval) await this.waitForConnection(maxRetry) } } async wait(time) { return new Promise((resolve) => setTimeout(resolve, time)) } async connect() { // connect to rabbitmq this.connection = await amqplib.connect(this.connectionString) // create connection this.channel = await this.connection.createChannel() // create exchange await this.channel.assertExchange(this.exchangeName, this.exchangeType, { durable: this.exchangeDurable, }) // create queue await this.channel.assertQueue(this.queueName, { durable: this.queueDurable, }) // set prefetch count this.channel.prefetch(this.prefetchCount) // bind queue to exchange await this.channel.bindQueue( this.queueName, this.exchangeName, this.routingKey ) return null } создание коннекта let RmqNotifications = await RMQConn({ exchangeType: 'direct', exchangeName: 'notifications', queueName: 'notifications', routingKey: 'notifications', })

Aleksey-Barabanov Автор вопроса
Aleksey Barabanov
connectionString как выглядит?

const connectionString = `amqp://${user}:${pass}@${host}:${port}` из ENV данные

module.exports.RMQConn = async function (initObj) { try { if (!instance) { instance = new QueueClient(initObj) await instance.waitForConnection(1000) } return instance } catch (err) { console.log(err.message) } } создание коннекта let RmqNotifications = await RMQConn({ exchangeType: 'direct', exchangeName: 'notifications', queueName: 'notifications', routingKey: 'notifications', })

хм.. странно. Думал что если сеть отваливается amqplib в on disconnect сообщить должна об этом, а вот выходит что нифига не так.. но я понял, пойду переписывать

вот такое есть this.connection.on('connect', () => { console.log('Connected!') }) this.connection.on('disconnect', (params) => { console.log('Disconnected: ', params.err) }) this.connection.on('connectFailed', (params) => { console.log('connectFailed: ', params) }) this.connection.on('unblocked', () => { console.log('Unblocked') }) this.connection.on('blocked', (params) => { console.log('Blocked, reason: ', params.reason) })

Vadim
А что за либа?

черт, сори, я перепутал либы )))) думал такое есть в amqplib, а он оесть только в amqp-connection-manager наверное ее проще заюзать будет, чем с нуля писать

а с чем это связано? разрушение каналов имею ввиду архитектура самого кролика? или внешние факторы?

Алекс
а с чем это связано? разрушение каналов имею ввиду...

С сетью, с опоздавшими хэртбитами, с проксей, если она стоит перед кроликом, с протоколом (например, если произошло исключение в процессе работы с каналом, то с ним уже ничего сделать нельзя).

А куда деваться, это нода, там единственный рекомендуемый клиент и тот без 1.0 версии в 2024м

Ну нода в целом в плане экосистемы по нулям

Владислав Килин
Ну нода в целом в плане экосистемы по нулям

Есть там и свои либы, аналогов которым нет. Скажем, лучше, чем жс, мы не нашли либы для рендера пдф, работы с браузером и даже для работы с smpp (не smtp).

Vadim
Есть там и свои либы, аналогов которым нет. Скажем...

На дотнетике есть божественные либы для пдф, даже в годы до неткора. Но может у вас конечно особые кейсы были

Владислав Килин
И зря!)

Да ну, он же специфический. Только под винду работает(л) (или уже нет?). Там только NServiceBus крутой, как я знаю, многие по нему джавовские либы пилили.

Похожие вопросы

Обсуждают сегодня

Кажется сломалась сборка в докере docker run --pull always --rm -it registry.werf.io/werf/werf:2-stable werf version ...
Evgeniy Medvedev
1
Гайс, я кажется багу нашел в v2.8.0, хуки себя ведут не ожидаемо (на верф 1.2 корректно все) Есть чарт Ingress Nginx controller (https://github.com/kubernetes/ingress-nginx/tr...
Danil Ivanov
3
Коллеги, здравствуйте. Подскажите пожалуйста. Используем версию werf v2.6.3. И стали у нас выходить в консоли вот такие "WARNINGS" как их отключить вообще? └ Adding custom ta...
vⱥ𝖉iϻ ϻⱥlͥтsͣeͫv♛
1
Вопросик. Вернее вопросище))) ситуация. Ажур девопс, большая репа, внешние агенты с так себе интернетом, качаю репозиторий запускаю верф, а верф опять качает репозиторий в сво...
Alex Подрябинкин
3
гайс, еще один вопрос 😄 с переходом на 2 верф - след релиз хистори на верф 2 раздувается минимум на 50кб, то есть выкат на 1.2 - релиз хистори около 950кб, а с миграцией - уж...
Danil Ivanov
1
Доброго времени суток, можно ли запустить werf compose up через podman? Error: exec: "docker": executable file not found in $PATH ловлю такую ошибку
Andrey🏔
9
Всем привет, подскажите или скиньте документацию, не смог найти что-то, как мне корректно зашифровать ssh priv в values-secret ?
Artem Drozdow
1
Ребят, привет. Вопрос: есть максимально простой werf.yaml: project: airbyte configVersion: 1 и Chart.yaml: apiVersion: v2 name: airbyte type: application version: 0.293...
Vasily Safronov
7
есть какие то именованные теги, типа registry.werf.io/werf/werf:v2.6.1 ??
Evgeniy Medvedev
1
всем привет, прочитал что в werf 1.2 есть SSA, он включен по умолчанию?
Alexandr Alexandr
2
Карта сайта