Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
2 / 2 / 0
Регистрация: 18.10.2013
Сообщений: 61

Сессии пользователей, .net + SQL Server

18.10.2013, 19:14. Показов 2145. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго вечера!
Возникла следующая проблема:
Есть .net приложение, которое взаимодействует с SQL Server. В свое время была необходимость знать кто из пользователей в данным момент работает с данными (или просто открыл программу) и для этого была реализована поддержка сессий пользователей. Реализовано все через доп. поток в приложении BackgroundWorker, который каждые 10 секунд сообщает серверу, что пользователь работает ( while ... Sql.Command.Execute() .... Thread.Sleep(10 000) ...).

У большинства пользователей все работает отлично, но у некоторых (по непонятным пока причинам) доп. поток просто перестает отправлять инструкции (возможно подвисает) и, как следствие, сессии обрываются.

В чем может быть проблема?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2013, 19:14
Ответы с готовыми решениями:

Аутентификация пользователей в SQL Server 2005
Имеется БД в Sql Server 2005 и хочу написать приложение в Visual C#2010, как сделать аутентификацию в Visual C#2010 пользователей с...

Получить список пользователей(MS SQL Server, пишу на C#)
Здравствуйте! Интерисует такой вопрос, как мне получить список всех пользователей определенного сервера и как получить список...

SQL Server и .Net - DataSource и свойство DataMember
Доброго времени суток! Я, как говорят "Чайник". Если напишу непонятные вещи, за ранее простите. Есть база созданная на SQL Server. Нужно...

7
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
19.10.2013, 09:22
Я бы начал исследование с размещения трукача вокруг Sql.Command.Execute(), с выводом в лог подробностей об исключении.

Подвисать на обращении к SQLServer он вряд ли может, т.к. по умолчанию таймаут на выполнение запросов 30 секунд. А вот на необработанном исключении поток запросто может сдохнуть, и если где-то снаружи есть молчаливый трукач, то никто и никогда не узнает о том, что же там случилось.
0
2 / 2 / 0
Регистрация: 18.10.2013
Сообщений: 61
20.10.2013, 17:37  [ТС]
Собственно, код написан крайне аккуратно, поиски ни к чему не привели. Наверно лучше предоставить фрагменты кода:
  1. Запуск фонового потока
    C#
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    
    // формируем поток сессии
    bgwSession = new BackgroundWorker();
    bgwSession.WorkerSupportsCancellation = true;
    bgwSession.DoWork += Live;
    bgwSession.RunWorkerCompleted += Stop;
     
    // ловим сон (для более детального сообщения об ошибке)
    Microsoft.Win32.SystemEvents.PowerModeChanged += PowerModeChanged;
     
    // запускаем поток
    bgwSession.RunWorkerAsync();
  2. Работа фонового потока
    C#
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    
    /// <summary>
    /// Сохраняет текущую сессию пользователя активной.
    /// </summary>
    /// <remarks>Выполняется в отдельном потоке.</remarks>
    private void Live(object sender, DoWorkEventArgs e)
    {
        // получаем сведения о потоке
        BackgroundWorker worker = (BackgroundWorker)sender;
     
        // время последнего успешного продления сессии
        int deltaSeconds = 0;
     
        // поддерживаем активность, пока сессия не будет закрыта
        while (true)
        {
            // приложение закрывается
            if (worker.CancellationPending)
            {
                // фиксируем отмену, выходим
                e.Cancel = true;
                break;
            }
            else
            {
                // продолжаем сессию
                SqlCommand sc = new SqlCommand (... )
                sc.CommandTimeout = 5;
     
                try
                {
                    sc.Connection.Open();
                    sc.ExecuteNonQuery();
                }
                catch(Exception ex)
                {
                }
     
                // анализ кода возврата хранимой процедуры
                //
                // ...
                deltaSeconds = 0;
     
                sc.Dispose();  // using не используется потому что опущен вызов функции с передачей SqlCommand по ссылке
     
                IsSleepPowerModeDetected = false;   // затираем признак спящего режима
            
                //
                // ...
                //
     
                // приостанавливаем поток на 10 секунд
                System.Threading.Thread.Sleep(10 * 1000);
     
                // увеличиваем время простоя на 10 секунд
                deltaSeconds += 10;
            }
        }
    }
0
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
20.10.2013, 18:50
C#
1
2
3
 catch(Exception ex)
{
}
Это называется "молчаливый трукач"
Это называется страусиная политика.
Это значит мы не хотим знать об исключениях, случившихся во время выполнения команды.

Надо в этом месте организовать вывод исключения в лог.

А что там с соединением с БД ?
Мы его каждый раз пересоздаём ?
Мы его шарим с запросами из других потоков?
Я бы для этого потока сделал выделенное соединение. Закрывать соединение на 10 секунд - это как-то нехорошо.
0
1 / 1 / 0
Регистрация: 02.10.2013
Сообщений: 13
23.10.2013, 21:19
Не проще ли при вызове запроса писать в ту же бд пользователя который работает с базой ?
0
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
23.10.2013, 21:36
да кажется он это и делает. Только пропал куда-то. Наверное у него уже всё прошло.
0
1 / 1 / 0
Регистрация: 02.10.2013
Сообщений: 13
23.10.2013, 21:51
ksk, есть опыт работы с EF 6 + Postgresql ?
0
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
24.10.2013, 05:44
Артурик92, нет, я по другой части.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.10.2013, 05:44
Помогаю со студенческими работами здесь

ADO.NET передача запроса на sql server
Сетевые пакеты запроса передаются на сервер БД по сети друг за другом или параллельно ?

Как подключить базу SQL Server к веб приложению Asp.Net?
В книге Евсеевой &quot;Работа с базами данных в C# &quot; очень и очень подробно описано как работать подключать и редактировать базы на языке C# на...

Подключение к БД пользователей и ошибка "Пользователь не связан с доверенным соединением с SQL Server"
Доброе время суток! Прошу прощения, если такая тема уже была, но через поиск ничего не нашёл. При подключении к БД без указания...

Проверка списка пользователей SQL server
Всем доброго дня. Подскажите пожалуйста как решить данную проблему. Суть. Есть SQL server, на нем есть определённая группы пользователей...

Авторизация несколько пользователей через SQL server
как сделать так, чтобы для каждого пользователя открывалась своя форма, у меня открывается только одна форма private void...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru