у нас слишком большой объем транзакций повторите попытку позже что значит

Как исправить ошибку «Транзакция слишком большая» (Transaction too large) при отправке монет из кошелька

Содержание статьи:

При переводе большого количества монет из кошелька на биржу возникала ли у вас эта ошибка? Не удалось создать транзакцию! слишком большая («Transaction too large»).

Недавно на нашем форуме один из наших пользователей задал следующий вопрос:

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

Итак, почему ваш кошелек выдает сообщение об ошибке, в котором указано, что транзакция слишком большая, и как в этом случае отправить большую сумму из кошелька? Следующее руководство поможет вам понять это и исправить эту ошибку.

Таким образом, когда в транзакции задействовано больше выходов, размер транзакции становится больше в байтах. Следовательно, кошелек отклонит вашу транзакцию с сообщением об ошибке «Транзакция слишком большая».

Но как вообще в вашем кошельке произошло так много транзакций?

В кошельке слишком много транзакций

Чтобы лучше понять это, представьте, что вам ежедневно платят 1$ наличными. Теперь, накопив большую сумму, вы хотите ее потратить, скажем, 1000$. Как вы думаете, кто-то будет принимать купюры по 1$ за покупку в 1000$ США? По сути, вам нужно отнести их в банк и обменять на более крупные банкноты, прежде чем вы сможете их потратить.

Точно так же баланс, который вы видите в своем кошельке, сохраняется не как одна общая сумма, а как набор выходных данных.

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

Решение для ошибки слишком большой транзакции

Есть два способа устранить эту ошибку.

Вариант 1: консолидируйте транзакции

Слишком много входов не поместятся в одной транзакции. Итак, что вам нужно сделать, это объединить все крошечные входы в несколько более крупных, прежде чем отправлять их на фактический адрес назначения?

Так как же объединить вводимые данные?

Как только ваш кошелек будет открыт, перейдите к отправке и нажмите на входы. Теперь выберите все входы и отправьте их на новый адрес получения, которым вы владеете. Если вы получаете слишком большую ошибку транзакции, объедините меньшее количество входных данных и отправьте их снова.

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

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

Вариант 2: выберите входные данные самостоятельно

Большинство клиентов кошельков автоматически выбирают входные данные при отправке монет и делают оптимальный выбор. Но иногда вы все равно получаете слишком большую ошибку транзакции.

Вместо того, чтобы позволять кошельку выбирать входы, вы сами выбираете их, используя функции управления монетами. Это полезно, особенно если вы отправляете определенные суммы.

Так как же избежать этой ошибки в будущем?

Получайте большие выплаты

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

«>Если вы используете мастерноды или получаете вознаграждение засчет стекирования, тут ничего не поделаешь. Ваш кошелек по-прежнему будет регулярно получать большое количество транзакций. Поэтому время от времени открывайте свой кошелек, синхронизируйте его и самостоятельно консолидируйте небольшие входные данные для использования в будущем.

Также есть средство, называемое грумером кошелька, которое делает это автоматически. Однако это для опытных пользователей, и мы расскажем о нем в другом руководстве.

Источник

Как исправить ошибку «Транзакция слишком большая» при отправке монет из кошелька

При переводе большого количества монет из кошелька на обмен вы когда-нибудь получали эту ошибку? Не удалось создать транзакцию! Транзакция слишком большая.

Недавно на нашем форуме один из наших пользователей задал следующий вопрос:

«У меня в кошельке более 1000 мелких транзакций, что в сумме составляет чуть более 0,8 биткойна. Я пытаюсь отправить все монеты на Binance, но все время получаю сообщение об ошибке: «Транзакция слишком большая». Я даже попытался установить большую индивидуальную комиссию за транзакцию, но все равно не смог отправить монеты. Я использую последнюю версию кошелька Bitcoin Core. “

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

Итак, почему ваш кошелек выдает сообщение об ошибке, в котором указывается, что транзакция слишком большая, и как вы отправляете большие суммы из кошелька? Следующее руководство поможет вам понять и исправить эту ошибку..

