我們需要使用Connection Pool的情況都通常都是指網(wǎng)絡(luò)連接,比如:DB connection, Socket的Connection,這些對(duì)象往往需要使用Pool來管理,因?yàn)檫@些對(duì)象的重復(fù)創(chuàng)建需要較長(zhǎng)的時(shí)間,是系統(tǒng)性能的瓶頸。
Connection Pool實(shí)現(xiàn)包括兩類:第一種是受管的Connection Pool,需要實(shí)現(xiàn)JCA的Resource Adapter規(guī)范,通過JNDI lookup出來ConnectionPool對(duì)象,然后調(diào)用受管ConnectionPool對(duì)象的getConnection方法獲得connection,第二種是自己實(shí)現(xiàn)一個(gè)Connection的Object Pool,通過自定義的ConnectionFactory類獲得一個(gè)connection。
第一種:受管的Connection Pool
目前J2EE Container中常用的connection pool有:
- DB Connection Pool
- JMS Connection Pool
- LDAP Connection Pool
- JCA Connection Pool
DB Connection Pool即JDBC connection pool,基本上所有的J2EE容器都提供了實(shí)現(xiàn),JMS connection pool一般的JMS Server都提供了實(shí)現(xiàn),LDAP connection pool由LDAP Server提供實(shí)現(xiàn), JCA connection pool需要自己實(shí)現(xiàn)resource adapter。
第二種:實(shí)現(xiàn)一個(gè)Connection的Object Pool
通常可以在已有第三方的Object Pool上實(shí)現(xiàn)自己的Connection Pool,如apache的commons pool,如果非要從頭開始當(dāng)然也是可以的。通常如果是要用規(guī)范的API獲取connection,如jdbc,jms,舉個(gè)例子DriverManager.getConnection, Connection.close, 為了使這個(gè)Connection Pool可以方便地用在各種jdbc驅(qū)動(dòng)上,而且為了使原來沒有使用該Connection Pool的應(yīng)用可以方便地切換到該Connection Pool上,我們可能需要用到AOP,這樣DriverManager.getConnection就是從pool中取出connecton(如果pool中有的話),Connection.close就是return給pool,從邏輯上釋放。用OO的方法也是可以實(shí)現(xiàn)的。
參考文章:JavaWorld:Dive into connection pooling with J2EE