Deutsch
Germany.ruФорумы → Архив Досок→ Программирование

предпочтения по количеству соединений с БД

800  1 2 все
AlexNek патриот09.05.23 18:40
AlexNek
09.05.23 18:40 

Разгорелась вот дискуссия, хотелось бы узнать еще мнений.


итак есть:DBContext и сессия пользователя

контекст можно открывать один раз на сессию(1) или каждый раз на операцию/транзакцию (2)

Возникло всё - из примерно следующей проблемы /просто как понятный пример/ - компонент перед отрисовкой загружает данные асинхронно.

Но вот вместо одной отрисовки он делает 2, при этом, при первой отрисовке он начинает грузить данные с базы, тут же начинает вторую отрисовку и начинает грузить те же самые данные опять. Контексту это не нравится и вылетает исключение. И предложено при каждой загрузке данных "открывать коннект" к базе по новому. И сделать это абсолютно везде.

#1 
alex445 коренной житель09.05.23 19:26
NEW 09.05.23 19:26 
в ответ AlexNek 09.05.23 18:40

Как где удобно, так и делайте. EF ещё содержит в себе паттерн unit of work, и если вы будете слишком часто использовать новый контекст или закрывать старый, вместо того, чтобы всё в одном делать, то лишитесь этого паттерна. Но если он и не нужен или удобнее использовать короткоживущие контексты, то и фиг с ним.

#2 
AlexNek патриот09.05.23 19:41
AlexNek
NEW 09.05.23 19:41 
в ответ alex445 09.05.23 19:26

предлагают так, ну и похоже понятие открытие/закрытие отличается от того, что предполагалось.

https://learn.microsoft.com/en-us/aspnet/core/blazor/blazo...

#3 
Murr патриот10.05.23 03:15
Murr
NEW 10.05.23 03:15 
в ответ AlexNek 09.05.23 18:40

контекст можно открывать один раз на сессию(1)

или

каждый раз на операцию/транзакцию (2)

-----

По затратам - почти невесомая операция - заполненная структура в памяти.

Более существенно на что она опирается при коннекте к базе - эта операция затратная.

Оракловский коннект - он ограниченно кешируемый - по закрытию просто возвращается в пулл.

По мелкомягкому - не помню, но думаю что примерно так же.

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

#4 
AlexNek патриот10.05.23 19:46
AlexNek
NEW 10.05.23 19:46 
в ответ Murr 10.05.23 03:15

В итоге оказалось проще, нашлось отчего происходит слишком много обновлений - бойтесь CascadedParameters смущ

#5 
alex445 коренной житель10.05.23 20:46
NEW 10.05.23 20:46 
в ответ AlexNek 10.05.23 19:46

Вы через них контекст передавали?

#6 
AlexNek патриот10.05.23 22:04
AlexNek
NEW 10.05.23 22:04 
в ответ alex445 10.05.23 20:46
Вы через них контекст передавали?

нет конечно, он через DI

народ просто хотел грузануть еще дополнительные данные из базы по изменению параметров.

А там получается так, с интервалом в десятки мс: параметр равен нулю (1), список с х элементами (2), список с х элементами (3). А базе нужно хотя бы сотню мс для чтения.

По честному должно быть только 1 и 2. 1 - не интересует, 2 читаем что надо. 3 - совершенно лишнее, но оно инициировало чтение также.

#7 
alex445 коренной житель11.05.23 14:33
NEW 11.05.23 14:33 
в ответ AlexNek 10.05.23 22:04, Последний раз изменено 11.05.23 14:46 (alex445)

А чего это вы всё чаще с Блейзором связываетесь? Вы же сказали, что отказались от него, т.к. Реакт и Ангуляр луТше?

#8 
AlexNek патриот11.05.23 19:09
AlexNek
NEW 11.05.23 19:09 
в ответ alex445 11.05.23 14:33
Вы же сказали, что отказались от него

Не следует смешивать разные проекты. То был клиент с PWA, а это сервер.

А еще есть и валом других, так что не нужно удивлятся.

#9 
alex445 коренной житель12.05.23 00:34
NEW 12.05.23 00:34 
в ответ AlexNek 11.05.23 19:09

В смысле "сервер"? А есть Блейзор-проекты, где на Блейзоре лишь серверная часть?

#10 
AlexNek патриот12.05.23 18:25
AlexNek
NEW 12.05.23 18:25 
в ответ alex445 12.05.23 00:34
alex445 коренной житель12.05.23 18:47
NEW 12.05.23 18:47 
в ответ AlexNek 12.05.23 18:25

Это всё понятно, но гуй-то в любом случае формируется Блейзором. Или вы можете как-то прикрутить тот же Ангуляр к блейзоровским компонентам? А как это выглядит и смысл в этой химере? Блейзор же был сделан в том числе как замена джаваскриптовому слою на клиенте. Если вам по-прежнему нужны js-спагетти для view model, то смысла использовать Блейзор нет.

#12 
AlexNek патриот12.05.23 23:33
AlexNek
NEW 12.05.23 23:33 
в ответ alex445 12.05.23 18:47
но гуй-то в любом случае формируется Блейзором

