Эскалация блокировок СУБД и 1С – как НЕ накосячить при разработке и доработке конфигураций



Сегодня рассмотрим, как 1C может “залипнуть” вследствие эскалации блокировок.

Даже если у Вас всего 10-20 рабочих мест.

В итоге Вы будете знать:

  • Что вообще такое “эскалация блокировок” и чем она страшна
  • Как правильно разрабатывать код, чтобы избежать эскалации
  • При каких условиях возникает эскалация на сервере 1С и сервере СУБД
  • Отличия платформы 8.2 и 8.3 в части эскалации блокировок
  • Инструменты диагностики эскалации.

Это отрывок из курса “Ускорение и Оптимизация систем на 1С”…

Многие воспринимают его как хитрую заумь, которая нужна только в компаниях, где 10 серверов и 500 рабочих мест.

Да, для таких он точно нужен. Но!

Есть огромное число нюансов и в простых проблемах.

Итак, 19 минут видео – и Вы будете знать об этой теме всё, что нужно :)

Видео 1. Вводная часть про блокировки

Небольшая матчасть про эскалации и транзакционные блокировки в платформе “1С:Предприятие 8”.

Здесь же даем рекомендации, как избежать эскалации блокировок.

Изменение большого числа данных в транзакции

Видео 2. Эскалация блокировок СУБД

В видео покажем, когда возникает эскалация блокировок на стороне СУБД.

Эскалация блокировок СУБД

Видео 3. Событие Lock:Escalation

Рассмотрим, как диагностировать эскалацию средствами MS SQL Server.

Событие Lock:Escalation

Видео 4. Эскалация блокировок 1С

В этом уроке разберем, когда происходит эскалация на сервере 1С.

Проведем диагностику блокировок и эскалации с помощью технологического журнала.

Эскалация блокировок 1С

Знания уровня 1С:Эксперт ДОЛЖНЫ быть у каждого

Эти видео-уроки взяты из курса “Ускорение и оптимизация систем на 1С:Предприятие 8.3 + подготовка на 1С:Эксперт”.

К слову – самый дорогой курс. Именно по нему возникает больше всего сомнений – “стоит ли его вообще проходить?”.

Мы хотели показать сегодня, что это не курс для каких-то отдельных частных случаев (типа 500+ рабочих мест) – а курс общей подготовки, для всех, кто хочет по-настоящему знать, как работает 1С.

По сути – для любого ответственного разработчика и внедренца.

И да, курсов по оптимизации два – LITE и PROF.

PROF отличается тем, что готовит Вас к самой высшей Аттестации 1С – 1С:Эксперт по технологическим вопросам крупных внедрений.

Вы сможете сдать его буквально через 2 месяца.

Комментарии / обсуждение (15):

  1. Ярослав Бессчетнов

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

    • Андрей Бурмистров

      Здравствуйте!
      Блокировки 1С и СУБД это два абсолютно разных, никак не зависящих друг от друга механизма. СУБД ничего не знает об управляемых блокировках 1С.
      В обоих видах блокировок есть эскалация, но порог разный. У вас скорее будет эскалация на СУБД MS SQL т.к. там порог ниже (порядка 5000 эл-в на одну таблицу за раз), чем эскалация на 1С (100 тыс. эл-в).

      > Существует мнение, что если установить по измерениям управляемую блокировку 1С, это поможет убрать эскалацию блокировок СУБД.
      Это бред и вы это уже доказали своим опытом. Еще раз повторю это два разных независимых механизма. При желании вы можете отключить эскалацию на MS SQL для определенной таблицы или всего сервера, но отключить эскалацию на упр. блокировках 1С нельзя, по крайней мере на текущий момент времени.

      • Ярослав Бессчетнов

        Андрей, спасибо большое за ответ. Т.е. получается, что если требуется провести документ, который записывает в регистр большой набор записей (> 10 000 строк), то нет никакой возможности избежать эскалации блокировок СУБД, кроме как отключить эскалацию MS SQL для таблицы или для всего сервера?

        • Андрей Бурмистров

          Все верно, ну либо как то программно разбивать запись на порции. На практике обычно просто отключают эскалацию для таблицы. Самый простые решения обычно самые эффективные, только следите за память занимаемой MS SQL т.к. при отключении эскалации под блокировки естественно будет уходить больше памяти.

    • White

      Ярослав, пришлите все же ссылку на эту статью, интересно посмотреть, что это за статья такая и кто её автор и где её опубликовали. У меня начальник (!!!) отдела разработки понатыкал управляемых блокировок перед записью набор записей регистра сведений, понимать буквально, перед строкой “НЗ.Записать()” использование “БлокировкаДанных = ….”. Когда я его спросил зачем это и сказал профита от этого никакого, он ответил, что в статье умной прочел ,что так надо делать, это избавляет от блокировок на SQL. Я тогда мягко говоря ох…..ох как удивился(((
      Мне кажется вы читали одну статью)

      • Андрей Бурмистров

        Видимо пора цикл статей выпускать “Мифы и легенды мира 1С”.
        Тут кстати может в статье и правильно написано, просто начальник ваш понял ее по своему.
        В курсе, да и на просторах интернета есть моя обработка отображающая текущие заблокированные строки как на 1С так и на СУБД, можете с помощью нее показать начальнику что упр. блокировки 1С никак не избавляют от блокировок СУБД. Речь идет конечно об X блокировках.

  2. Констанция

    Одна инструкция Transact-SQL получает более 5 000 блокировок в одной несекционированной таблице или индексе.

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

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

Вход на сайт

Зарегистрироваться

Подтверждение регистрации будет отправлено на указанный e-mail.

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

Восстановить доступ

E-mail или логин

Ссылка на создание нового пароля будет отправлена на указанный e-mail.