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 ответов

9 просмотров

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

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

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

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

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

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

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

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

Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
@NikaBelurgHR Бот? Ассемблер?
КТ315
11
юзеры Jetpack Compose тут?
Qtless Qtless
7
Добрый день! Подскажите, пожалуйста: какими компетенциями нужно обладать, чтобы претендовать на работу эрланг (отдельная благодарность, если про элексир тоже подскажете) разр...
via ☸️ led
20
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Карта сайта