日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > java >内容正文

java

方立勋_30天掌握JavaWeb_JDBC、连接池、JNDI(三)

發(fā)布時(shí)間:2023/12/20 java 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 方立勋_30天掌握JavaWeb_JDBC、连接池、JNDI(三) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

使用數(shù)據(jù)庫(kù)連接池優(yōu)化程序性能

缺點(diǎn):用戶每次請(qǐng)求都需要向數(shù)據(jù)庫(kù)獲得鏈接,而數(shù)據(jù)庫(kù)創(chuàng)建連接通常需要消耗相對(duì)較大的資源,創(chuàng)建時(shí)間也較長(zhǎng)。假設(shè)網(wǎng)站一天10萬訪問量,數(shù)據(jù)庫(kù)服務(wù)器就需要?jiǎng)?chuàng)建10萬次連接,極大的浪費(fèi)數(shù)據(jù)庫(kù)的資源,并且極易造成數(shù)據(jù)庫(kù)服務(wù)器內(nèi)存溢出、拓機(jī)。

使用連接池:

編寫數(shù)據(jù)庫(kù)連接池

  • 編寫連接池需實(shí)現(xiàn)java.sql.DataSource接口。DataSource接口中定義了兩個(gè)重載的getConnection方法:
    Connection getConnection()
    Connection getConnection(String username, String password)

  • 實(shí)現(xiàn)DataSource接口,并實(shí)現(xiàn)連接池功能的步驟:

    • 在DataSource構(gòu)造函數(shù)中批量創(chuàng)建與數(shù)據(jù)庫(kù)的連接,并把創(chuàng)建的連接加入LinkedList對(duì)象中。
    • 實(shí)現(xiàn)getConnection方法,讓getConnection方法每次調(diào)用時(shí),從LinkedList中取一個(gè)Connection返回給用戶。
    • 當(dāng)用戶使用完Connection,調(diào)用Connection.close()方法時(shí),Collection對(duì)象應(yīng)保證將自己返回到LinkedList中,而不要把conn還給數(shù)據(jù)庫(kù)。
    • Collection保證將自己返回到LinkedList中是此處編程的難點(diǎn)。

一般有三種方式:
1. 寫一個(gè)connection子類,覆蓋close方法,增強(qiáng)close方法
2. 用包裝設(shè)計(jì)模式
3. 用動(dòng)態(tài)代理

使用動(dòng)態(tài)代理技術(shù)構(gòu)建連接池中的connection

proxyConn = (Connection) Proxy.newProxyInstance(this.getClass().getClassLoader(), conn.getClass().getInterfaces(),new InvocationHandler() {//此處為內(nèi)部類,當(dāng)close方法被調(diào)用時(shí)將conn還回池中,其它方法直接執(zhí)行public Object invoke(Object proxy, Method method,Object[] args) throws Throwable {if (method.getName().equals("close")) {pool.addLast(conn);return null;}return method.invoke(conn, args);}});

開源數(shù)據(jù)庫(kù)連接池

  • 現(xiàn)在很多WEB服務(wù)器(Weblogic, WebSphere, Tomcat)都提供了DataSoruce的實(shí)現(xiàn),即連接池的實(shí)現(xiàn)。通常我們把DataSource的實(shí)現(xiàn),按其英文含義稱之為數(shù)據(jù)源,數(shù)據(jù)源中都包含了數(shù)據(jù)庫(kù)連接池的實(shí)現(xiàn)。
  • 也有一些開源組織提供了數(shù)據(jù)源的獨(dú)立實(shí)現(xiàn):
    • DBCP 數(shù)據(jù)庫(kù)連接池
    • C3P0 數(shù)據(jù)庫(kù)連接池
  • 實(shí)際應(yīng)用時(shí)不需要編寫連接數(shù)據(jù)庫(kù)代碼,直接從數(shù)據(jù)源獲得數(shù)據(jù)庫(kù)的連接。程序員編程時(shí)也應(yīng)盡量使用這些數(shù)據(jù)源的實(shí)現(xiàn),以提升程序的數(shù)據(jù)庫(kù)訪問性能。

DBCP數(shù)據(jù)源

  • DBCP 是 Apache 軟件基金組織下的開源連接池實(shí)現(xiàn),使用DBCP數(shù)據(jù)源,應(yīng)用程序應(yīng)在系統(tǒng)中增加如下兩個(gè) jar 文件:
    • Commons-dbcp.jar:連接池的實(shí)現(xiàn)
    • Commons-pool.jar:連接池實(shí)現(xiàn)的依賴庫(kù)
  • Tomcat 的連接池正是采用該連接池來實(shí)現(xiàn)的。該數(shù)據(jù)庫(kù)連接池既可以與應(yīng)用服務(wù)器整合使用,也可由應(yīng)用程序獨(dú)立使用。

使用DBCP示例代碼:

static{InputStream in = JdbcUtil.class.getClassLoader().getResourceAsStream("dbcpconfig.properties");Properties prop = new Properties();prop.load(in);BasicDataSourceFactory factory = new BasicDataSourceFactory();dataSource = factory.createDataSource(prop); }

C3P0 數(shù)據(jù)源

配置Tomcat數(shù)據(jù)源

查看Tomcat文檔,示例代碼:

<Context><Resource name="jdbc/datasource" auth="Container"type="javax.sql.DataSource" username="root" password="root"driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/jdbc"maxActive="8" maxIdle="4"/> </Context> Context initCtx = new InitialContext(); Context envCtx = (Context) initCtx.lookup("java:comp/env"); dataSource = (DataSource)envCtx.lookup("jdbc/datasource");

特別提醒:此種配置下,驅(qū)動(dòng)jar文件需放置在tomcat的lib下

JNDI技術(shù)簡(jiǎn)介

  • JNDI(Java Naming and Directory Interface),Java命名和目錄接口,它對(duì)應(yīng)于J2SE中的javax.naming包,
  • 這套API的主要作用在于:它可以把Java對(duì)象放在一個(gè)容器中(JNDI容器),并為容器中的java對(duì)象取一個(gè)名稱,以后程序想獲得Java對(duì)象,只需通過名稱檢索即可。
  • 其核心API為Context,它代表JNDI容器,其lookup方法為檢索容器中對(duì)應(yīng)名稱的對(duì)象。

總結(jié)

以上是生活随笔為你收集整理的方立勋_30天掌握JavaWeb_JDBC、连接池、JNDI(三)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。