|
3 / 3 / 1
Регистрация: 20.06.2015
Сообщений: 55
|
||||||
MS SQL SQL CLR - как продлить время жизни "независимого" объекта04.03.2023, 22:37. Показов 673. Ответов 0
Пишу CLR-сборку для MSSQL 2016. Нужно загружать данные, кешировать промежуточные вычисления и выводить результаты окончательных вычислений по запросу. Всё отлично работает, пока сборщик мусора .Net не убьёт объект с данными. А делает он это весьма быстро. Возникает вопрос, как хранить кеш данных внутри clr-сборки.
Добавлено через 5 минут Да, и ещё... Мне не удалось найти описание механизма вызова методов класса sql clr-сборки. Непонятно, когда создаётся объект класса SqlObjects и когда удаляется. Неужели он создаётся каждый раз при вызове метода класса из БД. Это было бы странно. Должны быть какие-то средства управления временем жизни объекта класса SqlObjects. Там и будет решение продления времени жизни объекта Data. Вот только документации по этому поводу не удалось найти. Может кто поделится ссылкой... Добавлено через 1 час 21 минуту Похоже, проблема зарыта глубже... Нашёл одну ссылку, которая частично описывает мою проблему. Предполагается, что сам mssql перезагружает библиотеку, тем самым убивая все объекты (и статические, разумеется, тоже). Только в моём случае нет ни ошибок, ни сбоев. Зачем выгружать библиотеку после нескольких секунд простоя - вопрос. Надо копать глубже... Добавлено через 19 минут Походу проблема известная и нет способа решить её, поскольку нет возможности управлять процессом перезагрузки clr-сборки в mssql. Рекомендуют кеш хранить в другом месте. Печаль. Добавлено через 3 часа 29 минут Можно использовать следующее обходное решение. Нужно проверить журнал SQL Server на предмет таких сообщений: AppDomain <X> (<Database>.<Assembly>[runtime].<X-1>) unloaded. AppDomain <X> (<Database>.<Assembly>[runtime].<X-1>) is marked for unload due to memory pressure. AppDomain <X> (<Database>.<Assembly>[runtime].<X-1>) created. Именно в момент выгрузки AppDomain из памяти теряются значения static. В данном случае можно проверить настройки памяти сервера. Имеет смысл изменить значение на фиксированное, выделив необходимое кол-во памяти: EXEC sys.sp_configure N'max server memory (MB)', N'4000' GO RECONFIGURE WITH OVERRIDE GO В принципе, сборка больше не выгружается, хотя корневая проблема не решается и всё таки для стабильности кеширование данных лучше осуществлять в БД. Возможно, временные таблицы #, доступные только внутри одной сессии, будут приемлемым решением, чтобы гарантировать сохранность данных кеша на протяжении всей работы сессии.
0
|
||||||
| 04.03.2023, 22:37 | |
|
Ответы с готовыми решениями:
0
Продлить время жизни куки в браузере Rust продлить время жизни переменой Продлить время жизни SID-а в куках |
| 04.03.2023, 22:37 | |
|
Помогаю со студенческими работами здесь
1
Продлить время жизни переменных (Public не работает) Время жизни объекта Время жизни объекта Время жизни static объекта Время жизни временного объекта Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
|
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo
Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло.
Но на выплатах по больничным это. . .
|
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
|
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y
Z4Tv2zpXVVo
https:/ / github. com/ shumilovas/ med2. git
|
|
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа.
В качестве фильтра для отбора справочника служит группа номенклатуры.
Отбор по наименованию группы. . .
|
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
|
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс.
Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
|
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа.
В качестве фильтра для отбора служит значение перечислений.
/ / Событие "НачалоВыбора" реквизита на форме. . .
|