Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
3 / 3 / 1
Регистрация: 20.06.2015
Сообщений: 55
MS SQL

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

04.03.2023, 22:37. Показов 673. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
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
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru