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

Доброго вечера, в чате для новичков мне никто не ответил,

может гуру подскажут. Есть одна очень большая транзакция с разными upsert (их много) и update (парочка) в моделях. Мне очень важно ее либо выполнить, либо откатить. Я делаю так:

retry(50, function () use ($task) {
DB::beginTransaction(); // Начало транзакции

try {
// Код с запросами upsert и update по моделям

DB::commit(); // Фиксация изменений
} catch (\Exception $e) {
DB::rollback(); // Откат изменений в случае ошибки
}
}, function ($attempt) {
return $attempt * 1000;
});

В итоге в логе вижу ошибку:
local.ERROR: There is already an active transaction {"exception":"[object] (PDOException(code: 0): There is already an active transaction

Спросите, почему так много retry - потому что получал часто mysql server has gone away.

Что посоветовали бы? Транзакцию необходимо гарантированно выполнить.

4 ответов

25 просмотров

Может, для начала разобраться с gone away?

Dimases- Автор вопроса
Артём
Может, для начала разобраться с gone away?

Идея хорошая, только с чего начать? Там реально большая нагрузка по запросам может быть. Не факт, что vds позволяет больше.

Dimases
Идея хорошая, только с чего начать? Там реально бо...

Значит, пора съезжать с VDS и масшабироваться

Dimases- Автор вопроса

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

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

Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
лучше скажите, причём тут паскаль?
Alexey Kulakov
22
Вопрос на перед, на следующую пятницу. Сколько строк кода можно вешать на одного программиста, понятно что если проект хорошо написан то можно и миллион. Но есть же где то пре...
AlekseyK Kluchnikov
31
Немного оффтопа: а кто на чем сидит для осдева в плане ide/редактора? Последнее время сидел на vscode, но я его прям не могу нормально воспринимать, перешел на сlion, но меня...
Evg Resh
29
#include <stdio.h> #include <stdlib.h> #include <time.h> int** generate_table(int size_matrix) { int** matrix = (int**)malloc(size_matrix * sizeof(int*)); for (int i ...
Чувак
1
@PerlBanjoBot use v5.38; sub split_on_cond($arr, $cond) { ($a, $b) = ([], []); push @{ $cond->($_) ? $a : $b }, $_ for @$arr; ($a, $b) } use Data::Dumper; warn Dumpe...
Sergei Zhmylove
10
Всем привет! как узнать, что текст в TSkLabel был выведен сокращенным ? Есть функция для TLabel которая позволяет определить , что текст выведен сокращенным function TFrmMai...
DELPHI SOLUTIONS
6
Вот объясните, как это работает: Вот есть допустим unix-подобная система, и программа запускает допустим printf или fork, как это передается ядру, и как оно обрабатывать начин...
Егор
14
Дебил? Я ищу друга
Bitard 228
27
У меня это всегда вопрос вызывало.. Нафига писать код так, чтобы потом ошибки вылавливать?
Nik
44
Карта сайта