成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

理解數據庫連接池底層原理之手寫實現

數據庫
數據庫連接池的基本思想是:為數據庫連接建立一個“緩沖池”,預先在池中放入一定數量的數據庫連接管道,需要時,從池子中取出管道進行使用,操作完畢后,在將管道放入池子中,從而避免了頻繁的向數據庫申請資源,釋放資源帶來的性能損耗。

前言

數據庫連接池的基本思想是:為數據庫連接建立一個“緩沖池”,預先在池中放入一定數量的數據庫連接管道,需要時,從池子中取出管道進行使用,操作完畢后,在將管道放入池子中,從而避免了頻繁的向數據庫申請資源,釋放資源帶來的性能損耗。在如今的分布式系統當中,系統的QPS瓶頸往往就在數據庫,所以理解數據庫連接池底層構造原理與設計思想是很有益處的。我們常用的數據庫連接池有C3P0,DBCP,Druid等,下面我們就來分析下數據庫連接池應該有些什么,以及手寫一個迷你版的數據庫連接池!

對數據庫連接池的一點思考

 

  • ***,數據庫連接池中存放的就是數據庫操作管道,不僅僅是存放,而且應該是管理這些管道;
  • 第二,應該提供外部配置文件去初始化數據庫連接池;
  • 第三,如果一個數據庫操作管道已經被占用,那么其他請求是否應該得到這個管道,也就是說我們要考慮多線程并發下,管道的分配問題;
  • 第四,如果做到管道的復用?放回池子中,標示可用,并不是真正的關閉管道;

寫一個迷你版數據庫連接池

理解數據庫連接池底層原理之手寫實現

  • IMyPool是一個接口,對外提供數據庫連接池的基本服務,比如得到一個數據庫操作管道。
  • MyDefaultPool是IMyPool的實現。
  • MyPooledConnection代表數據庫操作管道,它可以執行SQL,關閉管道等。
  • MyPoolFactory是一個工廠,單例模式,用于得到IMyPool實現。
  • DBConfigXML代表外部配置文件。
  • Test用于測試。

DBConfigXML

理解數據庫連接池底層原理之手寫實現

  • 我們在實際中使用數據庫連接池,需要在Spring的配置文件中,進行一些參數配置。這里,為了簡化解析,直接提供。

MyPooledConnection

理解數據庫連接池底層原理之手寫實現

  • 所謂數據庫連接管道,就是對JDBC Connection進行封裝而已,但是需要注意isBusy的這個標示。對管道的關閉,實際上只是標示的改變而已!

IMyPool

理解數據庫連接池底層原理之手寫實現

MyDefaultPool

理解數據庫連接池底層原理之手寫實現

  • 需要注意到是,MyDefaultPool持有一個管道集合,基于多線程的考慮,這里使用了Vector。

MyDefaultPool需要初始化

理解數據庫連接池底層原理之手寫實現

  • 數據庫連接池需要根據外部配置文件完成數據庫驅動加載以及初始化管道的建立。

createMyPooledConnection接口實現

理解數據庫連接池底層原理之手寫實現

  • 數據庫連接池在創建管道時,應該去看一下是否達到上限,如果沒有,則可以創建。
  • 不僅僅要創建出來,還要標示每一個管道的isBusy標志。

getMyPooledConnection接口實現

理解數據庫連接池底層原理之手寫實現

  • 這里需要注意的是:如果得不到操作管道,需要去創建管道!

getRealConnectionFromPool

理解數據庫連接池底層原理之手寫實現

  • ***,這里使用了synchronized,就是為了避免多線程下產生問題。
  • 第二,要知道Connection是有超時機制的,如果我們得到的管道的Connection已經超時了怎么辦呢?
  • 第三,得到管道后,一定注意isBusy的設置。

MyPoolFactory

理解數據庫連接池底層原理之手寫實現

Test測試

理解數據庫連接池底層原理之手寫實現

運行結果

理解數據庫連接池底層原理之手寫實現

理解數據庫連接池底層原理之手寫實現

 

好了,到這里,一個迷你版的數據庫連接池就有模有樣了! 

責任編輯:龐桂玉 來源: 51CTO博客
相關推薦

2019-11-27 10:31:51

數據庫連接池內存

2011-05-19 09:53:33

數據庫連接池

2010-03-18 15:09:15

python數據庫連接

2009-06-24 07:53:47

Hibernate數據

2020-12-18 05:42:46

reduxactions

2009-07-17 13:32:49

JDBC數據庫

2017-06-22 14:13:07

PythonMySQLpymysqlpool

2020-04-21 23:14:08

數據并發控制

2009-06-16 09:25:31

JBoss配置

2011-04-19 11:02:57

數據庫分頁

2021-07-05 07:51:43

JVM底層Python

2021-08-12 06:52:01

.NET數據庫連接池

2020-04-30 14:38:51

數據庫連接池線程

2018-10-10 14:27:34

數據庫連接池MySQL

2025-04-18 08:54:30

2009-07-29 09:33:14

ASP.NET數據庫連

2018-01-03 14:32:32

2025-01-16 10:30:49

2023-06-08 07:25:56

數據庫索引數據結構

2017-02-08 11:00:50

數據庫索引類型
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一级在线观看 | 免费成人在线网站 | 成人欧美一区二区三区1314 | av免费成人 | 一级黄色绿像片 | www.成人免费视频 | 免费一级毛片 | 99国产精品99久久久久久粉嫩 | 久久久久久免费毛片精品 | 中文字幕观看 | 国产精品久久精品 | 激情的网站 | 国产精品污www一区二区三区 | 亚洲品质自拍视频 | 亚洲精品九九 | 日韩精品一区二区三区 | 91精品国产手机 | 欧美日韩高清在线观看 | 午夜欧美一区二区三区在线播放 | 人人九九 | 黄视频欧美 | 色站综合| 91精品综合久久久久久五月天 | 欧美a在线看 | 99久久久久久久久 | 久久久91| 欧美成人黄色小说 | 日韩欧美在线视频播放 | 日韩一区二区三区在线视频 | 97精品国产| 中文字幕在线三区 | 91精品国产综合久久久久 | eeuss国产一区二区三区四区 | 免费黄色a级毛片 | 精品毛片在线观看 | 日韩在线免费视频 | 午夜在线视频 | 在线播放91| 亚洲欧美一区二区三区情侣bbw | 日本成人三级电影 | 色网在线观看 |