设为首页 收藏本站
查看: 826|回复: 0

[经验分享] JSP中tomcat的SQL Server2000数据库连接池的配置

[复制链接]

尚未签到

发表于 2017-2-10 08:39:36 | 显示全部楼层 |阅读模式
JSP中tomcat的SQL Server2000数据库连接池的配置环境:1. 数据库:Microsoft SQL Server 20002. 数据库驱动程序:net.sourceforge.jtds.jdbc.DriverJNDI(Java Naming and Directory Interface)概述:Tomcat4(5)提供了一个与Java Enterprise Edition应用服务相兼容的JNDI--InitialContext实现实例。它的初始数据设置在$CATALINA_HOME/conf/server.xml文件里,并可能在网页应用环境描述(/WEB-INF/web.xml)里被下列元素引用:1) <env-entry>--环境入口,设置应用程序如何操作。2) <resource-ref>--资源参数,一般是数据库驱动程序、JavaMail Session、自定义类工厂等。3) <resource-env-ref>--在Servlet 2.4里用来简化设置不需认证信息的资源资源如环境参数、resource-ref变量。InitialContext在网页应用程序初始化时被设置,用来支持网页应用程序组件。所有的入口和资源都放在JNDI命名空间里的java:comp/env段里。点击下列网址以获取更多信息:1) Java命名和目录接口(Java Naming and Directory Interface)2) J2EE平台说明(J2EE Platform Specification)设置JNDI资源设置JNDI资源要在$CATALINA_HOME/conf/server.xml文件里使用下列标志符:1) <environment>--设置域个可变的JNDI InitialContext入口的名字和值(同上面说的<env-entry>等价)。2) <resource>--设置应用程序可用的资源的名字和类型(同上面说的<resource-ref>等价)。3) <resourceparams>--设置Java资源类工厂的名称或将用的JavaBean属性。4) <resourcelink>--给全局JNDI环境(JNDI Context)添加一个链接。上述这些标志符必须放在<context>和</context>之间(针对专门的网页应用程序)或<defaultcontext>和</defaultcontext>之间。此外,设在网页应用环境描述(Web Application Descriptor)(/WEB-INF/web.xml)里的名字和值也在初始环境(Initial Context)里被设置,当被<environemt>元素值允许时将被重设初始值。全局变量能在<server>子元素的<globalnamingresources>里设置。数据库连接池概述:数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池正是针对这个问题提出来的。数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素:1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。3) 如果最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。配置Tomcat数据库连接池的前提:1. 必须装有Java运行环境;2. 必须有SQL Server2000数据库服务器(可以不在本地);3. 必须有jtds.jar,并将它放在$CATALINA_HOME/common/lib目录下(只能是这里)。使用它是因为Microsoft公司的Java SQL Server驱动程序不支持二次查询,可到网上搜到。目前使用的是jtds-0.6.jar。在$CATALINA_HOME/conf/server.xml里设置数据库连接池:下面是配置的代码,必须放在<host>和</host>之间。<context path="/quality" docbase="quality" debug="0" reloadable="true" crosscontext="true"><logger classname="org.apache.catalina.logger.FileLogger" prefix="localhost_quality_log." suffix=".txt" timestamp="true"><resource name="jdbc/connectDB" auth="Container" type="javax.sql.DataSource"><resourceparams name="jdbc/connectDB"><parameter><name>maxActive</name><value>100</value></parameter><parameter><name>maxIdle</name><value>30</value></parameter><parameter><name>maxWait</name><value>10000</value></parameter><parameter><name>removeAbandoned</name><value>true</value></parameter><parameter><name>removeAbandonedTimeout</name><value>60</value></parameter><parameter><name>logAbandoned</name><value>false</value></parameter><parameter><name>factory</name><value>org.apache.commons.dbcp.BasicDataSourceFactory</value></parameter><parameter><name>username</name><value>Iorishinier</value></parameter><parameter><name>password</name><value>mypasswd</value></parameter><parameter><name>driverClassName</name><value>net.sourceforge.jtds.jdbc.Driver</value></parameter><parameter><name>url</name><value>jdbc:jtds:sqlserver://127.127.127.127:1433/Northwind</value></parameter></resourceparams></context>下面是一些参数的说明:<context path="/quality" docbase="quality" debug="0" reloadable="true" crosscontext="true">其中:1) path  指定路径,这里设定的是$CATALINA_HOME/webapps下的quality目录;2) docBase 文件根目录。3) reloader  当网页被更新时是否重新编译。4) maxActive 连接池的最大数据库连接数。设为0表示无限制。5) maxIdle  数据库连接的最大空闲时间。超过此空闲时间,数据库连接将被标记为不可用,然后被释放。设为0表示无限制。6) maxWait 最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。7) removeAbandoned 回收被遗弃的(一般是忘了释放的)数据库连接到连接池中。8) removeAbandonedTimeout 数据库连接过多长时间不用将被视为被遗弃而收回连接池中。9) logAbandoned 将被遗弃的数据库连接的回收记入日志。10) driverClassName JDBC驱动程序。11) url   数据库连接字符串在$CATALINA_HOME/webapps/quality/WEB-INF/web.xml里设置被引用的资源:下面是配置代码,必须放在<web-app>和</web-app>里。<resource-ref><description>connectDB test</description><res-ref-name>jdbc/connectDB</res-ref-name><res-type>javax.sql.DataSource</res-type><res-auth>Container</res-auth></resource-ref>下面是一下参数的必要说明:1) description  对被引用的资源的描述。2) res-ref-name  资源名称。见上面的<resourceparams name="jdbc/connectDB">3) res-type  资源类型。见上面的<resource name="jdbc/connectDB" auth="Container" type="javax.sql.DataSource">在JSP中使用资源:这是在$CATALINA_HOME/webapps/quality下的某级子目录里的jsp网页文件部分代码:<%@ page contentType="text/html;charset=GBK"%><%@ page errorPage="error.jsp"%><%@ page import="javax.naming.*"%><%@ page import="javax.sql.*"%><%@ page import="java.sql.*"%><html><head></head><body><%………………………………// 数据库操作Context ctx=null;Connection cnn=null;Statement stmt=null;ResultSet rs=null;try{ctx=new InitialContext();if(ctx==null)throw new Exception("没有匹配的环境");DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/connectDB");if(ds==null)throw new Exception("没有匹配数据库");cnn=ds.getConnection();stmt=cnn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);rs=stmt.executeQuery("select * from table1");………………………………}finally{if(rs!=null)rs.close();if(stmt!=null)stmt.close();if(cnn!=null)cnn.close();if(ctx!=null)ctx.close();}%></body></html>代码说明:DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/connectDB");上面这句应用了刚才设的资源。资源使用完要释放,尤其是Context资源,见try-catch-finally部分的finally代码段,这是一种好的习惯。资源释放时如果释放了上级资源,下级资源将先被释放。如:释放了ctx,那么资源释放顺序将是rs,stmt,cnn,ctx。换句话说,如果释放了ctx,那么rs,stmt和cnn都将不可用了。这里的释放资源只是将数据库连接返回连接池中,并不是把资源真正释放掉,见数据库连接池概述。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-339934-1-1.html 上篇帖子: 黑莓浏览器通过BES服务器访问Tomcat服务器上的Word文档,报错,不支持的媒体类型:application/vnd.ms-wsworld 下篇帖子: 一个空的工程在myEclipse下tomcat运行都出错!!求解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表