|
3 / 3 / 1
Регистрация: 20.06.2015
Сообщений: 55
|
||||||
MS SQL SQL CLR - как продлить время жизни "независимого" объекта04.03.2023, 22:37. Показов 689. Ответов 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 объекта Время жизни временного объекта Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|