日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

java 数据库连接池

發布時間:2024/4/15 数据库 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java 数据库连接池 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

數據庫連接池,是一種相當實用的應用程序。它可以保存、維護及創建用戶所需的數據庫連接。從而使得用戶得到一個連接的時間降低90%以上。大大提升了數據庫訪問的反應時間。

?

這個是一個開源的代碼。大家可以修改它、使用它。

?

希望我的代碼能對大家有用。

?

此代碼,經過1000數量級的多線程并發訪問測試。在四核CPU下也進行了多線程測試。保證了連接池在真多線程上同步訪問的安全性。

里面包含了一個公開的接口。使用這個接口里面的函數??梢暂p易創建使用數據庫連接池服務。

使用一個守護線程維護這個連接池,完全自動化。

?

下載連接:http://download.csdn.net/user/lauo1188

?

?

連接池接口類:

?

[java]?view plaincopy
  • package?mysql;??
  • import?java.sql.*;??
  • import?java.sql.ResultSet;??
  • public?interface?Pool??
  • {??
  • ????public?boolean?start(String?dbname,String?user,String?psw);??//啟動數據庫連接池服務??
  • ????//以下start函數將允許用戶設置最低空閑連接數,最高空閑連接數,最大連接數??
  • ????public?boolean?start(int?lows,int?maxs,int?maxc,String?dbname,String?user,String?psw);??
  • ????public?Connection?getConnection();??//得到連接器??
  • ????public?boolean?freeConnection(Connection?con);//將連接返回到連接池中??
  • ????public?boolean?close();?//清除連接池,并且關閉它(使之變得不可用)??
  • }??
  • ?

    ?

    ?

    第一個實現類:VectorPool

    ?

    ?

    [java]?view plaincopy
  • /**?
  • ?*?@(#)Pool.java?
  • ?*?
  • ?*?
  • ?*?@author??lauo?
  • ?*?@version?1.00?2010/5/15?
  • ?*?
  • ?*?測試完成于2010-5-16??22:40分?
  • ?*/??
  • package?mysql;??
  • import?mysql.*;??
  • import?java.sql.*;??
  • import?java.util.*;??
  • /*?
  • ?*這里將實現ConnectionPool接口?
  • ?*/??
  • public?class?VectorPool?extends?Thread?implements?Pool???
  • {??
  • ????protected?final?boolean?debug?=?false;?//是否debug態(如是??輸出debug狀態信息)??
  • ????protected?boolean?init?=?false;//是否已經將setting初始化??
  • ????//timeDiff???一個連接超過此時間未使用過,則需要更新此連接----1小時??
  • ????protected?final?long?timeDiff?=??60*60*1000?;//1小時60分鐘,1分鐘60秒,1秒1000毫秒??
  • ????protected?int?lows?=?20?;?//連接池的最小空閑連接數??
  • ????protected?int?maxs?=?100?;?//連接池的最大空閑連接數??
  • ????protected?int?maxc?=?100;??
  • ????protected?String?dbname?=?null;??
  • ????protected?String?user?=?null;??
  • ????protected?String?psw?=?null;??
  • ??????
  • ????protected?Integer?conCount?=?0;?//這個是靜態的。當前連接數??
  • ????//下面是連接保存的池??
  • ????protected?Vector<ConInfo>?pool?=?new?Vector<ConInfo>();??
  • ????public?VectorPool()???
  • ????{??
  • ????}??
  • ????public?void?start()??
  • ????{??
  • ??????????
  • ????}??
  • ????//得到當前連接數??
  • ????protected?int?getConCount()??
  • ????{??
  • ????????return?conCount;??
  • ????}??
  • ????/*?
  • ?????*設置數據庫連接的基本參數?
  • ?????*/??
  • ????public??synchronized??boolean?start(String?db,String?u,String?p)??
  • ????{??
  • ????????if(false?==?init?&&?null?!=?pool)//如果未初始化,且連接池可用??
  • ????????{??
  • ????????????dbname??=???db;??
  • ????????????user????=???u;??
  • ????????????psw?????=???p;??
  • ????????????if(test())??
  • ????????????{??
  • ????????????????init????=???true;??
  • ????????????????super.start();???
  • ????????????????return?true;??
  • ????????????}??
  • ????????????else?return?false;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ????}??
  • ????public?synchronized?boolean?start(int?l,int?m,int?mc,String?db,String?u,String?p)??
  • ????{??
  • ????????if(l<0?||?m<0?||l>=m?||?m>mc)//0<l<m<=mc??
  • ????????????return?false;??
  • ????????if(false?==?init?&&?null?!=?pool)//如果未初始化,且連接池可用??
  • ????????{??
  • ????????????dbname??=???db;??
  • ????????????user????=???u;??
  • ????????????psw?????=???p;??
  • ????????????if(test())??
  • ????????????{??
  • ????????????????init????=???true;??
  • ????????????????lows?=?l<5?5:l;??//這里允許的最小的值為5??
  • ????????????????maxs?=?m<10?10:m;?//這里允許的最小的值為10??
  • ????????????????maxc?=?mc<20??20:mc;//這里允許的連接數??
  • ????????????????super.start();???
  • ????????????????return?true;??
  • ????????????}??
  • ????????????else???
  • ????????????????return?false;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ????}??
  • ????/*?
  • ?????*從連接池得到一個連接?
  • ?????*/??
  • ????public?synchronized?Connection?getConnection()??
  • ????{??
  • ??????????
  • ????????if(init)??
  • ????????{??
  • ????????????ConInfo?c?=?getOneConnection();??
  • ????????????return?c!=null?c.con:null;//安全得到一個連接??
  • ????????}??
  • ????????else??
  • ????????????return?null;??
  • ????}??
  • ????/*?
  • ?????*得到一個連接,包含了lastTime信息?
  • ?????*/??
  • ????protected?synchronized?ConInfo?getOneConnection()??
  • ????{??
  • ????????if(pool.size()!=0)??
  • ????????{??
  • ????????????return?pool.remove(0);??
  • ????????}??
  • ????????else?//如果連接池為空,創建新的連接??
  • ????????{??
  • ????????????if(debug)?System.out.println("new?connection!");??
  • ????????????return?newConInfo();??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*將一個連接放回到連接池中?
  • ?????*/??
  • ????public?synchronized?boolean?freeConnection(Connection?con)??
  • ????{??
  • ????????if(init==false?||?con?==?null?)//當沒有init或者已經close之后?不應該free它進來。??
  • ????????????return?false;??
  • ????????ConInfo?c?=??new?ConInfo(con);//調用了ConInfo的構造函數??
  • ????????pool.addElement(c);??
  • ????????return?true;??
  • ????}??
  • ????/*?
  • ?????*將內容清空?
  • ?????*且將本連接池對象置為無用狀態?
  • ?????*/??
  • ????public?synchronized??boolean?close()??
  • ????{??
  • ????????if(init)??
  • ????????{??
  • ????????????init?=?false;??
  • ????????????for(int?i?=?0;?i?<pool.size();i++)??
  • ????????????????pool.get(i).close();??
  • ????????????pool.clear();??
  • ????????????pool????=???null;//將此連接池置為無用狀態。如果要新的鏈接池,重新創建鏈接池對象??
  • ????????????dbname??=???null;??
  • ????????????user????=???null;??
  • ????????????psw?????=???null;??
  • ????????????return?true;??
  • ????????}??
  • ????????else???
  • ????????????return?false;??
  • ????}??
  • ?????
  • ??
  • ????/*?
  • ?????*下面將是一個一線程執行體,當start連接池服務之后,由它來維護?
  • ?????*連接池里面的連接,從而保證他們能被正確的創建、注銷?
  • ?????*?
  • ?????*/??
  • ????public?void?run()??
  • ????{??
  • ????????final?long?sleepTime?=?2*1000??;?//2秒???
  • ????????final?long?refreshTime?=?10*60*1000;?//10分鐘運行一次。連接是否應該被更新??
  • ????????final?long?lowsCheckTime?=?2*1000;//10秒檢查一次。最低連接數檢查間隔時間??
  • ????????final?long?maxsCheckTime?=?60*1000;//1分鐘檢查一次。最大連接數時間??
  • ????????long?loop?=?0;??
  • ????????while(true)??
  • ????????{??
  • ????????????if(loop%refreshTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("call?refresh:"+pool.size());??
  • ????????????????refreshByTimeDiff();??
  • ????????????}??
  • ????????????if(loop%maxsCheckTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("call?toMaxs:"+pool.size());??
  • ????????????????toMaxs();??
  • ????????????}??
  • ????????????if(loop%lowsCheckTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("conCnt:"+conCount+"?call?toLows:"+pool.size());??
  • ????????????????toLows();??
  • ????????????}??
  • ????????????loop?+=?sleepTime;//更新loop的時間。??
  • ????????????try{??
  • ????????????????sleep(sleepTime);??
  • ????????????}??
  • ????????????catch(Exception?e){??
  • ????????????????e.printStackTrace();??
  • ????????????????stop();??
  • ????????????}??
  • ??????????????
  • ????????}??
  • ??????????
  • ????}??
  • ????/*?
  • ?????*使過小的空閑連接數恢復到lows?
  • ?????*/??
  • ????protected?void?toLows()??
  • ????{??
  • ????????int?size?=?pool.size();??
  • ????????/*?
  • ?????????*這里要避免直接使用pool.size進行判斷?
  • ?????????*當連接一直被get出去之后,size很難達到lows,故此?
  • ?????????*/??
  • ????????for(;size<lows;size++)??
  • ????????{??
  • ????????????if(debug)?System.out.println("toLows?is?running!");??
  • ????????????ConInfo?c?=??newConInfo();??
  • ????????????if(c!=null)??
  • ????????????????synchronized(pool)??
  • ????????????????{??
  • ????????????????????pool.addElement(c);??
  • ????????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*使過多的空閑連接數恢復到maxs;?
  • ?????*/??
  • ????protected?void?toMaxs()??
  • ????{??
  • ????????int?size?=?pool.size();??
  • ????????for(;size>maxs;size--)??
  • ????????{??
  • ????????????if(debug)?System.out.println("toMaxs?is?running!");??
  • ????????????try{??
  • ????????????????getConnection().close();??
  • ????????????????synchronized(conCount)//這里修改要同步好。??
  • ????????????????{??
  • ????????????????????conCount?--;??
  • ????????????????}??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*查找當前的連接池,找到timeDiff時間內未使用過的連接,刪除它們,如果連接數不足,將由toLows補齊?
  • ?????*一個危險的線程不安全函數?
  • ?????*/??
  • ????public?void?refreshByTimeDiff()??
  • ????{??
  • ????????Calendar?nowTime?=?Calendar.getInstance();??
  • ????????long?now?=?nowTime.getTimeInMillis();??
  • ????????for(int?i=0;i<pool.size();i++)??
  • ????????{??
  • ????????????ConInfo?c?=?getOneConnection();??
  • ????????????if(now??-?c.lastTime.getTimeInMillis()?>=timeDiff)//刪除它們??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("refresh?the?pool!,,,,,,,,");??
  • ????????????????synchronized(pool)//獲得pool的鎖??
  • ????????????????{??
  • ????????????????????pool.remove(i).close();//使用了ConInfo中的關閉函數??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*一個測試數據庫連接是否可用的函數?
  • ?????*/??
  • ????protected?boolean?test()??
  • ????{??
  • ????????int?cnt?=?10;??
  • ????????Connection?c;??
  • ????????do{??
  • ????????????c?=?newConnection();??
  • ????????????cnt?--?;??
  • ????????}while(c==null?&&?cnt>=0);??
  • ????????if(c!=null)??
  • ????????{??
  • ????????????(new?ConInfo(c)).close();??
  • ????????????return?true;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ??????????????
  • ????}??
  • ??
  • ????/*?
  • ?????*下面為內置的類,用于表明一個連接最后使用時間?
  • ?????*/??
  • ????class?ConInfo??
  • ????{??
  • ????????protected?Calendar?lastTime;????//連接最后使用時間??
  • ????????protected?Connection?con?=?null;????//對應的connection??
  • ????????public?ConInfo(Connection?c)??
  • ????????{??
  • ????????????con?=???c;??
  • ????????????lastTime?=?Calendar.getInstance();??
  • ????????}??
  • ????????public?synchronized?void?close()??
  • ????????{??
  • ????????????try??
  • ????????????{??
  • ????????????????if(con!=null)??
  • ????????????????????con.close();??
  • ????????????????synchronized(conCount)??
  • ????????????????{??
  • ????????????????????conCount-=con!=null?1:0;??
  • ????????????????}??
  • ????????????????lastTime?=?null;??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*創建一個新的連接?
  • ?????*/??
  • ????protected??Connection?newConnection()??
  • ????{??
  • ????????try??
  • ????????{??
  • ????????????Class.forName("com.mysql.jdbc.Driver");??
  • ????????????int?cnt?=?0;??
  • ????????????Connection?c?=?null;??
  • ????????????synchronized(conCount)??
  • ????????????{??
  • ????????????????if(conCount<=maxc)//當連接數沒超過既定最大連接數時??
  • ????????????????do??
  • ????????????????{??
  • ????????????????????try{??
  • ????????????????????c?=?DriverManager.getConnection(dbname,user,psw);??
  • ????????????????????}catch(Exception?es){c=null;if(debug)?System.out.println("create?new?connection?error!");}??
  • ????????????????????cnt++;??
  • ????????????????}while(null?==?c??&&?cnt<3);??
  • ????????????????conCount+=c!=null?1:0;??
  • ????????????}??
  • ????????????return?c;//創建一個新的connection??
  • ????????}??
  • ????????catch(Exception?e)??
  • ????????{??
  • ????????????e.printStackTrace();??
  • ????????????return?null;??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*得到一個新的連接?
  • ?????*/??
  • ????protected?ConInfo?newConInfo()??
  • ????{??
  • ????????Connection?c?=?newConnection();??
  • ????????if(c==null)??
  • ????????????return?null;??
  • ????????return?new?ConInfo(c);??
  • ????}??
  • ??
  • ????/*?
  • ?????*測試函數main?
  • ?????*/??
  • ????public?static?void?main(String[]?argvs)??
  • ????{??
  • ????????VectorPool?pool?=?new?VectorPool();??
  • ????????Connection?con?=?null;??
  • ????????boolean?flag?=?pool.start("jdbc:mysql://localhost/finance","root","");??
  • ????????int?cnt?=?10000;//1萬次??
  • ????????long?t0??=?Calendar.getInstance().getTimeInMillis();??
  • ????????/測試選項??
  • ????????final?boolean?tflag?=?true?;//如為true?為使用連接池??否則直接創建一個新連接。??
  • ????????//??
  • ????????while(flag){??
  • ??????????
  • ????????????con?=?tflag???pool.getConnection():pool.newConnection();//;??
  • ????????????try??
  • ????????????{?????
  • ????????????????Statement?stm?=?con.createStatement();??
  • ????????????????ResultSet?rev?=?stm.executeQuery("select?*?from?user");??
  • ????????????????while(false?&&?rev!=null?&&?rev.next())??
  • ????????????????{??
  • ????????????????????System.out.println(rev.getString("id"));??
  • ????????????????}??
  • ????????????????stm.close();??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ??????????????????
  • ????????????}??
  • ????????//??if(Math.abs(Math.random())%10<4)??
  • ????????????if(tflag)//使用完之后要釋放,否則會出大問題??
  • ????????????????pool.freeConnection(con);??
  • ????????????try{??
  • ????????????????if(!tflag)??
  • ????????????????????con.close();//釋放連接?當不用pool時??
  • ????????????}??
  • ????????????catch(Exception?exx)??
  • ????????????{??
  • ????????????????exx.printStackTrace();??
  • ????????????}??
  • ????????????/*?
  • ????????????try{?
  • ????????????????sleep(100);?///間隔時間?
  • ????????????}?
  • ????????????catch(Exception?ee)?
  • ????????????{?
  • ????????????????ee.printStackTrace();?
  • ????????????}?
  • ????????????*/??
  • ????????????//System.out.println("cnt:"+cnt);??
  • ????????//??System.out.println("con_Cnt:"+pool.getConCount());??
  • ????????????if(--cnt<0)??
  • ????????????????break;??
  • ????????}??
  • ????????System.out.println("used?time:"+(Calendar.getInstance().getTimeInMillis()-t0));??
  • ????}??
  • }??
  • /*?
  • ?*?
  • use?the?pool;?
  • cnt:3?
  • cnt:2?
  • cnt:1?
  • cnt:0?
  • used?time:11286?
  • ---用了11.286秒?
  • cnt:9?
  • cnt:8?
  • cnt:7?
  • cnt:6?
  • cnt:5?
  • cnt:4?
  • cnt:3?
  • cnt:2?
  • cnt:1?
  • cnt:0?
  • used?time:129376?
  • 用了129.376秒(多了整整十倍)。?
  • 再測試一次:?
  • cnt:1?
  • cnt:0?
  • used?time:7871??
  • ---used?the?pool??7.871秒?
  • cnt:4?
  • cnt:3?
  • cnt:2?
  • cnt:1?
  • cnt:0?
  • used?time:100084??
  • ----create?the?connection?one?by?one???100.084秒?
  • */??
  • ?

    ?

    ?

    第二個實現類:ListPool

    ?

    ?

    [java]?view plaincopy
  • /*?
  • ?*?@(#)Pool.java?
  • ?*?
  • ?*?
  • ?*?@author??
  • ?*?@version?1.00?2010/5/15?
  • ?*/??
  • package?mysql;??
  • import?mysql.*;??
  • import?java.sql.*;??
  • import?java.util.*;??
  • /*?
  • ?*這里將實現ConnectionPool接口?
  • ?*/??
  • public?class?ListPool?extends?Thread?implements?Pool???
  • {??
  • ????protected?final?boolean?debug?=?false;?//是否debug態(如是??輸出debug狀態信息)??
  • ????protected?boolean?init?=?false;//是否已經將setting初始化??
  • ????//timeDiff???一個連接超過此時間未使用過,則需要更新此連接----1小時??
  • ????protected?final?long?timeDiff?=??60*60*1000?;//1小時60分鐘,1分鐘60秒,1秒1000毫秒??
  • ????protected?int?lows?=?20?;?//連接池的最小空閑連接數??
  • ????protected?int?maxs?=?100?;?//連接池的最大空閑連接數??
  • ????protected?int?maxc?=?100;??
  • ????protected?String?dbname?=?null;??
  • ????protected?String?user?=?null;??
  • ????protected?String?psw?=?null;??
  • ??????
  • ????protected?Integer?conCount?=?0;?//這個是靜態的。當前連接數??
  • ????//下面是連接保存的池??
  • ????protected?LinkedList<ConInfo>?pool?=?new?LinkedList<ConInfo>();??
  • ????public?ListPool()???
  • ????{??
  • ????}??
  • ????public?void?start()??
  • ????{??
  • ??????????
  • ????}??
  • ????//得到當前連接數??
  • ????protected?int?getConCount()??
  • ????{??
  • ????????return?conCount;??
  • ????}??
  • ????/*?
  • ?????*設置數據庫連接的基本參數?
  • ?????*/??
  • ????public??synchronized??boolean?start(String?db,String?u,String?p)??
  • ????{??
  • ????????if(false?==?init?&&?null?!=?pool)//如果未初始化,且連接池可用??
  • ????????{??
  • ????????????dbname??=???db;??
  • ????????????user????=???u;??
  • ????????????psw?????=???p;??
  • ????????????if(test())??
  • ????????????{??
  • ????????????????init????=???true;??
  • ????????????????super.start();???
  • ????????????????return?true;??
  • ????????????}??
  • ????????????else?return?false;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ????}??
  • ????public?synchronized?boolean?start(int?l,int?m,int?mc,String?db,String?u,String?p)??
  • ????{??
  • ????????if(l<0?||?m<0?||l>=m?||?m>mc)//0<l<m<=mc??
  • ????????????return?false;??
  • ????????if(false?==?init?&&?null?!=?pool)//如果未初始化,且連接池可用??
  • ????????{??
  • ????????????dbname??=???db;??
  • ????????????user????=???u;??
  • ????????????psw?????=???p;??
  • ????????????if(test())??
  • ????????????{??
  • ????????????????init????=???true;??
  • ????????????????lows?=?l<5?5:l;??//這里允許的最小的值為5??
  • ????????????????maxs?=?m<10?10:m;?//這里允許的最小的值為10??
  • ????????????????maxc?=?mc<20??20:mc;//這里允許的連接數??
  • ????????????????super.start();???
  • ????????????????return?true;??
  • ????????????}??
  • ????????????else???
  • ????????????????return?false;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ????}??
  • ????/*?
  • ?????*從連接池得到一個連接?
  • ?????*/??
  • ????public?synchronized?Connection?getConnection()??
  • ????{??
  • ??????????
  • ????????if(init)??
  • ????????{??
  • ????????????ConInfo?c?=?getOneConnection();??
  • ????????????return?c!=null?c.con:null;//安全得到一個連接??
  • ????????}??
  • ????????else??
  • ????????????return?null;??
  • ????}??
  • ????/*?
  • ?????*得到一個連接,包含了lastTime信息?
  • ?????*/??
  • ????protected?synchronized?ConInfo?getOneConnection()??
  • ????{??
  • ????????if(pool.size()!=0)??
  • ????????{??
  • ????????????return?pool.remove(0);??
  • ????????}??
  • ????????else?//如果連接池為空,創建新的連接??
  • ????????{??
  • ????????????if(debug)?System.out.println("new?connection!");??
  • ????????????return?newConInfo();??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*將一個連接放回到連接池中?
  • ?????*/??
  • ????public?synchronized?boolean?freeConnection(Connection?con)??
  • ????{??
  • ????????if(init==false?||?con?==?null?)//當沒有init或者已經close之后?不應該free它進來。??
  • ????????????return?false;??
  • ????????ConInfo?c?=??new?ConInfo(con);//調用了ConInfo的構造函數??
  • ????????pool.add(c);??
  • ????????return?true;??
  • ????}??
  • ????/*?
  • ?????*將內容清空?
  • ?????*且將本連接池對象置為無用狀態?
  • ?????*/??
  • ????public?synchronized??boolean?close()??
  • ????{??
  • ????????if(init)??
  • ????????{??
  • ????????????init?=?false;??
  • ????????????for(int?i?=?0;?i?<pool.size();i++)??
  • ????????????????pool.get(i).close();??
  • ????????????pool.clear();??
  • ????????????pool????=???null;//將此連接池置為無用狀態。如果要新的鏈接池,重新創建鏈接池對象??
  • ????????????dbname??=???null;??
  • ????????????user????=???null;??
  • ????????????psw?????=???null;??
  • ????????????return?true;??
  • ????????}??
  • ????????else???
  • ????????????return?false;??
  • ????}??
  • ?????
  • ??
  • ????/*?
  • ?????*下面將是一個一線程執行體,當start連接池服務之后,由它來維護?
  • ?????*連接池里面的連接,從而保證他們能被正確的創建、注銷?
  • ?????*?
  • ?????*/??
  • ????public?void?run()??
  • ????{??
  • ????????final?long?sleepTime?=?2*1000??;?//2秒???
  • ????????final?long?refreshTime?=?10*60*1000;?//10分鐘運行一次。連接是否應該被更新??
  • ????????final?long?lowsCheckTime?=?2*1000;//10秒檢查一次。最低連接數檢查間隔時間??
  • ????????final?long?maxsCheckTime?=?60*1000;//1分鐘檢查一次。最大連接數時間??
  • ????????long?loop?=?0;??
  • ????????while(true)??
  • ????????{??
  • ????????????if(loop%refreshTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("call?refresh:"+pool.size());??
  • ????????????????refreshByTimeDiff();??
  • ????????????}??
  • ????????????if(loop%maxsCheckTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("call?toMaxs:"+pool.size());??
  • ????????????????toMaxs();??
  • ????????????}??
  • ????????????if(loop%lowsCheckTime?==?0)??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("conCnt:"+conCount+"?call?toLows:"+pool.size());??
  • ????????????????toLows();??
  • ????????????}??
  • ????????????loop?+=?sleepTime;//更新loop的時間。??
  • ????????????try{??
  • ????????????????sleep(sleepTime);??
  • ????????????}??
  • ????????????catch(Exception?e){??
  • ????????????????e.printStackTrace();??
  • ????????????????stop();??
  • ????????????}??
  • ??????????????
  • ????????}??
  • ??????????
  • ????}??
  • ????/*?
  • ?????*使過小的空閑連接數恢復到lows?
  • ?????*/??
  • ????protected?void?toLows()??
  • ????{??
  • ????????int?size?=?pool.size();??
  • ????????/*?
  • ?????????*這里要避免直接使用pool.size進行判斷?
  • ?????????*當連接一直被get出去之后,size很難達到lows,故此?
  • ?????????*/??
  • ????????for(;size<lows;size++)??
  • ????????{??
  • ????????????if(debug)?System.out.println("toLows?is?running!");??
  • ????????????ConInfo?c?=??newConInfo();??
  • ????????????if(c!=null)??
  • ????????????????synchronized(pool)??
  • ????????????????{??
  • ????????????????????pool.add(c);??
  • ????????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*使過多的空閑連接數恢復到maxs;?
  • ?????*/??
  • ????protected?void?toMaxs()??
  • ????{??
  • ????????int?size?=?pool.size();??
  • ????????for(;size>maxs;size--)??
  • ????????{??
  • ????????????if(debug)?System.out.println("toMaxs?is?running!");??
  • ????????????try{??
  • ????????????????getConnection().close();??
  • ????????????????synchronized(conCount)//這里修改要同步好。??
  • ????????????????{??
  • ????????????????????conCount?--;??
  • ????????????????}??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*查找當前的連接池,找到timeDiff時間內未使用過的連接,刪除它們,如果連接數不足,將由toLows補齊?
  • ?????*一個危險的線程不安全函數?
  • ?????*/??
  • ????public?void?refreshByTimeDiff()??
  • ????{??
  • ????????Calendar?nowTime?=?Calendar.getInstance();??
  • ????????long?now?=?nowTime.getTimeInMillis();??
  • ????????for(int?i=0;i<pool.size();i++)??
  • ????????{??
  • ????????????ConInfo?c?=?getOneConnection();??
  • ????????????if(now??-?c.lastTime.getTimeInMillis()?>=timeDiff)//刪除它們??
  • ????????????{??
  • ????????????????if(debug)?System.out.println("refresh?the?pool!,,,,,,,,");??
  • ????????????????synchronized(pool)//獲得pool的鎖??
  • ????????????????{??
  • ????????????????????pool.remove(i).close();//使用了ConInfo中的關閉函數??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*一個測試數據庫連接是否可用的函數?
  • ?????*/??
  • ????protected?boolean?test()??
  • ????{??
  • ????????int?cnt?=?10;??
  • ????????Connection?c;??
  • ????????do{??
  • ????????????c?=?newConnection();??
  • ????????????cnt?--?;??
  • ????????}while(c==null?&&?cnt>=0);??
  • ????????if(c!=null)??
  • ????????{??
  • ????????????(new?ConInfo(c)).close();??
  • ????????????return?true;??
  • ????????}??
  • ????????else??
  • ????????????return?false;??
  • ??????????????
  • ????}??
  • ??
  • ????/*?
  • ?????*下面為內置的類,用于表明一個連接最后使用時間?
  • ?????*/??
  • ????class?ConInfo??
  • ????{??
  • ????????protected?Calendar?lastTime;????//連接最后使用時間??
  • ????????protected?Connection?con?=?null;????//對應的connection??
  • ????????public?ConInfo(Connection?c)??
  • ????????{??
  • ????????????con?=???c;??
  • ????????????lastTime?=?Calendar.getInstance();??
  • ????????}??
  • ????????public?synchronized?void?close()??
  • ????????{??
  • ????????????try??
  • ????????????{??
  • ????????????????if(con!=null)??
  • ????????????????????con.close();??
  • ????????????????synchronized(conCount)??
  • ????????????????{??
  • ????????????????????conCount-=con!=null?1:0;??
  • ????????????????}??
  • ????????????????lastTime?=?null;??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*創建一個新的連接?
  • ?????*/??
  • ????protected??Connection?newConnection()??
  • ????{??
  • ????????try??
  • ????????{??
  • ????????????Class.forName("com.mysql.jdbc.Driver");??
  • ????????????int?cnt?=?0;??
  • ????????????Connection?c?=?null;??
  • ????????????synchronized(conCount)??
  • ????????????{??
  • ????????????????if(conCount<=maxc)//當連接數沒超過既定最大連接數時??
  • ????????????????do??
  • ????????????????{??
  • ????????????????????try{??
  • ????????????????????c?=?DriverManager.getConnection(dbname,user,psw);??
  • ????????????????????}catch(Exception?es){c=null;if(debug)?System.out.println("create?new?connection?error!");}??
  • ????????????????????cnt++;??
  • ????????????????}while(null?==?c??&&?cnt<3);??
  • ????????????????conCount+=c!=null?1:0;??
  • ????????????}??
  • ????????????return?c;//創建一個新的connection??
  • ????????}??
  • ????????catch(Exception?e)??
  • ????????{??
  • ????????????e.printStackTrace();??
  • ????????????return?null;??
  • ????????}??
  • ????}??
  • ????/*?
  • ?????*得到一個新的連接?
  • ?????*/??
  • ????protected?ConInfo?newConInfo()??
  • ????{??
  • ????????Connection?c?=?newConnection();??
  • ????????if(c==null)??
  • ????????????return?null;??
  • ????????return?new?ConInfo(c);??
  • ????}??
  • ??
  • ????/*?
  • ?????*測試函數main?
  • ?????*/??
  • ????public?static?void?main(String[]?argvs)??
  • ????{??
  • ????????ListPool?pool?=?new?ListPool();??
  • ????????Connection?con?=?null;??
  • ????????boolean?flag?=?pool.start("jdbc:mysql://localhost/finance","root","");??
  • ????????int?cnt?=?10000;//1萬次??
  • ????????long?t0??=?Calendar.getInstance().getTimeInMillis();??
  • ????????/測試選項??
  • ????????final?boolean?tflag?=?true?;//如為true?為使用連接池??否則直接創建一個新連接。??
  • ????????//??
  • ????????while(flag){??
  • ??????????
  • ????????????con?=?tflag???pool.getConnection():pool.newConnection();//;??
  • ????????????try??
  • ????????????{?????
  • ????????????????Statement?stm?=?con.createStatement();??
  • ????????????????ResultSet?rev?=?stm.executeQuery("select?*?from?user");??
  • ????????????????while(false?&&?rev!=null?&&?rev.next())??
  • ????????????????{??
  • ????????????????????System.out.println(rev.getString("id"));??
  • ????????????????}??
  • ????????????????stm.close();??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ??????????????????
  • ????????????}??
  • ????????//??if(Math.abs(Math.random())%10<4)??
  • ????????????if(tflag)//使用完之后要釋放,否則會出大問題??
  • ????????????????pool.freeConnection(con);??
  • ????????????try{??
  • ????????????????if(!tflag)??
  • ????????????????????con.close();//釋放連接?當不用pool時??
  • ????????????}??
  • ????????????catch(Exception?exx)??
  • ????????????{??
  • ????????????????exx.printStackTrace();??
  • ????????????}??
  • ????????????/*?
  • ????????????try{?
  • ????????????????sleep(100);?///間隔時間?
  • ????????????}?
  • ????????????catch(Exception?ee)?
  • ????????????{?
  • ????????????????ee.printStackTrace();?
  • ????????????}?
  • ????????????*/??
  • ????????//??System.out.println("cnt:"+cnt);??
  • ????????//??System.out.println("con_Cnt:"+pool.getConCount());??
  • ????????????if(--cnt<0)??
  • ????????????????break;??
  • ????????}??
  • ????????System.out.println("used?time:"+(Calendar.getInstance().getTimeInMillis()-t0));??
  • ????}??
  • }??
  • /*?
  • ?*?
  • use?the?pool;?
  • cnt:3?
  • cnt:2?
  • cnt:1?
  • cnt:0?
  • used?time:11286?
  • ---用了11.286秒?
  • cnt:9?
  • cnt:8?
  • cnt:7?
  • cnt:6?
  • cnt:5?
  • cnt:4?
  • cnt:3?
  • cnt:2?
  • cnt:1?
  • cnt:0?
  • used?time:129376?
  • 用了129.376秒(多了整整十倍)。?
  • -------listPool?
  • used?time:10995?
  • */??
  • ?

    ?

    ?

    ?

    ?

    一個測試類:testPool

    ?

    [java]?view plaincopy
  • /**?
  • ?*?@(#)testPool.java?
  • ?*?
  • ?*?
  • ?*?@author??
  • ?*?@version?1.00?2010/5/15?
  • ?*/??
  • package??mysql;??
  • import?java.sql.*;??
  • import?java.util.*;??
  • import?mysql.*;??
  • public?class?testPool?extends?Thread??
  • {??
  • ????protected??String?dbname?=?null,??
  • ????????????????????????user?=?null,??
  • ????????????????????????psw??=?null;??
  • ????Pool?pool=?null;??
  • ????boolean?flag?=?true;??
  • ????public?testPool(Pool?p,boolean?f,String?d,String?u,String?pw)???
  • ????{??
  • ????????pool?=?p;??
  • ????????flag?=?f;??
  • ????????dbname?=?d;??
  • ????????user?=?u;??
  • ????????psw?=?pw;??
  • ????}??
  • ????public?void?start(int?n)??
  • ????{??
  • ????????while(n-->0)??
  • ????????{??
  • ????????????super.start();??
  • ????????}??
  • ????}??
  • ????public?void?run()??
  • ????{??
  • ????????long?id?=?this.getId();??
  • ????????Connection?con?=?null;??
  • ????????int?cnt?=?100;//1萬次??
  • ????????long?t0??=?Calendar.getInstance().getTimeInMillis();??
  • ????????/測試選項??
  • ????????final?boolean?tflag?=?true?;//如為true?為使用連接池??否則直接創建一個新連接。??
  • ????????//??
  • ????????while(flag){??
  • ??????????
  • ????????????con?=?tflag???pool.getConnection():newConnection();//;??
  • ????????????if(con?==?null)?continue;??
  • ????????????try??
  • ????????????{?????
  • ????????????????Statement?stm?=?con.createStatement();??
  • ????????????????ResultSet?rev?=?stm.executeQuery("select?*?from?user");??
  • ????????????????while(false?&&?rev!=null?&&?rev.next())??
  • ????????????????{??
  • ????????????????????System.out.println(rev.getString("id"));??
  • ????????????????}??
  • ????????????????stm.close();??
  • ????????????}??
  • ????????????catch(Exception?e)??
  • ????????????{??
  • ????????????????e.printStackTrace();??
  • ??????????????????
  • ????????????}??
  • ????????//??if(Math.abs(Math.random())%10<4)??
  • ????????????if(tflag)//使用完之后要釋放,否則會出大問題??
  • ????????????????pool.freeConnection(con);??
  • ????????????try{??
  • ????????????????if(!tflag)??
  • ????????????????????con.close();//釋放連接?當不用pool時??
  • ????????????}??
  • ????????????catch(Exception?exx)??
  • ????????????{??
  • ????????????????exx.printStackTrace();??
  • ????????????}??
  • ????????????/*?
  • ????????????try{?
  • ????????????????sleep(100);?///間隔時間?
  • ????????????}?
  • ????????????catch(Exception?ee)?
  • ????????????{?
  • ????????????????ee.printStackTrace();?
  • ????????????}?
  • ????????????*/??
  • ????????//??System.out.println("threadId:"+id+"??cnt:"+cnt);??
  • ???????????//System.out.println("con_Cnt:"+((Pool)pool).getConCount());??
  • ????????????if(--cnt<0)??
  • ????????????????break;??
  • ????????}??
  • ????????System.out.println("used?time:"+(Calendar.getInstance().getTimeInMillis()-t0));??
  • ????}??
  • ????public?Connection?newConnection()??
  • ????{??
  • ????????try??
  • ????????{??
  • ????????????Class.forName("com.mysql.jdbc.Driver");??
  • ????????????int?cnt?=?0;??
  • ????????????Connection?c?=?null;??
  • ????????????do??
  • ????????????{??
  • ????????????????c?=?DriverManager.getConnection(dbname,user,psw);??
  • ????????????????cnt++;??
  • ????????????}while(null?==?c?&&?cnt<15);??
  • ????????????if(null?==?c)??
  • ????????????????return?null;??
  • ????????????else??
  • ????????????????return?c;//創建一個新的connection??
  • ????????}??
  • ????????catch(Exception?e)??
  • ????????{??
  • ????????????e.printStackTrace();??
  • ????????????return?null;??
  • ????????}??
  • ????}??
  • ????public?static?void?main(String?argv[])??
  • ????{??
  • ????????Pool?pool?=?null;??
  • ????????boolean?who?=?true;??
  • ????????pool?=?who???new?VectorPool()?:?new?ListPool();??
  • ????????boolean?flag?=?pool.start(20,30,100,"jdbc:mysql://localhost/finance","root","");??
  • ????????int?cnt?=?100;??
  • ????????while(cnt-->0)??
  • ????????{??
  • ????????????testPool?p?=?new?testPool(pool,flag,"jdbc:mysql://localhost/finance","root","");??
  • ????????????p.start();??
  • ????????}?????
  • ????
  • ????}??
  • ??????
  • }??
  • /*?
  • ?*測試結果表明,當100*100時,Pool要略優于ListPool(差異不大,如下)?
  • ?*?
  • Pool:?
  • used?time:4967?
  • used?time:4997?
  • used?time:5017?
  • used?time:5218?
  • used?time:5558?
  • used?time:4937?
  • used?time:4977?
  • used?time:5107?
  • used?time:5378?
  • used?time:5368?
  • used?time:5408?
  • 2:?
  • used?time:5779?
  • used?time:6049?
  • used?time:6269?
  • used?time:6269?
  • used?time:6209?
  • used?time:6009?
  • ListPool?
  • used?time:5788?
  • used?time:6148?
  • used?time:5589?
  • used?time:5819?
  • used?time:5619?
  • used?time:6089?
  • used?time:5558?
  • used?time:6029?
  • used?time:5629?
  • 2?
  • used?time:5158?
  • used?time:5188?
  • used?time:5808?
  • used?time:5117?
  • used?time:5648?
  • used?time:5718?
  • used?time:5668?
  • used?time:5868?
  • used?time:5908?
  • used?time:5948?
  • used?time:5958?
  • used?time:5828?
  • used?time:5969?
  • used?time:5979?
  • used?time:6329?
  • used?time:6089?
  • ?*/??
  • ?

    轉載于:https://www.cnblogs.com/jiushini/archive/2012/06/05/2535595.html

    總結

    以上是生活随笔為你收集整理的java 数据库连接池的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    91在线观 | 不卡国产在线 | 久久久久久久久毛片精品 | 麻花豆传媒一二三产区 | 美女中文字幕 | 天天夜夜操 | 91探花国产综合在线精品 | 久久欧美视频 | 2019中文在线观看 | 狠狠色丁香婷婷综合橹88 | 国产精品久久久久亚洲影视 | 久久的色 | 337p日本欧洲亚洲大胆裸体艺术 | 久久不色 | 国产精品专区一 | 97免费在线观看视频 | 色狠狠婷婷 | 黄色aa久久 | 免费的黄色的网站 | 最新av免费在线观看 | www亚洲精品 | 黄色大片av| 久久久久久看片 | 欧美一级久久久 | 天天天天天天天操 | 精品国产一区二区久久 | 精品久久久久久综合日本 | 综合久久五月天 | 国产精品 日本 | 精精国产xxxx视频在线播放 | 92中文资源在线 | 久久精品精品电影网 | 最新真实国产在线视频 | 国产三级av在线 | 成年人网站免费在线观看 | 人人看人人做人人澡 | 国产啊v在线观看 | 久久久在线观看 | 豆豆色资源网xfplay | 五月天久久久久久 | 日本三级国产 | 亚洲人人射 | 久草在线视频免赞 | 激情视频免费观看 | 久久久国产在线视频 | 久久精品3 | 亚洲精欧美一区二区精品 | 一区二区视频在线观看免费 | 麻豆视频在线观看免费 | 日韩特级黄色片 | 狠狠色狠狠综合久久 | 国产成人一二三 | 免费视频 三区 | 99久久久久国产精品免费 | 日韩av进入 | 色综合久久88 | 亚洲精品字幕在线观看 | 国产精品免费久久久久久久久久中文 | 日韩在线视频观看免费 | wwxxxx日本 | 日韩精品一区二区久久 | 亚洲国产影院av久久久久 | 五月天激情婷婷 | 亚洲精品中文字幕在线 | 国产涩图 | 丁香久久综合 | 欧美精品久久天天躁 | 免费看三级黄色片 | 国精产品999国精产品岳 | 插插插色综合 | 亚洲日本在线视频观看 | 黄色软件视频大全免费下载 | 亚洲人天堂 | 91九色在线视频 | 丁香婷婷激情国产高清秒播 | 欧美另类成人 | 国产精品久久久久久久久久直播 | 麻豆首页 | 98涩涩国产露脸精品国产网 | 黄色a视频免费 | 激情av在线资源 | 日韩三级一区 | 国内99视频 | www.xxxx变态.com| 日日碰狠狠添天天爽超碰97久久 | 99精品视频一区 | 狠狠网亚洲精品 | 亚洲天天摸日日摸天天欢 | 99视屏 | 国产一区二区精品在线 | 久操视频在线观看 | 国产精品一区二区三区久久久 | 久久经典国产视频 | 欧美一区二区三区不卡 | 国产爽妇网 | 97av视频 | 亚洲视频久久久 | 亚洲一级片在线看 | 精品视频在线看 | 五月婷婷综合在线视频 | 国产精品夜夜夜一区二区三区尤 | 久久久国产日韩 | 91精品导航| 亚洲永久在线 | 久久麻豆视频 | 亚洲精品国产精品国自产观看 | wwwav视频| 亚洲成人999| 国产精品区一区 | 国内精自线一二区永久 | 国产经典 欧美精品 | 五月婷婷综合在线 | 夜夜躁狠狠燥 | 99久久99久久综合 | 99久久精品国产一区 | av播放在线 | 在线观看播放av | 免费看黄色大全 | 国产福利在线不卡 | 天天操天天干天天 | 黄色大全免费网站 | 国产精品中文字幕av | 精品国产视频在线观看 | 日韩美女黄色片 | av不卡在线看 | 2021国产视频 | 成人免费观看完整版电影 | 国产精品va在线播放 | 麻豆av一区二区三区在线观看 | 久久免费视频2 | 99久久精品国产一区二区三区 | 中文字幕欧美日韩va免费视频 | 91精品婷婷国产综合久久蝌蚪 | av电影中文 | 伊人六月 | 中文字幕免费观看视频 | 免费看搞黄视频网站 | 久久亚洲成人网 | 久久国产网站 | 91精品国产自产91精品 | 久久久官网 | 九九热免费在线视频 | 日日摸日日 | 国产精久久久 | 国产999在线 | 91视频在线国产 | 亚洲国产免费网站 | 免费成人av电影 | 性色av免费在线观看 | 久久国产欧美日韩 | 国产黄色电影 | 日本色小说视频 | 精品国内自产拍在线观看视频 | 免费视频久久 | 超碰在线观看99 | 精品嫩模福利一区二区蜜臀 | 国产精品99久久久久久宅男 | 日韩r级电影在线观看 | 亚洲精品18日本一区app | 久久精品视频免费 | 国产精品99久久久久人中文网介绍 | 99久久99久久精品 | 成人全视频免费观看在线看 | 69精品视频在线观看 | 精品国产一区二区三区久久久久久 | 国产精品免费视频一区二区 | 婷婷射五月 | 一级片免费在线 | www.国产毛片 | 日韩免费观看视频 | 日韩一区二区三区免费视频 | 正在播放一区二区 | 国产美女视频免费观看的网站 | 国产精品亚洲视频 | 97超碰人人爱| 亚洲黄色一级电影 | 亚洲成人家庭影院 | 久久99精品久久只有精品 | 激情综合网色播五月 | 韩国av在线| 国产美女精品久久久 | 久久伦理电影网 | 麻豆你懂的 | 成人免费在线电影 | 在线观看蜜桃视频 | 国产亚洲精品bv在线观看 | 最近中文字幕国语免费高清6 | 欧美日韩视频一区二区三区 | 午夜国产一区二区三区四区 | 亚洲精品色婷婷 | 蜜臀av夜夜澡人人爽人人桃色 | 国产成人综合图片 | 美女久久视频 | 午夜影视剧场 | 天天拍天天爽 | 天天干夜夜操视频 | 在线视频免费观看 | 香蕉一区| 91精品专区| 99久久久久国产精品免费 | 丁香视频在线观看 | 美女网站视频免费都是黄 | 在线观看av的网站 | 亚洲最大在线视频 | 九七在线视频 | 国产999 | 久草在线观 | 亚洲一区不卡视频 | 欧美精品久久久久久 | 正在播放亚洲精品 | av片在线观看免费 | 日韩午夜在线 | 91精品国自产拍天天拍 | 国产中文字幕视频在线 | 91精彩视频| 精品亚洲午夜久久久久91 | 国产九色在线播放九色 | 91色一区二区三区 | 啪啪动态视频 | 日韩精品视频在线观看免费 | 久久综合久久八八 | 99色视频 | 国内丰满少妇猛烈精品播 | 久久精品一区二区三区中文字幕 | 制服丝袜亚洲 | 亚洲综合网站在线观看 | 国产精品久久99精品毛片三a | 国产高清免费视频 | 亚洲精品国产精品国产 | 天天操夜操 | 6080yy精品一区二区三区 | 久草影视在线 | 亚洲网站在线看 | 国产亚洲成人网 | 亚洲视频久久 | 成人sm另类专区 | 欧美a级在线免费观看 | 国产不卡精品视频 | 92国产精品久久久久首页 | 一本到视频在线观看 | 亚洲视频在线观看 | 天天摸天天干天天操天天射 | 四虎影院在线观看av | 久久精品网址 | 九九视频精品免费 | 国产偷国产偷亚洲清高 | 成人免费中文字幕 | 天天骚夜夜操 | 亚洲欧洲国产日韩精品 | 亚洲激色| 欧美日韩久久不卡 | 精品久久一 | 久久综合成人 | 国产精品免费久久久久影院仙踪林 | 在线观看免费福利 | 久久精品久久久精品美女 | 久久久久麻豆v国产 | 国际精品久久久久 | 日韩婷婷 | 中文在线免费看视频 | 免费在线国产精品 | 色综合色综合久久综合频道88 | 久久伊人爱 | 久久久久国产免费免费 | 天天操天天干天天 | 亚洲作爱视频 | 又粗又长又大又爽又黄少妇毛片 | 日韩av片免费在线观看 | 一区二区三区高清在线观看 | 日本精品视频网站 | 天堂av一区二区 | av成人在线观看 | 日韩黄色一区 | 久操操| jizzjizzjizz亚洲| 人人超碰免费 | 九九免费在线看完整版 | 中文字幕一区二区在线观看 | 天天综合导航 | 开心婷婷色 | 精品a在线| av观看在线观看 | 国产91欧美| 91黄站| 日韩在线视频精品 | 四虎国产精品免费 | 久久久毛片 | 国产丝袜一区二区三区 | 美女视频黄免费的久久 | 久草av在线播放 | 亚洲国产欧美在线看片xxoo | 亚洲精品国产综合久久 | 亚洲一级电影视频 | 国产精品一区二区久久国产 | 国产精品视频 | 亚洲va欧洲va国产va不卡 | 国产淫片 | 国产一区二区高清不卡 | 亚洲国产成人av网 | 国内精品久久久久影院男同志 | 久久久99久久 | 综合网在线视频 | av一级久久 | 欧美日韩国产欧美 | 黄色资源网站 | www色,com| 福利视频午夜 | 亚洲欧美精品一区二区 | 久久久久女教师免费一区 | 国产精品自产拍在线观看 | 久久久久久久久久久精 | 亚洲久草在线视频 | 免费看成年人 | 亚洲v精品 | 808电影免费观看三年 | 国产一级高清 | 国产尤物视频在线 | 一区二区三区四区精品视频 | 中文在线字幕观看电影 | 精品一二三四五区 | 久久久久婷| 91精品国产成人 | 久久一级片| 久久8精品 | 最近高清中文字幕在线国语5 | 久热只有精品 | 人人舔人人舔 | 亚洲欧美日韩国产精品一区午夜 | 欧美在线18 | 国产成人免费在线 | 91在线看免费 | 久久美女高清视频 | 婷婷社区五月天 | 97福利在线观看 | 99视频在线免费 | 精品99免费 | 99久热在线精品视频观看 | 久久久久久综合网天天 | 欧美不卡视频在线 | 久香蕉 | 91精品国产成 | 一级理论片在线观看 | 国产免费又粗又猛又爽 | 久久视频这里只有精品 | 国产精品12| 久草精品视频在线看网站免费 | av动态图片| www黄com| 亚洲天堂毛片 | 国产精品久久久久高潮 | 亚洲精品国精品久久99热 | 蜜桃视频成人在线观看 | 毛片二区 | 国产一区二区视频在线 | 色激情五月 | www.天堂av| 久草视频精品 | 日本中文在线 | 国产视频一 | 黄色大片国产 | 蜜桃av久久久亚洲精品 | 91丨九色丨蝌蚪丨对白 | 在线a人v观看视频 | 人人插人人舔 | 在线观看视频你懂得 | 另类五月激情 | 国产精品欧美久久久久无广告 | 99精品国产成人一区二区 | 91精品国产99久久久久久红楼 | 狠狠久久综合 | 日韩欧美69 | 欧美日韩一区二区在线 | 欧美亚洲免费在线一区 | 91av在线看| 国产精品久久久久毛片大屁完整版 | 91九色在线播放 | 亚洲精品9| 你操综合 | 国产亚洲精品中文字幕 | 国产在线色 | 久久久久久久久影视 | 国内99视频| 日韩欧美高清在线 | 九九久 | 国内精品免费久久影院 | 99久久日韩精品视频免费在线观看 | 人人看人人草 | 蜜臀av一区二区 | 91麻豆操 | 久久久精选 | 久操视频在线观看 | 天天做天天爱天天爽综合网 | 五月开心色 | 亚洲综合视频在线观看 | 人人射| 国产精品美女久久久久久久 | 国产精品日韩精品 | 日本色小说视频 | 美女在线免费观看视频 | 97国产在线观看 | 啪啪av在线 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 视频一区二区在线 | 色多多视频在线 | 免费亚洲片 | 国产高清在线看 | 一级免费观看 | 在线观看成人毛片 | 亚洲视频播放 | 最近中文字幕mv免费高清在线 | 91.dizhi永久地址最新 | 国产在线传媒 | 黄色com| 国产男女爽爽爽免费视频 | 天天色棕合合合合合合 | 一区二区三区韩国免费中文网站 | 国产精品第2页 | 国产综合视频在线观看 | 日日爱999 | 97偷拍视频 | 欧美日韩高清一区二区 | 免费看一级 | 99精品视频精品精品视频 | 最近中文字幕免费av | 午夜影院在线观看18 | 99re亚洲国产精品 | 免费三级影片 | 中文字幕传媒 | 蜜臀av夜夜澡人人爽人人 | 最近中文字幕视频完整版 | 欧美日韩在线播放一区 | 六月婷操 | 亚洲成人影音 | 日本公妇在线观看高清 | 欧美日韩一区二区三区视频 | 国产 中文 日韩 欧美 | 精品资源在线 | 国产精品激情在线观看 | 五月天丁香亚洲 | 最新免费中文字幕 | 国产一级黄色电影 | 激情视频91 | 国内精品在线看 | 国内成人精品2018免费看 | 久久免费国产精品 | 久久精国产 | www.狠狠操 | 欧美国产日韩在线视频 | 国产精品久久久久aaaa九色 | 天天拍天天操 | 在线播放国产一区二区三区 | 久草精品视频在线观看 | 成人精品电影 | 亚洲精品在线观看的 | 中文在线a天堂 | 91av国产视频 | 色在线观看网站 | 久久成年人 | 日韩av免费在线电影 | av超碰免费在线 | 99热国内精品 | 日本午夜免费福利视频 | 五月天电影免费在线观看一区 | 99精品电影 | 中午字幕在线观看 | www.com.日本一级| 九九99| 探花视频免费观看高清视频 | 久久久精品视频成人 | 91在线精品观看 | 伊人五月天.com | 成年人视频在线观看免费 | 欧美精品你懂的 | 国产一区在线免费 | 91久久丝袜国产露脸动漫 | 日韩av成人免费看 | 精品欧美一区二区精品久久 | 色五月色开心色婷婷色丁香 | 国产福利91精品张津瑜 | 女人18片 | 91污在线 | 992tv在线成人免费观看 | 在线播放国产一区二区三区 | 最新国产精品拍自在线播放 | 色偷偷网站视频 | 国产手机av在线 | bayu135国产精品视频 | 国产视频在线免费观看 | 亚洲三级黄色 | 日日夜夜综合 | 久久少妇免费视频 | 六月丁香激情网 | 五月婷香蕉久色在线看 | 久久99国产综合精品 | 国产高清专区 | 九色91在线视频 | 看片在线亚洲 | 亚洲午夜久久久综合37日本 | 欧美一级高清片 | 日本黄色免费播放 | 在线中文字幕av观看 | 美女视频久久久 | 日日干天天爽 | 亚洲第一av在线播放 | 国产精品露脸在线 | 久草国产在线观看 | 欧美精品视| 国产精品美女毛片真酒店 | 中文字幕资源在线观看 | 国产精品毛片完整版 | 最新国产在线观看 | 97成人超碰| 中文字幕av最新更新 | 成人app在线免费观看 | 久久99九九99精品 | 国产精品久久三 | 青春草视频在线播放 | 福利视频一二区 | 色婷婷综合成人av | 日韩视频一区二区三区在线播放免费观看 | 国产 欧美 日产久久 | 国产精久久| 欧美在线free | 伊人射 | 国产999久久久 | 国产日韩精品一区二区在线观看播放 | 麻豆久久一区二区 | 欧美一区,二区 | 日韩综合一区二区三区 | 毛片无卡免费无播放器 | 日韩精品一区二区三区丰满 | 日韩午夜av | 一区二区三区久久 | 日本最新高清不卡中文字幕 | 亚洲精品男人天堂 | 天天干天天拍天天操 | 国产成人777777 | 国产精品视频全国免费观看 | 国产精品久久久久久久久免费看 | 国产成人精品一区二区三区福利 | 国产成人av一区二区三区在线观看 | 国产精品久久久久久一区二区三区 | 一区二区三区在线免费观看 | 国产99re| 成人在线免费av | 亚洲在线黄色 | 成人免费一区二区三区在线观看 | 81精品国产乱码久久久久久 | 久草在线视频网站 | 久久免费成人精品视频 | 欧美日高清视频 | av一级在线观看 | 麻豆 91 在线| 99视频导航 | 日韩精品三区四区 | 中文字幕日韩一区二区三区不卡 | 日韩在线视频一区 | 欧美一区影院 | 91av视频在线观看免费 | 日韩大片在线免费观看 | 91桃色在线播放 | 国产91aaa | 国产黑丝袜在线 | 色偷偷男人的天堂av | 人人爱人人射 | 欧美成人精品三级在线观看播放 | 超碰人人乐 | 亚洲毛片一区二区三区 | 免费看高清毛片 | 国产精选视频 | 久久亚洲私人国产精品 | 91麻豆精品91久久久久同性 | 欧美视频日韩视频 | aaa黄色毛片 | 国产视频色 | 国产精品igao视频网网址 | 在线 高清 中文字幕 | 久久久久久久久久亚洲精品 | 亚洲成人影音 | 中文字幕日韩无 | 成人免费看电影 | 欧美作爱视频 | 91九色视频在线播放 | 99视频黄| 国产精品久久久久999 | 一级片免费观看视频 | 欧美日韩一区二区视频在线观看 | 97在线影视| 国产999视频在线观看 | 国产一区二区三区在线免费观看 | 国产黄色免费电影 | 一区二区三区四区不卡 | 91在线成人 | 午夜视频在线观看一区二区三区 | 久热久草| 三级av在线免费观看 | 日韩特黄一级欧美毛片特黄 | 成人免费一区二区三区在线观看 | a在线v| 久久成人18免费网站 | 成人中文字幕+乱码+中文字幕 | 最近中文字幕免费 | 91九色视频观看 | 日韩在线观看高清 | 天天色官网 | 国产日韩欧美网站 | 美女网站在线播放 | 黄av免费| 麻豆国产精品va在线观看不卡 | 男女拍拍免费视频 | 国产系列 在线观看 | 国产精品第一视频 | 亚洲精品免费在线播放 | 激情丁香婷婷 | 国产精品视频最多的网站 | 久久看看| 69视频永久免费观看 | 狠狠干天天 | 日本中文字幕在线播放 | 狠狠色丁香婷婷综合最新地址 | 亚洲免费色 | 有没有在线观看av | 五月婷婷操 | 亚洲激精日韩激精欧美精品 | 国产午夜精品一区二区三区 | 国产精彩视频一区二区 | 亚洲成免费 | 精品国产一区二区三区四区在线观看 | 亚洲国产精品久久 | 三级黄色网络 | 成人免费看片98欧美 | 一区二区三区国产精品 | 日韩国产欧美在线视频 | 精品国内自产拍在线观看视频 | 99热都是精品 | 色五月色开心色婷婷色丁香 | 亚洲欧美日韩国产精品一区午夜 | а天堂中文最新一区二区三区 | 国产亚洲精品久久久久久电影 | 在线岛国av | 欧美日韩精品在线免费观看 | 天天干天天操天天爱 | 97av视频在线观看 | 国产三级香港三韩国三级 | 久热av| 天天操天天色综合 | 亚洲精品国精品久久99热 | 97国产视频 | 国产免费观看av | 国产69精品久久99不卡的观看体验 | 你操综合 | 亚洲精品18p | 最近中文字幕国语免费高清6 | 91九色性视频 | 久久99精品久久久久久秒播蜜臀 | 欧美精品黑人性xxxx | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 色偷偷88欧美精品久久久 | 五月天六月婷婷 | 国产不卡毛片 | 91精品黄色| 国产视频91在线 | 黄色美女免费网站 | 91精品久久久久 | 热久久视久久精品18亚洲精品 | 日韩一区二区久久 | 毛片永久免费 | 999久久久免费精品国产 | 日本久久综合视频 | 一区二区欧美激情 | 日日射av | 亚洲精品高清在线 | 精品久久免费 | 少妇bbb| 亚洲乱亚洲乱亚洲 | 日本三级国产 | 超碰免费97 | 亚洲精品资源在线观看 | 欧美日韩国产精品一区二区亚洲 | 一区二区三区四区五区六区 | 超碰人人超碰 | 国产高清免费视频 | 日韩精品免费一线在线观看 | 中文字幕一区二区三区在线观看 | 黄色av电影在线观看 | 婷婷丁香狠狠爱 | 香蕉视频在线看 | 在线视频a | 51久久夜色精品国产麻豆 | 成人免费视频播放 | 黄色字幕网 | 久久国产高清 | 亚洲欧洲视频 | 91久久人澡人人添人人爽欧美 | 中文字幕av最新更新 | 中文在线8资源库 | 丝袜美腿一区 | 成人黄色免费在线观看 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 精品99在线视频 | 人人澡人人添人人爽一区二区 | 国产一级一片免费播放放 | 成人午夜久久 | 99视频在线观看一区三区 | 日韩一区二区在线免费观看 | 国产淫片免费看 | 夜夜躁日日躁狠狠久久88av | 天天射天天爽 | 国产二级视频 | 青青五月天 | 成人一区二区在线 | 香蕉视频在线网站 | 日本巨乳在线 | 免费观看视频黄 | 日韩一级黄色av | 97超级碰| 国产91全国探花系列在线播放 | 黄色成年| 久久精品爱爱视频 | 精品在线视频一区二区三区 | 婷婷久久五月天 | 成人超碰在线 | 人人玩人人弄 | 精品视频999 | 久久久高清一区二区三区 | 国产精品久久av | 日韩精品高清不卡 | 亚洲精品国产精品国自产观看浪潮 | 久草在线网址 | 综合激情网... | 欧美91精品| 一区 二区电影免费在线观看 | 国产五月色婷婷六月丁香视频 | 日韩高清精品免费观看 | av色网站 | 亚洲九九九在线观看 | 久久久久久久99精品免费观看 | 欧美先锋影音 | 中文在线www | 精品国内自产拍在线观看视频 | 91一区二区三区久久久久国产乱 | 91漂亮少妇露脸在线播放 | 欧美日本在线观看视频 | 日韩三级中文字幕 | 又色又爽又激情的59视频 | 波多野结衣视频在线 | 国产视频一区精品 | 丁香婷婷激情 | 99精品视频免费观看视频 | 国产一二三四在线视频 | 99热这里是精品 | 91九色蝌蚪国产 | 亚洲免费在线观看视频 | 久久在线视频精品 | 欧美高清视频不卡网 | 91插插插网站| 天天操操操操操操 | 久久久国际精品 | 欧美另类tv | 久久国产高清视频 | 在线观看黄网站 | 国产亲近乱来精品 | av中文字幕免费在线观看 | 日韩一区二区在线免费观看 | 丝袜美腿亚洲综合 | 亚洲黄色一级视频 | 伊人婷婷 | 中文字幕av电影下载 | 久久深夜福利免费观看 | 久久久久久国产精品美女 | 国内精品久久久久影院日本资源 | 精品一区久久 | 久久免费大片 | 亚洲综合精品在线 | 亚洲一级特黄 | 国产成人精品久 | 国产五码一区 | 亚洲视频在线免费看 | 国产精品欧美久久久久天天影视 | 久草.com| 日韩性网站 | 91原创在线观看 | 亚洲精品视频在线观看免费视频 | 在线a视频免费观看 | 免费看的视频 | 中文字幕一区二区三区四区在线视频 | 天天色综合三 | 黄色a级片在线观看 | 久久人人艹 | 免费网站色| 久久久免费毛片 | 日韩在线中文字幕 | 亚洲伦理电影在线 | 久久久精品视频成人 | 四虎影视成人精品国库在线观看 | 久久久久久综合网天天 | 婷婷丁香花五月天 | 91在线看片 | 在线国产日本 | 天天精品视频 | 精品免费久久久久久 | 尤物九九久久国产精品的分类 | 欧美在线一 | 婷婷丁香视频 | 亚洲国产中文字幕 | 久久午夜剧场 | 亚洲精品美女久久 | 色综合综合 | 在线国产视频 | 国产视频欧美视频 | 青青草国产免费 | 久久久久久久久久久影院 | 日韩欧美国产激情在线播放 | 欧美色图亚洲图片 | 国内99视频 | 99精品偷拍视频一区二区三区 | 午夜12点| a电影免费看 | 亚洲国产精品人久久电影 | 99tvdz@gmail.com | 久久亚洲影视 | 99热国产精品 | 91成人免费视频 | 午夜精品福利一区二区三区蜜桃 | 亚洲精品国精品久久99热 | 婷婷精品在线视频 | av免费福利 | 黄色a在线| 亚洲国产中文字幕在线观看 | 免费观看一级成人毛片 | 日韩在线字幕 | 久久婷婷一区二区三区 | 在线观看91 | 久久免费大片 | 在线免费日韩 | 国产亚洲精品久久久久久久久久久久 | 狠狠色伊人亚洲综合网站色 | 青草视频网 | 欧美a级一区二区 | 成人久久久精品国产乱码一区二区 | 免费看搞黄视频网站 | 91精品一区二区三区久久久久久 | 九九有精品 | 日韩av片无码一区二区不卡电影 | 久久综合影音 | 97在线观看| 日日干天夜夜 | 久久国产精品久久国产精品 | 91视频在线观看大全 | 国产三级精品在线 | 久久视频在线观看免费 | 99精品欧美一区二区三区黑人哦 | 热久久国产 | 久久国产精彩视频 | 亚洲精品视频免费观看 | 国产系列 在线观看 | 成年人免费av | 五月婷婷视频在线 | 午夜精品一区二区国产 | 99精品热 | 91超级碰碰 | 日韩在线视频免费播放 | 欧美日韩国产综合一区二区 | 91精品国产91 | 久久69精品 | 欧美在线日韩在线 | 亚洲精品xxx | 亚洲国产av精品毛片鲁大师 | aaa日本高清在线播放免费观看 | 亚洲特级毛片 | 米奇四色影视 | 久热av| 精品久久国产精品 | 久久久久久久久影视 | 中文字幕在线观看av | 欧美性生活一级片 | 精品中文字幕在线播放 | 国产伦精品一区二区三区高清 | 最近的中文字幕大全免费版 | 中文字幕日韩在线播放 | 黄色软件视频大全免费下载 | 欧美无极色 | 中文字幕无吗 | 久久99久久99精品免费看小说 | 久久99热这里只有精品 | 在线视频精品 | 亚洲精品免费在线观看视频 | 精品视频免费久久久看 | 国产成人精品免费在线观看 | 91九色在线播放 | 亚洲欧洲av在线 | 91精品国产高清自在线观看 | 日韩手机在线观看 | 成人免费xxxxxx视频 | 97超碰精品 | 久草在线免费新视频 | 特级免费毛片 | 国产在线1区 | 国产在线观看国语版免费 | 高清av在线 | 午夜资源站| 国产人成在线视频 | 在线亚洲人成电影网站色www | 亚洲精品视频免费 | 国产成人一区在线 | 国产精品久久久久久一区二区三区 | 中文字幕在线网址 | 亚洲天堂网在线视频观看 | 91一区二区在线 | 国产午夜精品一区 | 天天综合中文 | 97超碰精品| 国内久久久 | 最新中文字幕视频 | 成人免费在线视频 | 免费在线播放av电影 | 91高清一区 | 99久久精品国产一区二区成人 | 国产在线免费观看 | 国精产品999国精产品视频 | 国产精品成人久久久久久久 | 国产中文字幕在线播放 | 手机看片国产日韩 | 久久综合在线 | a黄色 | 四虎视频 | 国产精品久久网站 | 国产精品福利一区 | 91麻豆精品国产91 | 欧美性一级观看 | 欧美日韩久久一区 | 国产中的精品av小宝探花 | 国产高清精品在线观看 | 中文字幕a∨在线乱码免费看 | 免费黄色特级片 | 国产91精品看黄网站在线观看动漫 | www色综合 | 久久国产精品免费 | 久久免费美女视频 | 成年人在线免费看视频 | 国产女v资源在线观看 | 91在线视频播放 | 国产一级在线观看 | www.玖玖玖| 日本黄色免费观看 | 久久黄色美女 | 草久在线观看视频 | 97综合在线| 国产免费观看高清完整版 | 欧美日韩高清一区二区 国产亚洲免费看 | 一区二区三区四区在线免费观看 | 久草免费在线观看视频 | 99色人| 欧美专区国产专区 | 日本中文字幕在线观看 | 久久视了 | 97在线公开视频 | 狠狠狠狠狠狠狠狠 | 91成人精品国产刺激国语对白 | 日韩91av | 色婷婷色 | 国产伦理一区二区 | 国产一区福利 | 日韩va亚洲va欧美va久久 | 久久久久草 | 欧美日韩国产一二 | 国产一区视频在线播放 | 黄色免费观看 | 国产毛片aaa | 丁香激情视频 | 国产日韩欧美在线 | 国产一区视频导航 | 亚洲国产剧情 | 在线看岛国av | 欧美成年人在线视频 | 狠狠色丁香婷婷综合久小说久 | 国内揄拍国内精品 | 日韩69视频| 日本女人在线观看 | 91麻豆精品国产91久久久无限制版 | 四虎影视4hu4虎成人 | 亚洲欧美日韩精品久久奇米一区 | 一区二区视频在线播放 | 欧美性超爽| 亚洲精品国| 色先锋av资源中文字幕 | 日韩高清在线一区二区 | 成人黄色在线视频 | 欧美一区免费在线观看 | 亚洲欧美视频一区二区三区 | 色 免费观看 | 亚洲va欧美| 伊人开心激情 | 五月天婷亚洲天综合网精品偷 | 五月婷婷开心 | 在线看国产精品 | 欧美一级在线观看视频 | www.久久精品视频 |