естественно


Что конкретно непонятно?


Если вам по-прежнему нужны js-спагетти для view model,

Зачем? Есть маленький кусок JS для смены фокуса, может еще какая то мелочь

#13 
alex445 коренной житель13.05.23 11:02
NEW 13.05.23 11:02 
в ответ AlexNek 12.05.23 23:33, Последний раз изменено 13.05.23 11:10 (alex445)

Там же для фокуса другую штуку сделали, зачем джаваскрипт? Забудьте про него. У меня в проекте есть лишь одна функция на нём, которую я написал сам стянул - сформировать файл из готового контента и скачать его. Строчек 6-7. Да и то лишь потому, что иначе браузер не даёт качать файлы.

#14 
AlexNek патриот13.05.23 11:20
AlexNek
NEW 13.05.23 11:20 
в ответ alex445 13.05.23 11:02
Там же для фокуса другую штуку сделал

Ну давайте для динамически создаваемой формы переместите фокус на любой элемент по ИД с помощью этой штуки. Сказать сколько это будет строк на JS?

#15 
AlexNek патриот13.05.23 13:43
AlexNek
NEW 13.05.23 13:43 
в ответ alex445 13.05.23 11:02

Вот как бы загадка. Есть Блазор код, TestComponent только логирует вызов фунций внутри себя и имеет CascadingParameter. /*Это коммент должен быть '//var _forecasts' как коммент, следующий вопрос, что будет в выводе с данной строкой без коммента?*/


<button @onclick="OnRefresh">Refresh</button>
<CascadingValue Value="@_forecasts">
    <TestComponent></TestComponent>
</CascadingValue>
@code{
 private WeatherForecast[]? _forecasts;
    protected override async Task OnInitializedAsync()
    {
        Console.WriteLine("---Main component loading shared data---");
        _forecasts = await ForecastService.GetForecastAsync(DateTime.Now);
    }
    private async Task OnRefresh()
    {
        Console.WriteLine("---Pressed button Refresh---");
        await Task.Delay(200);
        //var _forecasts = await ForecastService.GetForecastAsync(DateTime.Now);
    }
}

Вопрос: Что можно увидеть в логах?

#16 
AlexNek патриот13.05.23 13:46
AlexNek
NEW 13.05.23 13:46 
в ответ AlexNek 13.05.23 13:43

Вот важная часть TestComponent

@code {
    [CascadingParameter]
    private WeatherForecast[]? Forecasts { get; set; }
    
    protected override async Task OnInitializedAsync()
    {
        Console.WriteLine("OnInitializedAsync");
        await base.OnInitializedAsync();
    }

    public override async Task SetParametersAsync(ParameterView parameters)
    {
        var objects = parameters.ToDictionary();
        string parDescription = String.Join(", ",objects);
        Console.WriteLine($"set:{parDescription}");
        await base.SetParametersAsync(parameters);
    }

    protected override async Task OnParametersSetAsync()
    {
        Console.WriteLine("OnParametersSetAsync enter");
        await base.OnParametersSetAsync();
        // simulate some work
        await Task.Delay(250);
        Console.WriteLine("OnParametersSetAsync exit");
    }
}
#17 
alex445 коренной житель13.05.23 14:43
NEW 13.05.23 14:43 
в ответ AlexNek 13.05.23 11:20, Последний раз изменено 13.05.23 14:46 (alex445)
Ну давайте для динамически создаваемой формы переместите фокус на любой элемент по ИД с помощью этой штуки. Сказать сколько это будет строк на JS?

Динамически в смысле на джаваскрипте? Тогда сами себе проблемы создаёте - только с джаваскриптом и работайте.


А если через SignalR, то просто отсылаете новый запрос на обновление формы или её контрола, он себя перестраивает, и там уже ставите фокус куда вам надо.


Что за навязчивые попытки скрестить ежа с ужом? Вы либо дальше скриптизируете со всеми такими из себя динамическими вью моделями на JS, либо переходите на Блейзор целиком. Химеры это всегда проблемы и ненужная мешанина из технологий.


С каскадными параметрами ещё толком не работал, поэтому ничего сказать не могу.

#18 
AlexNek патриот13.05.23 16:03
AlexNek
NEW 13.05.23 16:03 
в ответ alex445 13.05.23 14:43
Динамически в смысле на джаваскрипте?

не что за болезнь такая везде его видеть?

Динамически в смысле форма создается по скрипту (не ява!!!)

Вот пример:

Текст х1

Чекбокс х2 ("синий", "зеленый")

@if x1==1 then x2=0

#19 
AlexNek патриот13.05.23 16:23
AlexNek
NEW 13.05.23 16:23 
в ответ alex445 13.05.23 14:43
то просто отсылаете новый запрос на обновление формы

Самому не смешно?

Попробуете ввести данные в первое поле а затем сделать обновление страницы

https://demos.devexpress.com/blazor/Editors


Но предлагаю начать с вышеприведенной задачи смущ

#20 
1 2 все