Транзакция слишком велика (в байтах) – что это значит?

Слишком большая транзакция просто означает, что транзакция слишком большая, чтобы поместиться в блок. Обычно это происходит, когда ваш кошелек объединяет большое количество входов в одну транзакцию. Дело не в комиссии, а в размере вашей транзакции. Отправляете ли вы или получаете монеты; каждая транзакция, которая происходит в цепочке блоков, имеет связанный с ней размер. Чтобы узнать больше, прочтите эту статью о размере мемпула биткойнов..

Чтобы ваша транзакция была добавлена ​​в цепочку блоков, она должна быть включена в новый добытый блок. Для каждого блока существует ограничение на максимальный размер данных, которые он может содержать, и это зависит от монеты к монете. Таким образом, когда в транзакции задействовано больше выходов, размер транзакции становится больше в байтах. Следовательно, кошелек отклоняет вашу транзакцию с сообщением об ошибке «Транзакция слишком большая»..

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Но как вообще в вашем кошельке было так много транзакций??

В кошельке слишком много транзакций

Вы добываете монеты ежедневно? Ваш кошелек разблокирован для укладки? Вы используете мастерноду? Независимо от того, занимаетесь ли вы майнингом, складываете или получаете награды за мастерноды, шансы есть в вашем кошельке слишком много транзакций. Это могут быть сотни или даже тысячи крошечных транзакций, которые вы совершили за определенный период времени..

Чтобы лучше понять это; представьте, что вам ежедневно платят 1 доллар наличными. Теперь, накопив большой кусок, вы хотите их потратить, скажем, 1000 долларов. Как вы думаете, кто-то будет принимать монеты по 1000 долларов США? По сути, вам нужно отнести их в банк и обменять на более крупные банкноты, прежде чем вы сможете их потратить..

Точно так же баланс, который вы видите в своем кошельке, хранится не как одна общая сумма, а как набор выходных данных..

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

Решение для слишком большой ошибки транзакции

Есть два способа исправить эту ошибку..

Исправление 1: консолидируйте транзакции

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

Итак, как объединить входы?

Откройте свой основной кошелек. Перейдите в настройки >> параметры, а затем перейдите на вкладку кошелька. Теперь включите функции управления монетами и перезапустите кошелек. Если вы используете кошелек Electrum, перейдите в Просмотр >> Покажите монеты и щелкните вкладку монет.

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Как только ваш кошелек будет открыт, перейдите к отправке и нажмите на входы. Теперь выберите все входы и отправьте их на новый адрес получения, которым вы владеете. Если вы получаете слишком большую ошибку транзакции, объедините меньшее количество входных данных и отправьте их.

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

Примечание: При объединении исходных данных взимается комиссия за транзакцию, но она незначительна. Если комиссия по-прежнему вас беспокоит, попробуйте отправить несколько транзакций прямо на ваш адрес обмена с меньшими суммами. Он будет успешно принят сетью.

Исправление 2: выберите входные данные самостоятельно

Большинство клиентов кошелька автоматически выбирают входные данные при отправке монет и делают оптимальный выбор. Но иногда вы все равно получаете слишком большую ошибку транзакции.

Вместо того, чтобы позволять кошельку выбирать входы, вы сами выбираете их, используя функции управления монетами. Это полезно, особенно если вы отправляете определенные суммы.

Так как же избежать этой ошибки в будущем??

Получайте большие выплаты

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

Если вы используете мастерноды или получаете вознаграждение за счет стекирования, то тут ничего не поделаешь. Ваш кошелек по-прежнему будет регулярно получать большое количество транзакций. Поэтому время от времени открывайте свой кошелек, синхронизируйте его и самостоятельно объединяйте меньшие данные для использования в будущем..

Также есть средство, называемое грумером для кошельков, которое делает это автоматически. Однако это для опытных пользователей, и мы объясним это в другом руководстве..

Источник

Как исправить ошибку «Транзакция слишком большая» (Transaction too large) при отправке монет из кошелька

