`
rmzdb
  • 浏览: 81287 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

【原】was的一次数据库连接不了的处理记录

阅读更多

环境:WAS 7.0.0.0
Jdk :自带1.6
Linux环境:Linux, version 2.6.18-194.1.AXS3
Database 产品版本:Oracle Database 11g Release 11.1.0.0.0 - Production
数据源配置驱动:11.1.0.1.0  (后来更换 11.2.0.1.0 版本)

遇到的几个棘手问题:
1.

写道

引用
Error while registering Oracle JDBC Diagnosability MBean.
javax.management.MalformedObjectNameException: Invalid character '
' in value part of property
at javax.management.ObjectName.construct(ObjectName.java:613)
at javax.management.ObjectName.<init>(ObjectName.java:1405)
at oracle.jdbc.driver.OracleDriver.registerMBeans(OracleDriver.java:303)
at oracle.jdbc.driver.OracleDriver$1.run(OracleDriver.java:213)
at java.security.AccessController.doPrivileged(AccessController.java:202)
at oracle.jdbc.driver.OracleDriver.<clinit>(OracleDriver.java:209)
at java.lang.J9VMInternals.initializeImpl(Native Method)
at java.lang.J9VMInternals.initialize(J9VMInternals.java:200)
at java.lang.J9VMInternals.initialize(J9VMInternals.java:167)
at java.lang.Class.forNameImpl(Native Method)
at java.lang.Class.forName(Class.java:136)
at org.apache.commons.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1415)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044)
at org.springframework.orm.hibernate3.LocalDataSourceConnectionProvider.getConnection(LocalDataSourceConnectionProvider.java:81)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:114)
at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2833)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2829)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1840)
at



解决:
发现还是jdbc驱动问题,原因因该是与bug有关,因此从新从otn.oracle.com下载驱动升级解决问题。
ojdbc6.jar的驱动版本可以运行java -jar ojdbc6.jar查看,如果是Oracle 11.1.0.6.0-Production+ JDBC 4.0 compiled with JDK6,带+号就是补丁版本,否则是没有打补丁的,仍然可能出错。
或者直接下载 Oracle 11.1.0.7.0-Production JDBC 4.0 compiled with JDK6 这个包的ojdbc6.jar
下载地址

引用
http://www.oracle.com/technology/tech/java/sqlj_jdbc/index.html


WAS数据源配置:
我的项目中,涉及到多个库的连接,并且在程序中,对多个库有操作。其中每个库本身又保持自己业务库的连接。项目中自己的库,一方面通过注入,由hibernate去管理。作为自己的本身业务库,另一方面又注入到一个连接工厂,维持一个所有数据源的Map。供程序调用。而所有的连接是用was的连接池管理。
刚开始数据总是会报一个com.ibm.websphere.ce.cm.StaleConnectionException的异常。
  原因分析:WebSphere并不保证缓存的连接都是有效的,在这种情况下当用户从连接池中取得了一个失效的连接并且用来进行数据库操作时,WebSphere就会抛出StaleConnectionException。在StaleConnectionException出现之前,用户无法判断这是否为一个无效连接。详见:

引用
http://www.ibm.com/developerworks/cn/websphere/library/techarticles/0601_chenzhh/index.html

文章中说到,是由于websphere与数据库之间的连接中断导致。这可以验证我之前遇到的情况。日志里面有数据库的IO异常错误。网络不稳定可能是一个因素。但是后来,我调整了环境后,仍然有错。这里的连接池的缓存可能还跟连接池的配置项有关。因为我自己的程序对数据库的操作数据比较多,在程序开始前,先从一个库到查询大量的数据,再到另一个库里去插入大量的数据。而我获取连接在一开始就获取了,由于长时间的连接闲置,was连接池可能会把物理连接给断掉。这可能也是导致无效连接的一个因素。后来我把获取连接的位置调整了一下,问题有了好转。上述链接,说到避免无效连接,其实就是在连接之前加个测试语句。这在proxool等连接池组件都有配置实现,但是我们用jndi在程序里,就可以通过捕获异常,再去获取连接。这里给出我自己的代码:

Java代码 

do {    
   Statement stmt = null;    
   try {    
     if (retryCount == 0) {    
        conn = getDataSource(alias).getConnection();    
      } else {    
                Properties jndiMap = new Properties();    
                    jndiMap.put(“1”,”jndi/1”);    
                    jndiMap.put(“2”,”jndi/2”);    
                    jndiMap.put(“3”,”jndi/3”);    
		Properties env = new Properties();    
		env.put(Context.INITIAL_CONTEXT_FACTORY,    
		"com.ibm.websphere.naming.WsnInitialContextFactory");    
		Context context = new InitialContext(env);    
		DataSource ds = (DataSource) context.lookup(jndiMap    
		.getProperty(alias));    
		conn = ds.getConnection();    
	}    
	stmt = conn.createStatement();    
	stmt.execute("select 1 from dual");    
} catch (StaleConnectionException sce) {    
	if (retryCount < 3) {    
    		retry = true;    
		retryCount++;    
	} else {    
	retry = false;    
        }    
} catch (Exception e) {    
   	e.printStackTrace();    
} finally {    
	try {    
 	    if (stmt != null) {    
	       stmt.close();    
	    }    
	    if (conn != null && retry) {    
	       conn.close();    
	    }    
	} catch (Exception e) {    
	    e.printStackTrace();    
	}    
    }    
} while (retry);   

注:(1) 不同版本的jndi的提取方式可能不一样。
  (2) 该异常所在websphere的jar包:以当前环境为例,在 plugins/com.ibm.ws.runtime.jar(自己确实找了很久,才引入进来编译的代码)
  当我就要觉得大功告成了,发现又现一个很严重的问题。系统启动没有几分钟,就有异常抛出:数据采集:数据入库异常java.lang.NullPointerException。数据长时间重连后,依旧获取不到连接,就导致了抛异常了,到systemOut.log 上一看,发现问题:

写道

引用
[13-1-29 19:46:39:163 GMT+08:00] 0000002d FreePool E J2CA0045E: 对资源 jndi/sjjh 调用方法 createOrWaitForConnection 时,没有可用的连接。
[13-1-29 19:46:39:165 GMT+08:00] 00000016 FfdcProvider I com.ibm.ws.ffdc.impl.FfdcProvider logIncident FFDC1003I: 已在 /opt/IBM/WebSphere/AppServer/profiles/AppSrv01/logs/ffdc/server1_55a955a9_13.01.29_19.46.39.1622748.txt com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource.getConnection 299 发出 FFDC 事件。


额外的提示:
First failure data capture(FFDC) 工具是 WebSphere 小组开发的一款可以在第一次异常发生时对其进行详细数据捕获的工具。我们将其移植进入 IBM Systems Director ,并对其功能进行了进一步的封装,从而使其能够针对 Director 这款软件中的各种异常数据进行捕获。FFDC 机制在 Director 启动时随之启动,然后监听异常数据,直至 Director 被关闭。
  
通过查看FFDC事件日志,报出以下日志:

写道

引用
[13-1-29 19:25:41:587 GMT+08:00] FFDC Exception:com.ibm.websphere.ce.j2c.ConnectionWaitTimeoutException SourceId:Max connections reached ProbeId:869 Reporter:com.ibm.ejs.j2c.PoolManager@28cc28cc
com.ibm.websphere.ce.j2c.ConnectionWaitTimeoutException: Connection not available, Timed out waiting for 180030
at com.ibm.ejs.j2c.FreePool.createOrWaitForConnection(FreePool.java:1562)
at com.ibm.ejs.j2c.PoolManager.reserve(PoolManager.java:2436)
at com.ibm.ejs.j2c.ConnectionManager.allocateMCWrapper(ConnectionManager.java:955)
at com.ibm.ejs.j2c.ConnectionManager.allocateConnection(ConnectionManager.java:609)
at com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource.getConnection(WSJdbcDataSource.java:646)
at com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource.getConnection(WSJdbcDataSource.java:613)
……(中间省略)……
==> Performing default dump from com.ibm.ejs.j2c.DiagnosticModuleForJ2C :Tue Jan 29 19:25:41 GMT+08:00 2013
Maximum number of connections has been reached, and the connection request has been waiting longer than:ConnectionWaitTime. Two possible solutions : increase the max number of connections, or increase the:ConnectionWaitTime.:
Maximum Connections = :10
Current number of connections = :10
Connection Wait Timout = :180

日志给出了很详细的处理方法,增大最大连接数,或者增大连接等待的时间,因为180秒的等待时间,当连接达到最大的连接数,获取连接时间超过180秒,就会抛出异常了。如果资源允许的话,我们很喜欢调整一下,连接数调整到100,连接等待时间再调整一下。可是情况依然没有好转,100个连接数,启动没有10分钟,就耗尽了。问题没有这么简单。
由于是现场的问题,立马让现场,抓了一个数据库的情况:

写道

引用
Select userName,count(userName) from v&session group by userName

100的连接耗尽,数据库的保有连接是 26 。
  到这,我有点疑惑了,难不成是was连接池的连接池与数据库的连接没有同步。也就是网上有那么几个稀少的提问:was7.0版本的连接池不会自动释放连接,有没有人碰到,我这里的情况貌似是这样,想想这是不是ibm本身的bug问题。开始查找IBM fix List。发现有关J2CA0045E 问题报错, 有两处提到:
  

引用
http://www-01.ibm.com/support/docview.wss?uid=swg21323294

写道

引用
J2CA0045E: Connection not available while invoking method
createOrWaitForConnection for resource jdbc/BPEDB.CWWBB0638E: Failed to connect to the database. The error reported by thedatabase is: com.ibm.websphere.ce.cm.ConnectionWaitTimeoutException:Connection not available, Timed out waiting for 180000.
Cause
This problem likely has two of the following causes:
The connection pool is incorrectly configured
The database settings for the maximum number of connections is incorrect or is lower than the settings of the connection pool in WebSphere Application Server
The embedded Derby database is used for processing the high-workload scenario, or the network deployment Derby server is improperly configured


原因描述的都很简单。连接池配置问题,最小超出最大连接,也属于配置问题,第三个跟我们的项目没有关系。到这里,我们不得不去考虑程序的问题了,我们又做了验证,发现这次
现场问题出来后,数据库的连接就是100了。跟之前的对比,原因:就是之前的抓数据库的信息晚了,导致was自己释放一部分的连接,所以库的保有连接是26。这个时候异常已经抛出来了。看来还应该是程序本身的问题。
后来经过查看代码发现:我们把获取连接写在了循环的里面了,而把关闭连接写在循环的外面。每次在里面通过连接工厂获取连接,当循环的次数为0或较少的时,程序在数据库上的开销几乎没有,即使有部分的连接没有关闭,由was的连接池也关闭了,不至于影响性能,但是当业务量大的时候,获取连接多,而且操作频繁,was关闭掉的连接诊断远远达不到获取连接的速度,就会抛异常了。但是这里比较奇怪的一点,当没有获取连接的时候,在程序的后端,执行close操作,竟然没有报空指针异常,虽然捕获了异常,也没有任何输出,该代码端的结束的log输出也不见了。这让我有点奇怪,这也是我在这个问题上查找原因花了不少时间的一个方面。

总结:was在连接池上的异常,多半都是自己程序上没有及时关闭导致的。在你疯狂的为bug着急的时候,请先看看自己的代码。毕竟第三方的bug是少之又少的。

 

分享到:
评论

相关推荐

    针对WAS6.1,对线程数、jvm,日志以及数据库连接进行性能调优

    在本文中,我们将讨论针对 WAS 6.1 的性能调优策略,涉及到线程数、JVM、日志和数据库连接等方面的优化。 一、线程数优化 在 WAS 6.1 中,线程数的设置对性能的影响非常大。我们可以通过设置 Web Container 的最大...

    was性能调整方案

    在IT行业中,WebSphere Application Server (WAS) 是IBM提供的一款强大的中间件产品,用于部署和管理企业级Java应用程序。WAS的性能调整是确保应用高效运行的关键环节,尤其是在高并发、大数据量的业务场景下。本文...

    WAS服务器技术指南

    通过对Servlet生命周期管理、JSP页面编译、数据库连接管理以及与其他Web服务器集成等内容的详细介绍,帮助读者全面理解WAS服务器技术的关键特性及其应用场景。对于从事企业级Java应用程序开发和部署的专业人士而言,...

    jsp+javaBean查询数据库

    总结,`jsp+javaBean查询数据库`涉及的关键点包括JSP与JavaBean的协作、数据库连接与查询、结果集处理、JavaBean的属性与方法、错误处理、资源管理以及数据库设计和安全。在实际开发中,还需要注意代码的可维护性、...

    db2数据库与中间件

    ### 三、数据库连接管理 - **连接到指定数据库:** - `$db2 connect to stmadc user db2admin using db2admin`:连接到名为 `stmadc` 的数据库,使用 `db2admin` 用户名和密码。 - `$db2 connect to dcold`:连接...

    TRS WAS 5.0 用户手册

    - **3.5.1 新建数据源**:允许管理员创建新的数据源,如数据库连接等。 - **3.5.2 测试数据源**:支持对数据源进行测试,确保其正常工作。 - **3.5.3 修改数据源**:提供了修改现有数据源配置的功能。 - **3.5.4 ...

    linux下得Was安装及配置

    5. **安装插件**:根据需要安装额外的插件,比如数据库连接器、版本控制工具等。 #### 使用MyEclipse进行WAS开发: - **创建项目**:在MyEclipse中创建新的Java Web项目。 - **配置服务器**:将WAS作为部署目标,在...

    WAS61在分布式平台上的安装和应用部署

    WAS作为一个中间件,负责处理应用程序的运行时环境,包括事务处理、安全管理、资源管理等。分布式平台意味着WAS将在多个节点上运行,以实现高可用性和负载均衡。 **必备条件** 在开始安装前,确保满足以下条件: 1....

    WAS V61安装调整和应用部署

    - **数据源配置**:通过管理控制台创建和配置数据源,确保应用程序能正确连接至数据库。 - **HTTP服务器集成**:安装IBM HTTP Server和HTTP插件,优化应用前端的请求处理。 - **应用部署**:将应用程序部署至WAS,...

    was报错日志

    6. **数据库连接问题**:如果WAS与数据库交互时出现问题,日志会记录连接失败、查询错误等,可能是数据库URL、用户名、密码错误,或者数据库服务器问题。 7. **容器问题**:Java容器(如JVM)的异常,如类加载错误...

    演示使用EntityFramework操作SQLite数据库的记录日记的小项目

    `OnConfiguring`方法用于配置数据库连接字符串。在这个例子中,我们使用SQLite,并指定数据库文件为`diary.db`。 然后,我们需要定义模型类,比如`DiaryEntry`,它将映射到数据库中的表。 ```csharp public class ...

    NC6+WAS安装及部署完全手册(Windows+Linux双版本)

    - 数据源配置:确保NC6与WAS的数据交互顺畅,需要正确配置数据库连接池。 - 安全性设置:包括用户认证、授权和加密,确保系统安全。 - 应用部署:发布和更新NC6应用到WAS,包括WAR或EAR文件的上传、热部署等。 - ...

    WAS和DB2调优.doc

    综上,WAS和DB2调优涉及多个层面,包括JVM内存管理、会话控制、并发处理、数据库连接管理、缓存策略以及日志记录和数据库参数配置。通过合理配置这些参数,可以显著提高系统的响应速度和稳定性,同时降低资源消耗,...

    WAS 常用配置截图

    【标题】"WAS 常用配置截图" 指的是WebSphere Application Server(WAS)的一些常见配置,这是IBM提供的一款强大的企业级应用服务器,用于部署和管理Java应用程序和Web服务。WAS在企业级环境中广泛使用,因为其稳定...

    was应用服务器项目部署

    - **特殊配置**:在WAS环境下,可能需要对某些配置项进行特定处理,例如注释掉`JNDIPrefix`以确保报表正常显示。 #### 八、总结 通过以上步骤,我们可以在WAS应用服务器上成功部署应用程序及其相关的报表项目。...

    WAS5.1安装图解

    最后,为了使WebSphere能够正常运行企业级应用,还需要进行一些关键的后续配置,例如数据库连接、安全管理、应用程序部署等。这些配置可以通过WebSphere的管理控制台进行,一个基于Web的图形用户界面,它允许管理员...

    win7 odbc SQORAS32: An Unsupported operation was attempted

    错误提示“Unsupported operation was attempted”通常意味着尝试执行的操作不被ODBC驱动程序或数据库管理系统支持。 描述中提到的链接指向了一个博客文章,虽然具体内容没有给出,但我们可以推测博主可能详细记录...

    在websphere7.0中配置mysql数据源

    在WAS中,我们需要创建认证别名来存储数据库连接的凭证。在“全局安全性”下的“Java认证和授权服务”中,选择“J2C认证数据”,然后新建别名。别名和用户标识可以相同,后者是连接数据库的用户名。确保为每个数据库...

Global site tag (gtag.js) - Google Analytics