Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Java EE (J2EE) и Spring > Как определить сколько конектов занято к базам.


Автор: Fameing 6.4.2006, 18:09
Как определить из TomCat сколько на данний момент используется соединений с базой? Есть маленькая заметочка баз данних много около 60 шт.
И нужно узнать сколько конекшенов сейчас заняты.

Автор: tux 7.4.2006, 02:31
Все зависит от того, как у тебя в 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 - http://jakarta.apache.org/commons/dbcp/apidocs/org/apache/commons/dbcp/BasicDataSource.html. Осталось привести к нужному типу и вызвать методы getNumActive() - количество активных (используемых соединений) и getNumIdle() - количество соединений в состоянии ожидания.

Автор: Fameing 7.4.2006, 09:26
Чтото я непонял !


пример получения соединения
как здесь ето реализовать 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>

Автор: tux 7.4.2006, 09:52
Видимо по умолчанию это 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 - количество используемых соединений. Правда как будет работать не проверял.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)