Содержание статьи:

При переводе большого количества монет из кошелька на биржу возникала ли у вас эта ошибка? Не удалось создать транзакцию! слишком большая («Transaction too large»).

Недавно на нашем форуме один из наших пользователей задал следующий вопрос:

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

Итак, почему ваш кошелек выдает сообщение об ошибке, в котором указано, что транзакция слишком большая, и как в этом случае отправить большую сумму из кошелька? Следующее руководство поможет вам понять это и исправить эту ошибку.

Таким образом, когда в транзакции задействовано больше выходов, размер транзакции становится больше в байтах. Следовательно, кошелек отклонит вашу транзакцию с сообщением об ошибке «Транзакция слишком большая».

Но как вообще в вашем кошельке произошло так много транзакций?

В кошельке слишком много транзакций

Чтобы лучше понять это, представьте, что вам ежедневно платят 1$ наличными. Теперь, накопив большую сумму, вы хотите ее потратить, скажем, 1000$. Как вы думаете, кто-то будет принимать купюры по 1$ за покупку в 1000$ США? По сути, вам нужно отнести их в банк и обменять на более крупные банкноты, прежде чем вы сможете их потратить.

Точно так же баланс, который вы видите в своем кошельке, сохраняется не как одна общая сумма, а как набор выходных данных.

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

Решение для ошибки слишком большой транзакции

Есть два способа устранить эту ошибку.

Вариант 1: консолидируйте транзакции

Слишком много входов не поместятся в одной транзакции. Итак, что вам нужно сделать, это объединить все крошечные входы в несколько более крупных, прежде чем отправлять их на фактический адрес назначения?

Так как же объединить вводимые данные?

Как только ваш кошелек будет открыт, перейдите к отправке и нажмите на входы. Теперь выберите все входы и отправьте их на новый адрес получения, которым вы владеете. Если вы получаете слишком большую ошибку транзакции, объедините меньшее количество входных данных и отправьте их снова.

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

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

Вариант 2: выберите входные данные самостоятельно

Большинство клиентов кошельков автоматически выбирают входные данные при отправке монет и делают оптимальный выбор. Но иногда вы все равно получаете слишком большую ошибку транзакции.

Вместо того, чтобы позволять кошельку выбирать входы, вы сами выбираете их, используя функции управления монетами. Это полезно, особенно если вы отправляете определенные суммы.

Так как же избежать этой ошибки в будущем?

Получайте большие выплаты

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

«>Если вы используете мастерноды или получаете вознаграждение засчет стекирования, тут ничего не поделаешь. Ваш кошелек по-прежнему будет регулярно получать большое количество транзакций. Поэтому время от времени открывайте свой кошелек, синхронизируйте его и самостоятельно консолидируйте небольшие входные данные для использования в будущем.

Также есть средство, называемое грумером кошелька, которое делает это автоматически. Однако это для опытных пользователей, и мы расскажем о нем в другом руководстве.

Источник

Как исправить ошибку «Транзакция слишком большая» (Transaction too large) при отправке монет из кошелька

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

При переводе большого количества монет из кошелька на биржу возникала ли у вас эта ошибка? Не удалось создать транзакцию! Транзакция слишком большая («Transaction too large»).

Недавно на нашем форуме один из наших пользователей задал следующий вопрос:

«У меня в кошельке более 1000 мелких транзакций, что в сумме составляет чуть более 0,8 Биткойна. Я пытаюсь отправить все монеты на Binance, но все время получаю сообщение об ошибке: «Транзакция слишком большая». Я даже попытался установить большую индивидуальную комиссию за транзакцию, но все равно не смог отправить монеты. Я использую кошелек Bitcoin Core последней версии».

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

Итак, почему ваш кошелек выдает сообщение об ошибке, в котором указано, что транзакция слишком большая, и как в этом случае отправить большую сумму из кошелька? Следующее руководство поможет вам понять это и исправить эту ошибку.

Слишком большая транзакция просто означает, что транзакция слишком велика для размещения в блоке. Обычно это происходит, когда ваш кошелек объединяет большое количество входов в одну транзакцию.

