3 / 3 / 1
Регистрация: 20.06.2015
Сообщений: 55
MS SQL

SQL CLR - как продлить время жизни "независимого" объекта

04.03.2023, 22:37. Показов 689. Ответов 0

Студворк — интернет-сервис помощи студентам
Пишу CLR-сборку для MSSQL 2016. Нужно загружать данные, кешировать промежуточные вычисления и выводить результаты окончательных вычислений по запросу. Всё отлично работает, пока сборщик мусора .Net не убьёт объект с данными. А делает он это весьма быстро. Возникает вопрос, как хранить кеш данных внутри clr-сборки.

C#
1
2
3
4
5
6
7
8
9
10
11
public partial class SqlObjects
{
    // Контейнер
    private static TData Data = new TData();
 
    // Интерфейс
    [Microsoft.SqlServer.Server.SqlProcedure(Name = "some_db_procedure1")]
    public static void SomeProcedure1(...) { ... работа с Data ... }
 
    [Microsoft.SqlServer.Server.SqlProcedure(Name = "some_db_procedure2")]
    public static void SomeProcedure2(...) {  ... работа с Data ... }
Как продлить время жизни объекта Data? - В идеале чтобы он вообще никогда не удалялся. Мне всё равно, где его разместить, главное, чтобы к нему был доступ из класса SqlObjects. Есть идеи, как это сделать?

Добавлено через 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
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.03.2023, 22:37
Ответы с готовыми решениями:

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

Rust продлить время жизни переменой
у меня есть функциия которая принимает указатель на сцену и загружает ресурсы этой сцены выглядит она приблизительно так: pub fn...

Продлить время жизни SID-а в куках
Здравствуйте! Не могу продлить время жизни SID'а в куках. Есть 2 файла: ex.php &lt;?php ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.03.2023, 22:37
Помогаю со студенческими работами здесь

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

Время жизни объекта
Есть метод, который: 1. Создаёт ResizeObserver. 2. Создаёт для него анонимный метод-обработчик. 3. Запускает прослушивание событий. ...

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

Время жизни static объекта
Приветствую, Что то я запутался с проклятым static, помогите. Дано: public class Main extends Activity{ public static...

Время жизни временного объекта
можно ли передать временный объект в функцию по ссылке? void f1(int &amp; ); ..... int main() { f1(int());


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модель заражения группы наркоманов
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. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru