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

Кто может поделиться опытом наката долгих скриптов? Условния наката: 1 сервер

кликхауса, накат идет через liquibase. По времени наката пока ограничений нет, т.е. даже долгий накат одного скрипта сейчас возможен.
В идеале получить синхронный накат, чтобы скрипты отрабатывали последовательно.

Сейчас сделал отдельный профиль, для наката и там переопределил настройки
mutations_sync = 2
lock_acquire_timeout = 600

Один из примеров, таблица на 2-3кк строк, было создано несколько колонок с таймерами, теперь рещено их объединить в одну. Для этого надо скопировать старые значения с новую колонку.
ALTER TABLE events
UPDATE dutaion = event_timer
WHERE type = 'event_timer';

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

2 ответов

15 просмотров

alter table ничего не блокирует он просто ждет когда тред на мутацию в фоне выполнится объем данных прочитанный \ записанный при мутации зависит от WHERE мутация это принудительное перечитывание и перезаписывание всех партов в которых есть event_timer сколько у вас данных в таблице?

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
доброго времени. db, dw и прочие исполняются при трансляции или при выполнении программы?
lutayyy
10
Почему никто не подсказал, что можно объявить свои типы данных, в которых меньше полей, чем в отданном джейсоне, и добавлять их по необходимости?
Strange Rabbit
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Карта сайта