Дело не в комиссии, а в размере вашей транзакции. Отправляете ли вы или получаете монеты, каждая транзакция, которая происходит в блокчейне, имеет связанный с ней размер.

Чтобы ваша транзакция была добавлена ​​в блокчейн, она должна быть включена в новый добытый блок. Для каждого блока существует ограничение на максимальный размер данных, которые он может содержать, и это зависит от монеты.

Таким образом, когда в транзакции задействовано больше выходов, размер транзакции становится больше в байтах. Следовательно, кошелек отклонит вашу транзакцию с сообщением об ошибке «Транзакция слишком большая».

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Но как вообще в вашем кошельке произошло так много транзакций?

В кошельке слишком много транзакций

Вы добываете монеты ежедневно? Ваш кошелек разблокирован? Вы используете мастерноду? Независимо от того, занимаетесь ли вы майнингом, холдите или получаете награды за мастерноды, есть шанс, что в вашем кошельке слишком много транзакций. Это могут быть сотни или даже тысячи крошечных транзакций, которые вы совершили за определенный период времени.

Чтобы лучше понять это, представьте, что вам ежедневно платят 1$ наличными. Теперь, накопив большую сумму, вы хотите ее потратить, скажем, 1000$. Как вы думаете, кто-то будет принимать купюры по 1$ за покупку в 1000$ США? По сути, вам нужно отнести их в банк и обменять на более крупные банкноты, прежде чем вы сможете их потратить.

Точно так же баланс, который вы видите в своем кошельке, сохраняется не как одна общая сумма, а как набор выходных данных.

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

Решение для ошибки слишком большой транзакции

Есть два способа устранить эту ошибку.

Вариант 1: консолидируйте транзакции

Слишком много входов не поместятся в одной транзакции. Итак, что вам нужно сделать, это объединить все крошечные входы в несколько более крупных, прежде чем отправлять их на фактический адрес назначения?

Так как же объединить вводимые данные?

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Как только ваш кошелек будет открыт, перейдите к отправке и нажмите на входы. Теперь выберите все входы и отправьте их на новый адрес получения, которым вы владеете. Если вы получаете слишком большую ошибку транзакции, объедините меньшее количество входных данных и отправьте их снова.

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

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

Вариант 2: выберите входные данные самостоятельно

Большинство клиентов кошельков автоматически выбирают входные данные при отправке монет и делают оптимальный выбор. Но иногда вы все равно получаете слишком большую ошибку транзакции.

Вместо того, чтобы позволять кошельку выбирать входы, вы сами выбираете их, используя функции управления монетами. Это полезно, особенно если вы отправляете определенные суммы.

Так как же избежать этой ошибки в будущем?

Получайте большие выплаты

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

Если вы используете мастерноды или получаете вознаграждение засчет стекирования, тут ничего не поделаешь. Ваш кошелек по-прежнему будет регулярно получать большое количество транзакций. Поэтому время от времени открывайте свой кошелек, синхронизируйте его и самостоятельно консолидируйте небольшие входные данные для использования в будущем.

Также есть средство, называемое грумером кошелька, которое делает это автоматически. Однако это для опытных пользователей, и мы расскажем о нем в другом руководстве.

Источник

Вы не умеете работать с транзакциями

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Заголовок вышел броским, но накипело. Сразу скажу, что речь пойдет об 1С. Дорогие 1С-ники, вы не умеете работать с транзакциями и не понимаете что такое исключения. К такому выводу я пришел, просматривая большое количество кода на 1С, рождаемого в дебрях отечественного энтерпрайза. В типовых конфигурациях с этим все достаточно хорошо, но ужасающее количество заказного кода написано некомпетентно с точки зрения работы с базой данных. Вы когда-нибудь видели у себя ошибку «В данной транзакции уже происходили ошибки»? Если да — то заголовок статьи относится и к вам. Давайте под катом разберемся, наконец, что такое транзакции и как правильно с ними обращаться, работая с 1С.

