AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 26.11.2009, 19:08   #1  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Форма активных пользователей (SysUsersOnline) и сессии COM-коннектора
После небольшого спора с коллегой, занимающимся 1С, на тему того, сколько сессий открывает COM-коннектор, работающий в качестве сервиса COM+, при одновременном доступе через него в Аксапту нескольких "внешних" приложений (в данном случае 1С), подумалось: а почему, собственно, в форме активных пользователей видна только одна сессия business connector'а? Ведь явно в описанном сценарии определенные операции выполняются параллельно, чего штатными средствами в рамках одной сессии достичь невозможно: AOS на каждую сессию создает один-единственный поток и обрабатывает запросы от клиента синхронно. И тут, просматривая сообщения в eventlog'е о том, как начинаются и завершаются соединения business connector'а, я обратил внимание, что у них очень специфический номер сессии: он начинается c 65534 и затем уменьшается по мере появления новых сессий, при этом освобождаемые при завершении сессий номера активно используются повторно (65535 - какая-то служебная сессия пользователя '-AOS-', которая явно пропускается в той же форме активных пользователей). В то же время, метод получения информации о сессиях, SysUsersOnline::getAllOnlineUserInfo(), обращается лишь к сессиям с номерами от 1 до info::licensedUsersTotal(), т.е. условно к первым сотням. Так вот, после небольшой модификации этого метода на форме активных пользователей появились дополнительные сессии, создаваемые business connector'ом с указанием - при наличии активных соединений с БД - их SPID/SID и проч. (показ Serial No, SID, INST_ID - это доработка). И теперь стало понятнее, почему при подключении COM-коннектора "свободные" сессии на AOS'е заканчиваются раньше, чем на той же форме активных пользователей начнет показываться предельное число активных сессий.



Не совсем пока понятно, что делать с сессиями, которые показываются с типом NotAOS - для них не создается экземпляр AOSSessionInfo, и вообще, если верить eventlog'у, они уже завершены, но объекты xSession для них создаются...
Ниже приведена модификация SysUsersOnline::getAllOnlineUserInfo() для отображения таких сессий.
X++:
#define.MaxSessionId        (65535)             //+Отображать все COM-соединения в активных пользователях, gl00m, 26.11.2009
server static container getAllOnlineUserInfo()
{
    int                     counter;
    int                     num;
    int                     maxSessions = Info::licensedUsersTotal();
    int                     idleTicks;
    container               users;
    container               c;
    xSession                session;
    UserInfo                userInfo;
    AOSSessionInfo          aosSession;
    AOSClientMode           clientMode;
    // Отображать все COM-соединения в активных пользователях, gl00m, 26.11.2009 -->
    SetEnumerator           setEnum;
    Set                     setOfSessionIds = new Set( typeof(counter) );
    Counter                 cnAosUsers      = info::licensedAosUsers();
    // Отображать все COM-соединения в активных пользователях, gl00m, 26.11.2009 <--
    ;

    if (!maxSessions)          //Demo mode
        maxSessions = 3;

    num = 0;
    for(counter = 1; counter <= maxSessions;counter++)
    {
    // Отображать все COM-соединения в активных пользователях, gl00m, 26.11.2009 -->
        setOfSessionIds.add( counter );
    }
    for (counter = #MaxSessionId - cnAosUsers; counter <= #MaxSessionId; counter++)
    {
        setOfSessionIds.add( counter );
    }
    setEnum = setOfSessionIds.getEnumerator();
    while (setEnum.moveNext())
    {
        counter = setEnum.current();
//      session = new xSession(counter, true);
        session = new xSession(counter, false); // NB! с параметром _checkSession == true ничего не выйдет
    // Отображать все COM-соединения в активных пользователях, gl00m, 26.11.2009 <--

Последний раз редактировалось gl00mie; 26.11.2009 в 19:14.
За это сообщение автора поблагодарили: raz (5), Logger (10).
Старый 26.11.2009, 23:53   #2  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Интересно, почему штатно они не отображаются?
В чем глубокий смысл скрывать такие сессии? Тем более что только для них возможно получить SPID соединения в базе.

Для обычного пользователя COM - SPID соединения не виден, из-за чего неудобно разруливать блокировки и т.п.
Старый 27.11.2009, 08:59   #3  
raz is offline
raz
NavAx
Аватар для raz
NavAx Club
Лучший по профессии 2014
Лучший по профессии 2009
 
1,494 / 1065 (38) ++++++++
Регистрация: 22.07.2003
Адрес: МО
2 Logger

SPID виден при использовании АОСов (тонкий клиент), причем видно только у пользователей текущего АОСа.
Миниатюры
Нажмите на изображение для увеличения
Название: active_users.jpg
Просмотров: 527
Размер:	99.5 Кб
ID:	5382  

Последний раз редактировалось raz; 27.11.2009 в 09:13.
Старый 27.11.2009, 12:23   #4  
egorych is offline
egorych
Участник
Самостоятельные клиенты AX
Oracle
 
761 / 154 (7) ++++++
Регистрация: 09.11.2006
Адрес: Краснодарский край
У меня надпись NotAOS говорит о том, что пользователь подключен к другому АОСу.
Старый 27.11.2009, 16:04   #5  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,701 / 1195 (43) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
Про business connector - не знаю. Но некоторые выводы по ComConnector я описал здесь

Закрыть AxaptaCOMConnector из AXAPTA

"Фишка" в том, что есть "процесс-диспетчер" и "рабочие" процессы. Соответственно, есть некоторые отличия в их работе.
За это сообщение автора поблагодарили: Logger (10).
Старый 28.11.2009, 11:37   #6  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от raz Посмотреть сообщение
2 Logger

SPID виден при использовании АОСов (тонкий клиент), причем видно только у пользователей текущего АОСа.
Да это так.

Но я имел в виду что штатно для ком коннектора SPID не виден. Т.е. заходишь в форму активных пользователей - и видишь SPID у всех пользователей в трехзвенке, выполняющих запросы к БД. Для ком пользователя (имеется в виду "процесс-диспетчер" - а только он и виден в активных юзерах в штатной форме) SPID никогда не виден, независимо от его активности.

А теперь благодаря тому что открыты сессии из диапазона номеров под 65535 - видны их SPID.

Последний раз редактировалось Logger; 28.11.2009 в 11:47.
Старый 28.11.2009, 11:45   #7  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от Владимир Максимов Посмотреть сообщение
Про business connector - не знаю. Но некоторые выводы по ComConnector я описал здесь

Закрыть AxaptaCOMConnector из AXAPTA

"Фишка" в том, что есть "процесс-диспетчер" и "рабочие" процессы. Соответственно, есть некоторые отличия в их работе.
Ага, и похоже мы нашли способ просматривать "рабочие" процессы.
Теги
com connector, sysusersonline, активные пользователи, ax3.0

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
msdynamicsax: VB script that test the com connector for Dynamics Ax 4.0 Blog bot DAX Blogs 0 25.08.2008 18:05
Зависшие сессии пользователей dj_Mage DAX: Администрирование 1 05.07.2006 14:59
Не все сессии пользователей видны Atani DAX: Администрирование 2 15.04.2004 08:47
Количество активных пользователей VIS DAX: Функционал 2 13.05.2003 17:34

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 04:16.