精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

自己動手寫SQL執行引擎

運維 數據庫運維
在造輪子的過程中一開始是非常有激情非常快樂的。但隨著系統越來越龐大,復雜性越來越高,進度就會越來越慢,還時不時要推翻自己原來的設想并重新設計,然后再協同修改關聯的所有代碼,就如同泥沼,越陷越深。

[[344553]]

自己動手寫SQL執行引擎

前言

在閱讀了大量關于數據庫的資料后,筆者情不自禁產生了一個造數據庫輪子的想法。來驗證一下自己對于數據庫底層原理的掌握是否牢靠。在筆者的github中給這個database起名為Freedom。

整體結構

既然造輪子,那當然得從前端的網絡協議交互到后端的文件存儲全部給擼一遍。下面是Freedom實現的整體結構,里面包含了實現的大致模塊:

 

最終存儲結構當然是使用經典的B+樹結構。當然在B+樹和文件系統block塊之間的轉換則通過Buffer(Page) Manager來進行。當然了,為了完成事務,還必須要用WAL協議,其通過Log Manager來操作。

Freedom采用的是索引組織表,通過DruidSQL Parse來將sql翻譯為對應的索引操作符進而進行對應的語義操作。

MySQL Protocol結構

client/server之間的交互采用的是MySQL協議,這樣很容易就可以和mysql client以及jdbc進行交互了。

query packet

mysql通過3byte的定長包頭去進行分包,進而解決tcp流的讀取問題。再通過一個sequenceId來在應用層判斷packet是否連續。

 

result set packet

mysql協議部分最復雜的內容是其對于result set的讀取,在NIO的方式下加重了復雜性。

Freedom通過設置一系列的讀取狀態可以比較好的在Netty框架下解決這一問題。

 

row packet

還有一個較簡單的是對row格式進行讀取,如上圖所示,只需要按部就班的解析即可。

 

由于協議解析部分較為簡單,在這里就不再贅述。

SQL Parse

Freedom采用成熟好用的Druid SQL Parse作為解析器。事實上,解析sql就是將用文本表示

的sql語義表示為一系列操作符(這里限于篇幅原因,僅僅給出select中where過濾的原理)。

對where的處理

例如where后面的謂詞就可以表示為一系列的以樹狀結構組織的SQL表達式,如下圖所示:

當access層通過游標提供一系列row后,就可以通過這個樹狀表達式來過濾出符合where要求的數據。Druid采用了Parse中常用的visitor很方便的處理上面的表達式計算操作。

對join的處理

對join最簡單處理方案就是對兩張表進行笛卡爾積,然后通過上面的where condition進行過濾,如下圖所示:

 

Freedom對于縮小笛卡爾積的處理

由于Freedom采用的是B+樹作為底層存儲結構,所以可以通過where謂詞來界定B+樹scan(搜索)的范圍(也即最大搜索key和最小搜索key在B+樹種中的位置)。考慮sql

  1. select a.*,b.* from t_archer as a join t_rider as b where a.id>=3 and a.id<=11 b.id and b.id>=19 b.id<=31 

那么就可以界定出在id這個索引上,a的scan范圍為[3,11],如下圖所示:

 

b的scan范圍為[19,31],如下圖所示(假設兩張表數據一樣,便于繪圖):

 

scan少了從原來的15*15(一共15個元素)次循環減少到4*4次循環,即循環次數減少到7.1%

當然如果存在join condition的話,那么Freedom在底層cursor遞歸處理的過程中會預先過濾掉一部分數據,進一步減少上層的過濾。

B+Tree的磁盤結構

leaf磁盤結構

Freedom的B+Tree是存儲到磁盤里的。考慮到存儲的限制以及不定長的key值,所以會變得非常復雜。Freedom以page為單位來和磁盤進行交互。葉子節點和非葉子節點都由page承載并刷入磁盤。結構如下所示:

 

一個元組(tuple/item)在一個page中分為定長的ItemPointer和不定長的Item兩部分。

其中ItemPointer里面存儲了對應item的起始偏移和長度。同時ItemPointer和Item如圖所示是向著中心方向進行伸張,這種結構很有效的組織了非定長Item。

leaf和node節點在Page中的不同

雖然leaf和node在page中組織結構一致,但其item包含的項確有區別。由于Freedom采用的是索引組織表,所以對于leaf在聚簇索引(clusterIndex)和二級索引(secondaryIndex)中對item的表示也有區別,如下圖所示:

 

其中在二級索引搜索時通過secondaryIndex通過index-key找到對應的clusterId,再通過