Почему надо бить тревогу

Для начала, давайте разберемся, что же такое представляет собой ошибка «В данной транзакции уже происходили ошибки». Это, на самом деле, предельно простая штука: вы пытаетесь работать с базой данных внутри уже откаченной (отмененной) транзакции. Например, где-то был вызван метод ОтменитьТранзакцию, а вы пытаетесь ее зафиксировать.

Почему это плохо? Потому что данная ошибка ничего не говорит вам о том, где на самом деле случилась проблема. Когда в саппорт от пользователя приходит скриншот с таким текстом, а в особенности для серверного кода, с которым интерактивно не работает человек — это… Хотел написать «критичная ошибка», но подумал, что это buzzword, на который уже никто не обращает внимания…. Это задница. Это ошибка программирования. Это не случайный сбой. Это косяк, который надо немедленно переделывать. Потому что, когда у вас фоновые процессы сервера встанут ночью и компания начнет стремительно терять деньги, то «В данной транзакции уже происходили ошибки» это последнее, что вы захотите увидеть в диагностических логах.

Есть, конечно, вероятность, что технологический журнал сервера (он ведь у вас включен в продакшене, да?) как-то поможет диагностировать проблему, но я сейчас навскидку не могу придумать вариант — как именно в нем найти реальную причину указанной ошибки. А реальная причина одна — программист Вася получил исключение внутри транзакции и решил, что один раз — не карабас «подумаешь, ошибка, пойдем дальше».

Что такое транзакции в 1С

Неловко писать про азбучные истины, но, видимо, немножго придется. Транзакции в 1С — это то же самое, что транзакции в СУБД. Это не какие-то особенные «1С-ные» транзакции, это и есть транзакции в СУБД. Согласно общей идее транзакций, они могут либо выполниться целиком, либо не выполниться совсем. Все изменения в таблицах базы данных, выполненные внутри транзакции, могут быть разом отменены, как будто ничего не было.

Далее, нужно понимать, что в 1С не поддерживаются вложенные транзакции. Собственно говоря, они не поддерживаются не «в 1С», а вообще не поддерживаются. По-крайней мере, теми СУБД, с которыми умеет работать 1С. Вложенных транзакций, например, нет в MS SQL и Postgres. Каждый «вложенный» вызов НачатьТранзакцию просто увеличивает счетчик транзакций, а каждый вызов «ЗафиксироватьТранзакцию» — уменьшает этот счетчик. Данное поведение описано в множестве книжек и статей, но выводы из этого поведения, видимо, разобраны недостаточно. Строго говоря, в SQL есть т.н. SAVEPOINT, но 1С их не использует, да и вещь это достаточно специфичная.

Здесь и далее, специально для Воинов Истинной Веры, считающих, что код должен писаться только на английском, под спойлерами будет приведен аналог кода в англоязычном синтаксисе 1С.

На самом деле, нет. Мне совершенно не хочется дублировать примеры на английском только ради того, чтобы потешить любителей холиваров и священных войн.

Вы же наверняка пишете такой код, да? Приведенный пример кода содержит ошибки. Как минимум, три. Знаете какие? Про первую я скажу сразу, она связана с объектными блокировками и не имеет отношения непосредственно к транзакциям. Про вторую — чуть позже. Третья ошибка — это deadlock, который возникнет при параллельном исполнении этого кода, но это тема для отдельной статьи, ее рассматривать сейчас не будем, дабы не усложнять код. Ключевое слово для гугления: deadlock управляемые блокировки.

Обратите внимание, простой ведь код. Такого в ваших 1С-системах просто вагон. И он содержит сразу, как минимум, 3 ошибки. Задумайтесь на досуге, сколько ошибок есть в более сложных сценариях работы с транзакциями, написанных вашими программистами 1С 🙂

Объектные блокировки

