169 похожих чатов

Поправьте меня если я не прав, но современные реалии масштабирования

средней руки это добавь контейнер - убери контейнер. какая разница что внутри? Эликсир там или го. чтобы масштабировать эликсир way нужно добавлять ноды... а в данном случае контейнер = нода

10 ответов

8 просмотров

На бумажке оно так красиво и звучит, но проблема с состоянием на сервере решается не очень тривиально, и добавить/убрать контейнер тут будет не очень просто Да и потом, языки всё-таки несут какие-то фичи в себе. Например, в эликсире есть прерывания в многозадачности. В голанге такого нет, и рутины могут повиснуть надолго при сборке мусора

Drilla-_ Автор вопроса
Lama Lover
На бумажке оно так красиво и звучит, но проблема с...

состояние - имеешь ввиду непонятно когда контейнер нужно перезапустить если он повис?

Drilla _
состояние - имеешь ввиду непонятно когда контейнер...

Имею в виду, например, открытые соединения, состояния вебсокетов, какие-нибудь интерактивные вещи, которые в раме лежат

Drilla-_ Автор вопроса
Drilla _
и как сейчас решают это?

Какие-нибудь алгоритмы синхронизации данных. Это могут быть и неконфликтные структуры данных, это могут быть консенсусы, это могут быть мастер/слейв репликации и так далее

Nekotari殿
Расист! Расист!!!!

при чем тут расизм? это бдсм терминология

Lama Lover
На бумажке оно так красиво и звучит, но проблема с...

Вроде бы в го конкурентный сборщик мусора настроенный на low latency, и подвиснуть надолго он может только если этот мусор ну очень старательно плодить.

Sergey
Вроде бы в го конкурентный сборщик мусора настроен...

Так можно сказать про любой сборщик мусора. В голанге, например, всё ещё нет защиты от неаккуратного использования shared memory (даже unsafe-а растового нет). Поэтому сборка мусора тут STW и довольно жирная. То, что она low latency это какое-то странно утверждение. Зная алгоритм сборки мусора в голанге, могу сказать что это точно не самый эффективный и быстрый алгоритм сборки мусора: какие-нибудь jvm и .net в этом плане сильно эффективнее

Lama Lover
На бумажке оно так красиво и звучит, но проблема с...

На практике, в Go же оптимизированный GC, заостренный на минимальные прерывания, так что вопрос - какое количество реальных сервисов на Go - с зависшеми рутинами встречаются, как и с тормозящим GC. Т.е. Не смотря на теоретическую возможность и скорее всего не частые случаи (предположение) - вопрос, насколько эта проблема реально часто встречается. К примеру, у меня мой друг работает на Go - так он каждый раз с удивлением на меня смотрит, когда я ему говорю про stop the world GC или про зависшую гоурутину. Потому что на их высоко-нагруженном сервисе - такое за много лет ни разу не встречалось.

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Привет, не могли бы подсказать почему "A tree falls in a forest" не отображается в journalctl? openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1); syslog (LO...
•_• Asmanov 🎓
3
Карта сайта