clusterId在clusterIndex中找到對應的row記錄。

由于要落盤,所以Freedom在node節點中的item里面寫入了index-key對應的pageno,

這樣就可以容易的從磁盤恢復所有的索引結構了。

B+Tree在文件中的組織

有了Page結構,我們就可以將數據承載在一個個page大小的內存里面,同時還可以將page刷新到對應的文件里。有了node.item中的pageno,我們就可以較容易的進行文件和內存結構之間的互相映射了。

B+樹在磁盤文件中的組織如下圖所示:

 

B+樹在內存中相對應的映射結構如下圖所示:

 

文件page和內存page中的內容基本是一致的,除了一些內存page中特有的字段,例如dirty等。

每個索引一個B+樹

在Freedom中,每個索引都是一顆B+樹,對記錄的插入和修改都要對所有的B+樹進行操作。

B+Tree的測試

筆者通過一系列測試case,例如隨機變長記錄對B+樹進行插入并落盤,修復了其中若干個非常詭異的corner case。

B+Tree的todo

筆者這里只是完成了最簡單的B+樹結構,沒有給其添加并發修改的鎖機制,也沒有在B+樹做操作的時候記錄log來保證B+樹在宕機等災難性情況下的一致性,所以就算完成了這么多的工作量,距離一個高并發高可用的bptree還有非常大的距離。

Meta Data

table的元信息由create table所創建。創建之后會將元信息落盤,以便Freedom在重啟的時候加載表信息。每張表的元信息只占用一頁的空間,依舊復用page結構,主要保存的是聚簇索引和二級索引的信息。元信息對應的Item如下圖所示:

 

如果想讓mybatis可以自動生成關于Freedom的代碼,還需實現一些特定的sql來展現Freedom的元信息。這個在筆者另一個項目rider中有這樣的實現。原理如下圖所示:

 

實現了上述4類SQL之后,mybatis-generator就可以通過jdbc從Freedom獲取元信息進而自動生成代碼了。

事務支持

由于當前Freedom并沒有保證并發,所以對于事務的支持只做了最簡單的WAL協議。通過記錄redo/undolog從而實現原子性。

redo/undo log協議格式

Freedom在每做一個修改操作時,都會生成一條日志,其中記錄了修改前(undo)和修改后(redo)的行信息,redo用來回滾,redo用來宕機recover。結構如下圖所示:

 

WAL協議

WAL協議很好理解,就是在事務commit前將當前事務中所產生的的所有log記錄刷入磁盤。

Freedom自然也做了這個操作,使得可以在宕機后通過log恢復出所有的數據。

 

回滾的實現

由于日志中記錄了undo,所以對于一個事務的回滾直接通過日志進行undo即可。如下圖所示:

 

宕機恢復

Freedom如果在page全部刷盤之后關機,則可以由通過加載page的方式獲取原來的數據。

但如果突然宕機,例如kill -9之后,則可以通過WAL協議中記錄的redo/undo log來重新

恢復所有的數據。由于時間和精力所限,筆者并沒有實現基于LSN的檢查點機制。

Freedom運行

  1. git clone https://github.com/alchemystar/Freedom.git 
  2. // 并沒有做打包部署的工作,所以最簡單的方法是在java編輯器里面 
  3. run alchemystar.freedom.engine.server.main 

以下是筆者實際運行Freedom的例子:


 

 

join查詢

 

delete回滾

 

Freedom todo

Freedom還有很多工作沒有完成,例如有層次的鎖機制和MVCC等,由于工作忙起來就耽擱了。

于是筆者就看了看MySQL源碼的實現理解了一下鎖和MVCC實現原理,并寫了兩篇博客。比起

自己動手擼實在是輕松太多了^_^。

MVCC

https://my.oschina.net/alchemystar/blog/1927425

二階段鎖

https://my.oschina.net/alchemystar/blog/1438839

尾聲

在造輪子的過程中一開始是非常有激情非??鞓返?。但隨著系統越來越龐大,復雜性越來越高,進度就會越來越慢,還時不時要推翻自己原來的設想并重新設計,然后再協同修改關聯的所有代碼,就如同泥沼,越陷越深。至此,筆者才領悟了軟件工程最重要的其實是控制復雜度!始終保持簡潔的接口和優雅的設計是實現一個大型系統的必要條件。

本文轉載自微信公眾號「解Bug之路」,可以通過以下二維碼關注。轉載本文請聯系解Bug之路公眾號。

 

責任編輯:武曉燕 來源: 解Bug之路
相關推薦

2017-03-02 13:31:02

監控系統

2015-07-23 14:53:50