Суть проблемы в том, что в указанном примере кода изменяется объект базы данных, но в другом сеансе может сидеть интерактивный пользователь (или соседний фоновый поток), который тоже будет менять этот объект. Здесь один из вас может получить ошибку «запись была изменена или удалена». Если это произойдет в интерактивном сеансе, то пользователь почешет репу, ругнется и попробует переоткрыть форму. Если это произойдет в фоновом потоке, то вам придется искать это в логах. А журнал регистрации, как вы знаете, медленный, а ELK-стек для журналов 1С у нас в отрасли настраивают единицы… (мы, к слову, входим в число тех, кто настраивает и другим помогает настраивать :))

Короче говоря, это досадная ошибка и лучше, чтобы ее не было. Поэтому, в стандартах разработки четко написано, что перед изменением объектов необходимо ставить на них объектную блокировку методом «ОбъектСправочника.Заблокировать()«. Тогда параллельный сеанс (который тоже должен так поступить) не сможет начать операцию изменения и получит ожидаемый, управляемый отказ.

А теперь про транзакции

С первой ошибкой разобрались, давайте перейдем ко второй.

Если не предусмотреть проверку исключения в этом методе, то исключение (например, весьма вероятное на методе «Записать()») выбросит вас из данного метода без завершения транзакции. Исключение из метода «Записать» может быть выброшено по самым разным причинам, например, сработают какие-то прикладные проверки в бизнес-логике, или возникнет упомянутая выше объектная блокировка. Так или иначе, вторая ошибка гласит: код, начавший транзакцию, не несет ответственность за ее завершение.

у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть фото у нас слишком большой объем транзакций повторите попытку позже что значит. Смотреть картинку у нас слишком большой объем транзакций повторите попытку позже что значит. Картинка про у нас слишком большой объем транзакций повторите попытку позже что значит. Фото у нас слишком большой объем транзакций повторите попытку позже что значит

Именно так я бы назвал эту проблему. В нашем статическом анализаторе кода 1С на базе SonarQube мы даже отдельно встроили такую диагностику. Сейчас я работаю над ее развитием, и фантазия программистов 1С, чей код попадает ко мне на анализ, порой приводит меня в шок и трепет…

Почему? Потому что выброшенное наверх исключение внутри транзакции в 90% случаев не даст эту транзакцию зафиксировать и приведет к ошибке. Следует понимать, что 1С автоматически откатывает незавершенную транзакцию только после возвращения из скриптового кода на уровень кода платформы. До тех пор, пока вы находитесь на уровне кода 1С, транзакция остается активной.

Поднимемся на уровень выше по стеку вызовов:

Смотрите, что получается. Наш проблемный метод вызывается откуда-то извне, выше по стеку. На уровне этого метода разработчик понятия не имеет — будут ли какие-то транзакции внутри метода ОченьПолезныйИВажныйКод или их не будет. А если будут — то будут ли они все завершены… Мы же все тут за мир и инкапсуляцию, верно? Автор метода «ВажныйКод» не должен думать про то, что именно происходит внутри вызываемого им метода. Того самого, в котором некорректно обрабатывается транзакция. В итоге, попытка поработать с базой данных после выброса исключения изнутри транзакции, с высокой вероятностью приведет к тому, что «В данной транзакции бла-бла…»

Размазывание транзакций по методам

Второе правило «транзакционно-безопасного» кода: счетчик ссылок транзакций в начале метода и в его конце должен иметь одно и то же значение. Нельзя начинать транзакцию в одном методе и завершать ее в другом. Из этого правила, наверное, можно найти исключения, но это будет какой-то низкоуровневый код, который пишут более компетентные люди. В общем случае так писать нельзя.

Выше — неприемлемый говнокод. Нельзя писать методы так, чтобы вызывающая сторона помнила и следила за возможными (или вероятными — как знать) транзакциями внутри других методов, которые она вызывает. Это нарушение инкапсуляции и разрастание спагетти-кода, который невозможно трассировать, сохраняя рассудок.

Особенно весело вспомнить, что реальный код намного больше синтетических примеров из 3-х строчек. Выискивать начинающиеся и завершающиеся транзакции по шести уровням вложенности — это прям мотивирует на задушевные беседы с авторами.

