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

Подскажите а в tarantool 1.10 (memtx) before_replace приводит к новой

записи в WAL если мы вернули старое значение или нет? То есть станет ли это изменение локальным или также раскатится по всем нодам? А в версии 2 что-то поменяется?

1 ответов

7 просмотров

*_replace исполняется до записи в wal вообще, он ловит транзакцию за хвост и позволяет все перевернуть вверх дном. если в before_replace вернуть старое значение, то операция транзакции превратится в NOP. раскатится оно по нодам или нет, зависит только от ее пары replica_id/lsn. если оригинально транзакция стартанула с текущей ноды — то на других нодах ее нет, и на все ноды раскатится операция NOP, если транзакция прилетела по репликации, то на другой ноде она уже есть, и на эту ноду-источник не вернётся. за исключением ситуации, когда нода-источник транзакции, грохнулась, ей отрезали хвост ее журнала, тогда она пойдет стягивать свои транзакции со своих реплик.

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

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

А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Нужен пулл реквест с хаммингберд + асинкхттпклиент или хаммингберд + юрлсессия?
Karl {🌪️}{🐊} Shinobi
7
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
5
может там как раз сжатие?
Дмитрий
7
Как структуру (из MSVC) в которой описаны битовые поля описать для fasm? Вот например это (fBinary...fDummy2 - это физически 1 DWORD): typedef struct _DCB { DWORD DCBlength;...
Евгений
3
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
9
Карта сайта