java项目连接oracle数据库,连的人多 *** 作数据库会越来越慢,怎么解决

java项目连接oracle数据库,连的人多 *** 作数据库会越来越慢,怎么解决,第1张

估计你oracle装在本地了吧,你机器是多大内存啊,oracle服务端是很耗内存的,如果你自己搞小项目建议用mysql吧,如果搞商用项目建议搞个大点的机器用作oracle服务端,我们开发的时候 服务端都装在单板上的,32G内存。

tomcat连接池的方法

1:连接池所要解决的问题:

应用程序每一次与数据库的连接都会由于网络传输和执行数据库查询而严重降低了程序的执行效率,因此我们需要用到连接池将将我们经常要用到的数据保存在连接池中,这样就减少了网络传输和因查询而给程序执行效率带来的影响。

2:连接池的本质:用一个集合保存查询出来的数据。

3:连接池的实现原理:

我们要使用Connect pool,首先要做的是访问datasource(所有的要访问的数据都放在这里面)。datasource数据源是通过LDAP(light directory access protocal)软件进行管理的(其本质就是将数据源以树状结构进行存储,这样的话,方便查询(树状结构的查询效率是最快的),java通过JNDI(java naming directory interface)访问LDAP里面的数据。

4:在tomcat种配置连接池:

1)打开tomcat目录下的conf/context.cfg:在里面加入如下配置

Xml代码

<Resource driverClassName="oracle.jdbc.driver.OracleDriver"url="jdbc:oracle:thin:@localhost:1521:orcl" username="scott" password="tiger" maxActive="20" type="javax.sql.DataSource" author="Container" name="ds"></Resource>

<Resource driverClassName="oracle.jdbc.driver.OracleDriver"url="jdbc:oracle:thin:@localhost:1521:orcl" username="scott" password="tiger" maxActive="20" type="javax.sql.DataSource" author="Container" name="ds"></Resource>

其中:maxActive:代表的是要配置的最大连接数。

type:资源类型

2)通过应用程序执行上述连接:

Java代码

<%@page contentType="text/html" %>

<%@page import="java.sql.*"%>

<%@page import="javax.sql.*"%>

<%@page import="javax.naming.*"%>

<html>

<body>

<% Context ctx=new InitialContext()

DataSource ds=(DataSource)ctx.lookup("java:comp/env/ds")//必须要

Connection con=ds.getConnection()

out.println("<h1>connection succeeful</h1>")

con.close()

%>

</body>

</html>

<%@page contentType="text/html" %>

<%@page import="java.sql.*"%>

<%@page import="javax.sql.*"%>

<%@page import="javax.naming.*"%>

<html>

<body>

<% Context ctx=new InitialContext()

DataSource ds=(DataSource)ctx.lookup("java:comp/env/ds")//必须要

Connection con=ds.getConnection()

out.println("<h1>connection succeeful</h1>")

con.close()

%>

</body>

</html>

conn.close():连接池是被覆盖了的,本质上的含义,把连接池借过来的连接还回去。

从零开始学java web 开发书上的例子

以sql server 2005为例,讲解tomcat6.0上的配置。

下载sqljdbc.jar放在tomcat的lib目录,tomcat/conf/context.xml文件,<Context></Context>中加入配置代码。

<Resource name="jdbc/dbplling" author="Container" type="javax.sql.DataSource" driverClassName="com.microsoft.sqlserverdriver.jdbc.sqlserverdriverDriver"url="jdbc:sqlserver//127.0.0.1:1433databasename=testdemo" username="sa" password="123" maxActive="100" maxIdle="30"maxWait="5000"></Resource>

web.xml

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee

http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

<welcome-file-list>

<welcome-file>index.jsp</welcome-file>

</welcome-file-list>

<resource-ref>

<description>SQL Server 2005 DataSource</description>

<res-ref-name>jdbc/dbpooling</res-ref-name>

<res-type>javax.sql.DataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

</web-app>

showUsers.jsp

<%@ page language="java" import="java.sql.*,javax.sql.*,javax.naming.*"

pageEncoding="GB2312"%>

<html>

<head>

<title>全部注册用户信息</title>

</head>

<body>

<%

try {

DataSource ds = null

InitialContext ctx = new InitialContext()//建立上下文对象

ds = (DataSource) ctx.lookup("java:comp/env/jdbc/dbpooling")//通过JNDI查找数据连接池

Connection conn = ds.getConnection()//获得数据库连接对象

PreparedStatement pstate = conn

.prepareStatement("select * from [User]")

ResultSet rs = pstate.executeQuery()

out.println("<table border=1>")

out.println("<tr><td>用户名</td><td>密码</td></tr>")

while (rs.next()) {

out.println("<tr><td>")

out.println(rs.getString(2))

out.println("</td><td>")

out.println(rs.getString(3))

out.println("</td></tr>")

}

out.println("</table>")

} catch (SQLException e) {

out.println(e)

}

%>

</body>

</html>

如果有次数限制就用for循环,没有次数限制就用while循环

你说的连接时间不同,是时间间隔不同还是时间点不同?

若间隔不同可以用sleep方法,若不同的时间点处理就比较复杂了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6688561.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存