Пытаемся исправить код

Вернемся к исходному методу и попытаемся его починить. Сразу скажу, что объектную блокировку мы чинить пока не будем, просто, чтобы не усложнять код примера.

Первый подход типичного 1С-ника

Обычно программисты 1С знают, что при записи может быть выдано исключение. А еще они боятся исключений, поэтому стараются их все перехватывать. Например, вот так:

Ну как, стало лучше, да? Ведь теперь, возможные ошибки записи обрабатываются и даже логируются. Исключения больше не возникнут при записи объекта. И в логе даже видно — на каком объекте, не поленился, вывел в сообщение ссылку вместо лаконичного «Ошибка записи справочника», как это часто любят писать вечно торопящиеся разработчики. Иными словами, налицо забота о пользователе и рост компетенций.

Однако, опытный 1С-ник здесь скажет, что нет, лучше не стало. По сути ничего не поменялось, а может даже стало и хуже. В методе «Записать()» платформа 1С сама начнет транзакцию записи, и эта транзакция будет уже вложенной по отношению к нашей. И если в момент работы с базой данных 1С свою транзакцию откатит (например, будет выдано исключение бизнес-логики), то наша транзакция верхнего уровня все равно будет помечена как «испорченная» и ее нельзя будет зафиксировать. В итоге этот код так и останется проблемным, и при попытке фиксации выдаст «уже происходили ошибки».

А теперь представьте, что речь идет не о маленьком методе, а о глубоком стеке вызовов, где в самом низу кто-то взял и «выпустил» начатую транзакцию из своего метода. Верхнеуровневые процедуры могут и понятия не иметь, что кто-то там внизу начинал транзакции. В итоге, весь код валится с невнятной ошибкой, которую расследовать невозможно в принципе.

Код, который начинает транзакцию, обязан завершить или откатить ее. Не взирая ни на какие исключения. Каждая ветка кода должна быть исследована на предмет выхода из метода без фиксации или отмены транзакции.

Методы работы с транзакциями в 1С

Не будет лишним напомнить, что вообще 1С предоставляет нам для работы с транзакциями. Это всем известные методы:

Первые 3 метода очевидны и делают то, что написано в их названии. Последний метод — возвращает Истину, если счетчик транзакций больше нуля.

И есть интересная особенность. Методы выхода из транзакции (Зафиксировать и Отменить) выбрасывают исключения, если счетчик транзакций равен нулю. То есть, если вызвать один из них вне транзакции, то возникнет ошибка.

Как правильно пользоваться этими методами? Очень просто: надо прочитать сформулированное выше правило: код, начавший транзакцию, должен нести ответственность за ее завершение.

Как же соблюсти это правило? Давайте попробуем:

Выше мы уже поняли, что метод ДелаемЧтоТо — потенциально опасен. Он может выдать какое-то исключение, и транзакция «вылезет» наружу из нашего метода. Окей, добавим обработчик возможного исключения:

Отлично, мы поймали возникающую ошибку, но что с ней делать? Записать сообщение в лог? Ну, может быть, если код логирования ошибок должен быть именно на этом уровне и ошибку мы тут ждем. А если нет? Если мы не ожидали тут никаких ошибок? Тогда мы должны просто передать это исключение выше, пусть с ними разбирается другой слой архитектуры. Делается это оператором «ВызватьИсключение» без аргументов. В этих ваших джава-сиплюсплюсах это делается точно так же оператором throw.

Так, стоп… Если мы просто прокидываем исключение дальше, то зачем тут вообще нужна Попытка? А вот зачем: правило заставляет нас обеспечить завершение начатой нами транзакции.

Теперь, вроде бы, красиво. Однако, мы ведь помним, что не доверяем коду ДелаемЧтоТо(). Вдруг там внутри его автор не читал этой статьи, и не умеет работать с транзакциями? Вдруг он там взял, да и вызвал метод ОтменитьТранзакцию или наоборот, зафиксировал ее? Нам очень важно, чтобы обработчик исключения не породил нового исключения, иначе исходная ошибка будет потеряна и расследование проблем станет невозможным. А мы помним, что методы Зафиксировать и Отменить могут выдать исключение, если транзакция не существует. Здесь-то и пригождается метод ТранзакцияАктивна.