貝葉斯分類器

2014-11-26 10:54:20

C#

2018-02-07 10:46:20

數據存儲

2018-09-12 10:58:11

NBA數據存儲

2015-06-02 09:51:40

iOS網絡請求封裝接口

2015-06-02 10:24:43

iOS網絡請求降低耦合

2023-12-15 10:14:42

數據庫select語句

2023-12-16 13:21:00

Python元類ORM

2011-08-25 09:30:22

2020-05-20 13:53:41

HTTP環境安裝

2015-09-01 09:49:28

2015-06-02 09:41:00

iOS網絡請求NSURLSessio

2011-07-19 09:36:24

SplitSQL

2014-06-20 09:18:54

Dustjs中間件

2009-03-16 16:30:18

2014-03-17 10:34:48

SQL Server

2024-12-06 09:58:09

2011-08-12 10:46:57

Linux

2009-12-03 13:56:05

Suse Linux開xinetd
點贊
收藏

51CTO技術棧公眾號

91福利国产成人精品播放| 日本一区二区三区免费观看| 久久在线视频精品| 欧美1区二区| 在线一区二区三区四区五区| 在线综合视频网站| 午夜av免费在线观看| 奇米色一区二区三区四区| 欧美老女人在线视频| 波多野吉衣中文字幕| 成人在线视频国产| 日韩欧美有码在线| 男人的天堂视频在线| 欧美扣逼视频| 国产高清精品网站| 国产精品久久久久久久app| 丰满少妇高潮久久三区| 九一国产精品| 精品99999| www.se五月| 免费高潮视频95在线观看网站| 中文字幕不卡三区| 久久精品国产一区二区三区日韩| 亚洲天堂中文在线| 亚洲一区激情| 欧美精品在线看| 夫妇露脸对白88av| 亚洲精品蜜桃乱晃| 日韩一卡二卡三卡四卡| 精品久久久久久中文字幕2017| 羞羞网站在线看| 国产精品久久毛片av大全日韩| 国产一区二区在线网站| 国产免费视频一区二区三区| 日日欢夜夜爽一区| 91国产中文字幕| 欧美色图亚洲视频| 欧美高清视频手机在在线| 亚洲人成自拍网站| 黄色网址在线视频| 丁香5月婷婷久久| 日韩一区二区精品在线观看| 日本特黄a级片| 最新欧美电影| 欧美日韩一区二区免费在线观看| 嫩草影院中文字幕| 91精品久久| 国产精品不卡视频| 亚洲国产高清国产精品| 国产高清视频在线观看| 久久综合狠狠综合久久综合88 | 欧美gv在线| 亚洲一区欧美一区| 国产美女主播在线| 91白丝在线| 亚洲国产精品视频| 无码专区aaaaaa免费视频| 成人性生交大片免费看网站 | 国产91丝袜在线播放0| 亚洲综合一区二区不卡| 国产偷人妻精品一区二区在线| 久久狠狠亚洲综合| 2022国产精品| 午夜久久久久久久久久| 丁香桃色午夜亚洲一区二区三区| 99re视频在线| 涩涩视频免费看| 北条麻妃国产九九精品视频| 国产伦精品一区二区三区照片| 人妻与黑人一区二区三区| 国产suv精品一区二区883| 成人欧美视频在线| 五月婷婷伊人网| 久久日一线二线三线suv| 青青草国产精品| 在线观看国产原创自拍视频| 亚洲欧美区自拍先锋| 日韩精品在线观看av| 黄色污网站在线观看| 色播五月激情综合网| 精品亚洲一区二区三区四区| 国产午夜久久av| 亚洲国产高清自拍| a天堂中文字幕| 天天揉久久久久亚洲精品| 欧美二区在线播放| 久久久精品视频网站| 久久成人免费网| 国产高清在线精品一区二区三区| 暖暖视频在线免费观看| 亚洲欧美一区二区在线观看| 岛国大片在线播放| 麻豆精品蜜桃| 日韩欧美成人一区二区| 草草影院第一页| 国产韩日影视精品| 91精品国产91久久久| 中文字幕在线观看国产| 成人性生交大片| 午夜视频久久久| 17videosex性欧美| 欧美精品一二三四| 性欧美成人播放77777| 91久久久精品国产| 国产91精品最新在线播放| 国产农村妇女毛片精品| 26uuu久久综合| 国产经典久久久| 日韩三区免费| 亚洲精品国产精品国自产在线 | 国产区精品区| 欧美黑人性猛交| 又污又黄的网站| 久久综合一区二区| 乱熟女高潮一区二区在线| 精品欧美一区二区三区在线观看| 日韩午夜在线观看视频| 亚洲黄色小说视频| 亚洲国产美女| 亚洲一区二区三区在线免费观看| 国外av在线| 激情久久av一区av二区av三区 | 亚洲自拍一区在线观看| 粉嫩av一区二区三区在线播放 | 一区二区黄色| 97久久天天综合色天天综合色hd| 国产一二三在线观看| 亚洲777理论| 免费黄色在线播放| 在线观看国产精品入口| 国产主播在线一区| 大乳在线免费观看| 在线一区二区三区| 亚洲成人网在线播放| 亚洲国产日本| 动漫3d精品一区二区三区| www红色一片_亚洲成a人片在线观看_| 欧美色男人天堂| 免费看日本黄色片| 人人狠狠综合久久亚洲| 欧美日韩在线高清| 2022成人影院| 亚洲欧美999| 亚洲欧美综合另类| 久久婷婷国产综合国色天香| 欧美日韩黄色一级片| 加勒比久久高清| 午夜精品一区二区三区在线| 欧美一级特黄aaaaaa大片在线观看| 亚洲精品ww久久久久久p站| 成人免费黄色av| 欧美jjzz| 国产伦精品一区二区三区视频孕妇 | 免费黄色在线视频| 国产欧美另类| 蜜桃视频在线观看91| 亚洲精品**中文毛片| 亚洲精品在线视频| 看黄色一级大片| 国产精品嫩草影院av蜜臀| 亚洲a级黄色片| 伊人久久大香线| 99中文字幕| 五月天国产在线| 伊人久久五月天| 91精品中文字幕| 亚洲综合av网| 人妻在线日韩免费视频| 视频一区国产视频| 中文字幕日韩精品久久| 日韩免费一级| 欧美一级电影久久| 懂色一区二区三区| 欧美一区二区视频免费观看| 久久网一区二区| 91女人视频在线观看| www.天天射.com| 亚洲激情五月| 韩国成人动漫在线观看| 素人一区二区三区| 欧美精品在线观看| 日韩av成人| 欧美老女人在线| 国产午夜久久久| 国产亚洲综合在线| 久久久久中文字幕亚洲精品| 新狼窝色av性久久久久久| 亚洲欧美日产图| 超碰97久久国产精品牛牛| 日本精品久久久久影院| 国产精品剧情一区二区在线观看| 337p日本欧洲亚洲大胆色噜噜| 无码人妻丰满熟妇区bbbbxxxx| 综合欧美亚洲日本| 亚洲最大免费视频| 精品在线播放免费| 日本免费黄视频| 女人色偷偷aa久久天堂| 欧美三级华人主播| 亚洲日本va午夜在线电影| 国产精品成人aaaaa网站| 色呦呦在线资源| 一区二区成人av| 六月婷婷综合网| 欧美喷潮久久久xxxxx| 日韩少妇高潮抽搐| 亚洲欧美日韩中文播放| b站大片免费直播| 成人白浆超碰人人人人| 91女神在线观看| 噜噜噜躁狠狠躁狠狠精品视频| 香蕉视频免费版| 欧美三级伦理在线| 极品日韩久久| 成人av动漫| 91在线观看免费高清| 91超碰碰碰碰久久久久久综合| 久久久久中文字幕2018| 黄色免费在线网站| 在线观看日韩视频| 男人天堂综合| 亚洲精品不卡在线| 亚洲精品一区二区口爆| 欧美男女性生活在线直播观看 | 欧美精品123区| 免费又黄又爽又猛大片午夜| 亚洲6080在线| 精品少妇一二三区| 一区二区在线看| 疯狂撞击丝袜人妻| 国产精品国产三级国产有无不卡 | 日韩系列在线| 国产乱码精品一区二区三区卡| 日韩亚洲精品在线观看| 成人免费网视频| 亚州精品国产| 国产欧美日韩高清| 巨大黑人极品videos精品| 国产成人福利网站| av激情成人网| 国产成人在线亚洲欧美| 欧美成人黑人| 日韩免费观看av| 欧美暴力调教| 国产精品国产三级国产aⅴ9色| 综合在线影院| 国产精品91一区| 国产精品久久久久久妇女| 国产精品国产亚洲伊人久久 | 中文亚洲欧美| 国产黄视频在线| 午夜一区不卡| 日本激情视频在线| 看片的网站亚洲| 亚洲18在线看污www麻豆| 极品少妇xxxx精品少妇| 男男受被啪到高潮自述| 成人精品gif动图一区| 午夜免费福利影院| 91在线免费播放| a级在线免费观看| 国产精品久久久久一区二区三区 | 国产精品久久久久9999赢消| 天天干天天色天天爽| 欧美精品色网| 国产深夜男女无套内射| 久久影院亚洲| 亚洲一区在线不卡| 国产乱人伦偷精品视频不卡| 特级特黄刘亦菲aaa级| 99免费精品视频| 大胸美女被爆操| 亚洲乱码日产精品bd| 国产一二三四在线| 色欲综合视频天天天| 在线观看免费视频一区| 日韩一级大片在线| 色综合888| 俺去亚洲欧洲欧美日韩| 国产精品一区hongkong| 人九九综合九九宗合| 欧美aaaaaaaa| 精品国产免费一区二区三区| 激情婷婷综合| 国产精品久久久影院| 国产欧美日韩一区二区三区在线| 日本888xxxx| 国产成人8x视频一区二区| 永久免费看mv网站入口78| 中文字幕五月欧美| 日韩av大片在线观看| 欧美精选一区二区| 色猫av在线| 另类专区欧美制服同性| 欧美日韩大片| 3d动漫精品啪啪一区二区三区免费| 久久99精品国产自在现线| 亚洲一区综合| 香蕉久久夜色精品| 男插女视频网站| 国产日韩精品一区| 国产无遮挡裸体免费视频| 欧美日韩视频在线观看一区二区三区| 国产成人无码www免费视频播放| 一本色道久久综合狠狠躁篇怎么玩 | av免费在线一区| 国产精品国产精品| 欧美电影免费播放| 少妇高潮喷水久久久久久久久久| 激情成人午夜视频| 免费看黄色的视频| 性欧美大战久久久久久久久| 一道本在线视频| 亚洲欧美综合区自拍另类| 色婷婷在线播放| 成人国产精品免费视频| 国产在线观看91一区二区三区| 精品国产一区二区三区无码| 激情综合色综合久久综合| 婷婷色一区二区三区| 偷拍日韩校园综合在线| 午夜久久久久久噜噜噜噜| 日韩亚洲欧美成人| 欧美va在线观看| 久久偷窥视频| 亚洲日本欧美| 国产成人精品一区二区三区在线观看| 国产精品麻豆一区二区| 日韩欧美一级大片| 国产亚洲日本欧美韩国| 欧美粗大gay| 女同一区二区| 久久不射网站| www.色多多| 欧美日韩一区二区三区| 免费看黄色一级视频| 欧美华人在线视频| 97久久综合精品久久久综合| 成人黄色片免费| 国产精品一区二区在线观看网站| 国产美女福利视频| 91精品蜜臀在线一区尤物| 老司机在线永久免费观看| 国产欧美日韩专区发布| 久久国产精品成人免费观看的软件| 苍井空浴缸大战猛男120分钟| 99久久精品国产精品久久 | 欧美在线不卡一区| 国产裸舞福利在线视频合集| 国产成人精品视| 欧美限制电影| 欧美一级xxxx| 亚洲卡通动漫在线| 丰满少妇在线观看bd| 国内精品久久久久| 亚洲动漫在线观看| 国产第一页视频| 中文字幕乱码日本亚洲一区二区| 中文字幕免费观看视频| 色偷偷av一区二区三区| 国产精品久久久久久久久久久久久久久 | 欧美日韩第一页| 66精品视频在线观看| xxxx18hd亚洲hd捆绑| 久久久久青草大香线综合精品| 国产三级av片| 亚洲香蕉伊综合在人在线视看| 国产欧美在线观看免费| 少妇高潮大叫好爽喷水| 不卡高清视频专区| 无码人妻av免费一区二区三区| 色偷偷av一区二区三区| **爰片久久毛片| 日本毛片在线免费观看| 国产精品丝袜黑色高跟| 国产av无码专区亚洲av| 91国在线精品国内播放| 欧美日韩激情| 色哟哟网站在线观看| 欧美色另类天堂2015| 免费av毛片在线看| 国内一区在线| 毛片av中文字幕一区二区| 欧美激情精品久久| 日韩高清a**址| 青青在线精品| 黄色国产一级视频| 国产精品人人做人人爽人人添 | 岛国精品在线播放| 无码一区二区三区在线观看| 久久久精品美女| 亚洲国产精品嫩草影院久久av| 国产成人在线综合| 精品国产91久久久久久老师| av大全在线免费看| 国产一区不卡在线观看| 久久精品二区亚洲w码| 成人精品免费在线观看| 久久精品视频亚洲| 伊人久久大香线蕉|