Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как определить сколько конектов занято к базам. 
V
    Опции темы
Fameing
Дата 6.4.2006, 18:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 108
Регистрация: 21.2.2006
Где: Ukraine. Kiev

Репутация: 2
Всего: 2



Как определить из TomCat сколько на данний момент используется соединений с базой? Есть маленькая заметочка баз данних много около 60 шт.
И нужно узнать сколько конекшенов сейчас заняты.
PM MAIL ICQ   Вверх
tux
Дата 7.4.2006, 02:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



Все зависит от того, как у тебя в Tomcat сконфигурированы соединения с БД. Сам Tomcat средствами для создания пула соединений не располагает, поэтому использует что-то стороннее, чаще всего commons-dbcp. Так вот, если у тебя в конфигурации задана вот такая фабрика - org.apache.commons.dbcp.BasicDataSourceFactory, например вот так:
Код

<Resource name="jdbc/TestDB"
    auth="Container"
    type="javax.sql.DataSource"/>

    <ResourceParams name="jdbc/TestDB">
        <parameter>
            <name>factory</name>
            <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
        </parameter>
        ...
    </ResourceParams>
</Resource>

то все возможно. Эта фабрика возвращает следующую реализацию интерфейса javax.sql.DataSource - org.apache.commons.dbcp.BasicDataSource. Осталось привести к нужному типу и вызвать методы getNumActive() - количество активных (используемых соединений) и getNumIdle() - количество соединений в состоянии ожидания.
PM MAIL Skype GTalk Jabber YIM   Вверх
Fameing
Дата 7.4.2006, 09:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 108
Регистрация: 21.2.2006
Где: Ukraine. Kiev

Репутация: 2
Всего: 2



Чтото я непонял !


пример получения соединения
как здесь ето реализовать smile
Код

public Connection opencon(String jndi) throws SQLException {
            Context initContext;
            Connection conn = null;
            DataSource pool;
            try {
                initContext = new InitialContext();
                Context envContext = (Context) initContext.lookup("java:/comp/env");
                pool = (DataSource) envContext.lookup("jdbc/pool/" + jndi);
                pool.getNumActive();
                conn = pool.getConnection();
            } catch (NamingException e) {
                logger.error("NamingException opencon() : " + jndi + " " + e);
            }
            return conn;


а в JNDI описал так
Код

<ResourceParams name="jdbc/pool/*****">
        <parameter>
            <name>url</name>
            <value>jdbc:oracle:oci8:@****</value>
        </parameter>
        <parameter>
            <name>password</name>
            <value>******</value>
        </parameter>
        <parameter>
            <name>maxActive</name>
            <value>8</value>
        </parameter>
        <parameter>
            <name>maxWait</name>
            <value>10000</value>
        </parameter>
        <parameter>
            <name>driverClassName</name>
            <value>oracle.jdbc.driver.OracleDriver</value>
        </parameter>
        <parameter>
            <name>username</name>
            <value>******</value>
        </parameter>
        <parameter>
            <name>maxIdle</name>
            <value>5</value>
        </parameter>
    </ResourceParams>

PM MAIL ICQ   Вверх
tux
Дата 7.4.2006, 09:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



Видимо по умолчанию это DBCP. Тогда так:
Код

public Connection opencon(String jndi) throws SQLException {
            Context initContext;
            Connection conn = null;
            BasicDataSource pool;
            try {
                initContext = new InitialContext();
                Context envContext = (Context) initContext.lookup("java:/comp/env");
                pool = (BasicDataSource) envContext.lookup("jdbc/pool/" + jndi);
                int numActive = pool.getNumActive();
                conn = pool.getConnection();
            } catch (NamingException e) {
                logger.error("NamingException opencon() : " + jndi + " " + e);
            }
            return conn;
}

Тогда в numActive - количество используемых соединений. Правда как будет работать не проверял.
PM MAIL Skype GTalk Jabber YIM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0994 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.