Финальный вариант

Наконец, мы можем написать правильный, «транзакционно-безопасный» вариант кода. Вот он:

**UPD: в комментариях предложен более безопасный вариант, когда ЗафиксироватьТранзакцию расположен внутри блока Попытка. Здесь приведен именно этот вариант, ранее Фиксация располагалась после блока Попытка-Исключение.

Постойте, но ведь не только «ОтменитьТранзакцию» может выдавать ошибки. Почему же тогда «ЗафиксироватьТранзакцию» не обернут в такое же условие с «ТранзакцияАктивна»? Опять же, по тому же самому правилу: код, начавший транзакцию, должен нести ответственность за ее завершение. Наша транзакция необязательно самая первая, она может быть вложенной. На нашем уровне абстракции мы обязаны заботиться только о нашей транзакции. Все прочие должны быть нам неинтересны. Они чужие, мы не должны нести за них ответственность. Именно НЕ ДОЛЖНЫ. Нельзя предпринимать попыток выяснения реального уровня счетчика транзакций. Это опять нарушит инкапсуляцию и приведет к «размазыванию» логики управления транзакциями. Мы проверили активность только в обработчике исключения и только для того, чтобы убедиться, что наш обработчик не породит нового исключения, «прячущего» старое.

Чек-лист рефакторинга

Давайте рассмотрим несколько наиболее распространенных ситуаций, требующих вмешательства в код.

Паттерн:

Обернуть в «безопасную» конструкцию с Попыткой, Проверкой активности и пробросом исключения.

Паттерн:

Анализ и Рефакторинг. Автор не понимал, что делает. Начинать вложенные транзакции можно безопасно. Не нужно проверять условие, нужно просто начать вложенную транзакцию. Ниже по модулю он наверняка еще там извращается с их фиксацией. Это гарантированный геморрой.

Примерно похожий вариант:

аналогично: фиксация транзакции по условию — это странно. Почему тут условие? Что, кто-то иной мог уже зафиксировать эту транзакцию? Повод для разбирательства.

Паттерн:

Паттерн:

Данная транзакция уже не завершится в случае исключения. Нет смысла продолжать цикл. Код требуется переписать, сверяясь с исходной задачей. Дополнительно обеспечить более информативное сообщение об ошибке.

В заключение

Я, как вы уже, наверное, догадались, отношусь к людям, любящим платформу 1С и разработку на ней. К платформе, разумеется, есть претензии, особенно в среде Highload, но в общем и целом, она позволяет недорого и быстро разрабатывать очень качественные корпоративные приложения. Давая из коробки и ORM, и GUI, и веб-интерфейс, и Reporting, и много чего еще. В комментариях на Хабре обычно пишут всякое высокомерное, так вот, ребята — основная проблема 1С, как экосистемы — это не платформа и не вендор. Это слишком низкий порог вхождения, который позволяет попадать в отрасль людям, не понимающим, что такое компьютер, база данных, клиент-сервер, сеть и всякое такое. 1С сделала разработку корпоративных приложений слишком легкой. Я за 20 минут могу написать на ней учетную систему для закупок/продаж с гибкими отчетами и веб-клиентом. После этого, мне несложно подумать о себе, что и на больших масштабах можно писать примерно так же. Как-то там 1С сама все внутри сделает, не знаю как, но наверное сделает. Напишу-ка я «НачатьТранзакцию()».

И знаете — самое главное, что это прекрасно. Простота разработки в 1С позволяет моментально реализовывать бизнес-идеи и встраивать их в процессы компании. Потом всегда можно отрефакторить, главное понимать как. И если вдруг вам нужна помощь в аудите вашей «медленной 1С» — обращайтесь к специалистам по оптимизации. Она совсем не медленная.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *