Повлияет ли утечка соединения с базой данных в одном приложении на другие на сервере?

Я использую сервер jboss EAP 6.1, и на нем размещено около 20 приложений. Все 20 используют отдельные базы данных, расположенные на 5 серверах баз данных.

Если в одном приложении есть утечка соединения, повлияет ли это соединение на другие приложения?

Ниже приведена ошибка, которую я получаю, когда тестирую подключение к базе данных определенного приложения. Странно то, что это вызвано StringIndexOutOfBoundsException

06:31:22,981 WARN  [org.jboss.jca.core.connectionmanager.pool.strategy.OnePool] (ajp-/0.0.0.0:8809-3) IJ000604: Throwable while attempting to get a new connection: null: javax.resource.ResourceException: Could not create connection
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getLocalManagedConnection(LocalManagedConnectionFactory.java:288)
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.createManagedConnection(LocalManagedConnectionFactory.java:246)
    at org.jboss.jca.core.connectionmanager.pool.mcp.SemaphoreArrayListManagedConnectionPool.createConnectionEventListener(SemaphoreArrayListManagedConnectionPool.java:788)
    at org.jboss.jca.core.connectionmanager.pool.mcp.SemaphoreArrayListManagedConnectionPool.getConnection(SemaphoreArrayListManagedConnectionPool.java:344)
    at org.jboss.jca.core.connectionmanager.pool.AbstractPool.getSimpleConnection(AbstractPool.java:404)
    at org.jboss.jca.core.connectionmanager.pool.AbstractPool.getConnection(AbstractPool.java:372)
    at org.jboss.jca.core.connectionmanager.AbstractConnectionManager.getManagedConnection(AbstractConnectionManager.java:329)
    at org.jboss.jca.core.connectionmanager.tx.TxConnectionManagerImpl.getManagedConnection(TxConnectionManagerImpl.java:368)
    at org.jboss.jca.core.connectionmanager.AbstractConnectionManager.allocateConnection(AbstractConnectionManager.java:464)
    at org.jboss.jca.adapters.jdbc.WrapperDataSource.getConnection(WrapperDataSource.java:139)
    at com.mycomp.availability.DataSourceAvailTest.test(DataSourceAvailTest.java:167) [classes:]
    at org.apache.jsp.checkavail_jsp._jspService(checkavail_jsp.java:191)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:69) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:847) [jboss-servlet-api_3.0_spec-1.0.2.Final-redhat-1.jar:1.0.2.Final-redhat-1]
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:365) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:309) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:242) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:847) [jboss-servlet-api_3.0_spec-1.0.2.Final-redhat-1.jar:1.0.2.Final-redhat-1]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:295) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:214) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:149) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.jboss.modcluster.container.jbossweb.JBossWebContext$RequestListenerValve.event(JBossWebContext.java:91)
    at org.jboss.modcluster.container.jbossweb.JBossWebContext$RequestListenerValve.invoke(JBossWebContext.java:72)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:407) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.jboss.as.web.security.SecurityContextAssociationValve.invoke(SecurityContextAssociationValve.java:169) [jboss-as-web-7.3.3.Final-redhat-3.jar:7.3.3.Final-redhat-3]
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:145) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:97) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:102) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:336) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.coyote.ajp.AjpProcessor.process(AjpProcessor.java:490) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.coyote.ajp.AjpProtocol$AjpConnectionHandler.process(AjpProtocol.java:420) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:926) [jbossweb-7.3.1.Final-redhat-1.jar:7.3.1.Final-redhat-1]
    at java.lang.Thread.run(Thread.java:744) [rt.jar:1.7.0_51]
Caused by: java.lang.StringIndexOutOfBoundsException: String index out of range: -1
    at java.lang.String.substring(String.java:1911) [rt.jar:1.7.0_51]
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getDriver(LocalManagedConnectionFactory.java:562)
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getLocalManagedConnection(LocalManagedConnectionFactory.java:259)

person Thirumalai Parthasarathi    schedule 12.08.2014    source источник
comment
Какой URL вы используете? Добавьте конфигурацию источника данных из файла standalone.xml.   -  person Neeraj    schedule 12.08.2014
comment
@Neeraj: у меня нет доступа к конфигурации источника данных. Как вы думаете, это происходит из-за неправильной настройки базы данных JNDI?   -  person Thirumalai Parthasarathi    schedule 12.08.2014
comment
Да, потому что возникает исключение при попытке получить ключ драйвера из настроенного ‹connection-url› в источнике данных. Он пытается получить индекс секунды: в ‹connection-url›, но выдает исключение, потому что он не определен правильно.   -  person Neeraj    schedule 12.08.2014
comment
хорошо.. я попытаюсь получить файл конфигурации. Но можете ли вы сказать мне, как вы знаете, что он ищет второй :? и я пытаюсь выяснить местоположение банки, содержащей класс LocalMangedConnectionFactory.   -  person Thirumalai Parthasarathi    schedule 12.08.2014
comment
Я проверил исходный код LocalMangedConnectionFactory Этот класс находится в jdbcadapters. вы можете найти его в {JBOSS_HOME}\modules\org\jboss\ironjacamar   -  person Neeraj    schedule 12.08.2014
comment
Я пытался найти этот путь уже несколько часов... большое спасибо... кстати, в моих окнах он был в месте {JBOSS_HOME}\modules\system\layers\base\org\jboss\ironjacamar. я тоже видел код ... с предположением, что URL-адрес подключения установлен правильно, например, вот так, jdbc:sqlserver://servername почему он ищет : в или после индекса 6 ..?   -  person Thirumalai Parthasarathi    schedule 12.08.2014
comment
Он пытается получить ключ драйвера, например, в вашем случае он примет jdbc:sqlserver в качестве ключа и загрузит драйвер из кеша.   -  person Neeraj    schedule 12.08.2014
comment
Давайте продолжим обсуждение в чате.   -  person Thirumalai Parthasarathi    schedule 12.08.2014


Ответы (1)


Исключение возникает при попытке получить ключ драйвера из настроенного <connection-url> в источнике данных. Он пытается получить индекс секунды ":" в <connection-url>, но выдает исключение, потому что он не определен правильно.

Вы можете проверить исходный код LocalMangedConnectionFactory Этот класс находится в jdbcadapters. вы можете найти его в {JBOSS_HOME}\modules\org\jboss\ironjacamar

Он пытается получить ключ драйвера, например, в вашем случае он примет jdbc:sqlserver в качестве ключа и загрузит драйвер из кеша.

person Neeraj    schedule 12.08.2014