From 7a3ed18c89946f5566fdc6a28d6b3ee9064f9473 Mon Sep 17 00:00:00 2001 From: brusnitsyn Date: Tue, 16 Jun 2026 16:31:58 +0900 Subject: [PATCH] =?UTF-8?q?=D0=A3=D0=B2=D0=B5=D0=BB=D0=B8=D1=87=D0=B8?= =?UTF-8?q?=D0=BB=20=D0=B1=D1=83=D1=84=D1=84=D0=B5=D1=80=20=D0=B4=D0=BB?= =?UTF-8?q?=D1=8F=20=D0=BF=D1=80=D0=B5=D0=B4=D1=81=D1=82=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/Jobs/RefreshMaterializedViews.php | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/app/Jobs/RefreshMaterializedViews.php b/app/Jobs/RefreshMaterializedViews.php index 4d37c5a..63f1d96 100644 --- a/app/Jobs/RefreshMaterializedViews.php +++ b/app/Jobs/RefreshMaterializedViews.php @@ -30,9 +30,23 @@ class RefreshMaterializedViews implements ShouldQueue */ public int $timeout = 1800; + /** + * Размер temp_buffers на время обновления каждого представления. + */ + protected string $tempBuffers = '512MB'; + public function handle(): void { foreach ($this->views as $view) { + // CONCURRENTLY использует временные таблицы и local (temp) buffers для + // diff'а старых и новых данных. На больших представлениях стандартного + // temp_buffers (8MB) не хватает — PostgreSQL падает с "no empty local + // buffer available". temp_buffers можно изменить только до первого + // обращения к временным таблицам в сессии, поэтому под каждое + // представление берём свежее соединение и сразу поднимаем temp_buffers. + DB::reconnect(); + DB::statement("SET temp_buffers = '{$this->tempBuffers}'"); + // CONCURRENTLY не блокирует чтение представления во время обновления, // но требует наличия уникального индекса на представлении и не может // выполняться внутри транзакции (DB::statement работает в autocommit).