真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎樣解析mysql與oracle體系結構

這篇文章給大家介紹怎樣解析MySQL與oracle 體系結構,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

為饒陽等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及饒陽網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站設計、網(wǎng)站建設、饒陽網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

做為一個學習oracle的工程師,現(xiàn)在開始學習mysql。

  mysql數(shù)據(jù)庫和oracle 相比作為一個開源數(shù)據(jù)庫,從學習的角度來說的話。他不像oracle的教育體系。文檔那么全面

學習oracle最好的方法是看oracle的官方文檔。本人由于英語水平有限。所以看了高性能mysql和深入淺出mysql

看了倆本書都不錯。所有的資料都是教你怎么干活的。對于體系架構等還是有點少。

我個人認為學習數(shù)據(jù)庫,要先了解數(shù)據(jù)庫的體系結構和sql的執(zhí)行過程。經(jīng)過查詢很多資料。感覺自己應該是明白了

先說oracle 體系結構,oracle的體系結構圖官方都有。網(wǎng)上也有好多講這個東西的。如果不明白可以查找下看一下。oracle的資料市面非常多。
提示:只做了innodb的比較,剩下的存儲引擎為在之中
怎樣解析mysql與oracle 體系結構

   1,數(shù)據(jù)庫(database):     |—物理存儲:(os操作系統(tǒng)文件):        |— datafile      數(shù)據(jù)文件(存儲的是實實在在數(shù)據(jù)的地方)業(yè)務數(shù)據(jù)、系統(tǒng)數(shù)據(jù)、臨時數(shù)據(jù)(order by。。)回退數(shù)據(jù)

                                                |                                                               |—countralfile  控制文件(存儲的是數(shù)據(jù)庫的結構信息)

                                                |                                                               |—logfile         日志文件(存儲的是改變的數(shù)據(jù))做恢復用

                                                |—邏輯存儲: |—表空間(table space)存數(shù)據(jù)字典的地方

                                                                      |—段(磁盤/io,存儲各種類型的數(shù)據(jù)的地方)不能跨表空間                                                                         

                                                                      |—區(qū)(為段分配空間的)不能跨越段                                                                        

                                                                      |—塊(最小的單位是block)不能跨越區(qū)

   2,實例(instance): |—sga:內(nèi)存cpu: shard pool 共享池:最近使用的sql語句(程序)和最近使用的數(shù)據(jù)字典的信息

                                        |                         buffer cache  數(shù)據(jù)庫緩沖區(qū):最近使用的數(shù)據(jù),大小由db_cache_size決定

                                        |                         redo log buffer  日志緩沖區(qū):最近改變的數(shù)據(jù)log buffer。按順序寫,循環(huán)寫

                                        |                         java pool

                                        |                         large pool

                                        |—后臺進程: |—數(shù)據(jù)庫寫進程dbwr:把數(shù)據(jù)由數(shù)據(jù)庫緩沖區(qū)寫入數(shù)據(jù)文件里

                                                              |—日志寫進程lgwr:把數(shù)據(jù)由日志緩沖區(qū)寫入日志文件里

                                                              |—檢查點進程ckpt:1,數(shù)據(jù)庫同步的標志。三大核心文件必須保證在同一檢查點上,數(shù)據(jù)庫才能起來,最先寫在日志文件里,寫在數(shù)據(jù)文件的頭里

                                                              |                           2,觸發(fā)數(shù)據(jù)庫寫進程,把數(shù)據(jù)由數(shù)據(jù)庫緩沖區(qū)寫入數(shù)據(jù)文件里

                                                              |—系統(tǒng)監(jiān)控進程smon:1,歷程恢復

                                                              |                               2,釋放臨時段的空間

                                                              |                               3,合并相鄰的空間碎片

                                                              |—程序監(jiān)控進程pmon:釋放資源(包括正常和異常資源)

                                                              |  MMON監(jiān)視進程每到指定時間去訪問統(tǒng)計數(shù)據(jù),這樣就知道表空間使用量到警告或邊界沒有

怎樣解析mysql與oracle 體系結構

下面看一下mysql的結構圖
怎樣解析mysql與oracle 體系結構


對于mysql來說他是線程模式。所以對應的上面oracle進程

master thread 主要負責將臟緩存頁刷新到數(shù)據(jù)文件,執(zhí)行purge操作,觸發(fā)檢查點,合并插入緩沖區(qū)

insert buffer thread 負責插入緩沖區(qū)的合并操作

read thread 負責數(shù)據(jù)庫 讀讀操作,可配置多個讀線程

write theead 負責數(shù)據(jù)庫 讀寫操作,可配置多個寫線程

log theead 用于數(shù)據(jù)庫的重做日志刷新到logfile 中

purage theead   mysql5.5之后單獨的purage theead  執(zhí)行purge操作 

事務被提交后,其所使用的undolog可能不再需要,因此需要PurgeThread來回收已經(jīng)使用并分配的undo頁。在InnoDB 1.1版本之前,purge操作僅在InnoDB存儲引擎的Master Thread中完成。而從InnoDB 1.1版本開始,purge操作可以獨立到單獨的線程中進行,以此來減輕Master Thread的工作,從而提高CPU的使用率以及提升存儲引擎的性能。用戶可以在MySQL數(shù)據(jù)庫的配置文件中添加如下命令來啟用獨立的Purge Thread:

look thread 負責鎖控制和死鎖檢測等

錯誤檢測線程: 主要負責錯誤監(jiān)控和錯誤處理

write theead master thread 相當于 dbwr 
數(shù)據(jù)庫寫進程dbwr:把數(shù)據(jù)由數(shù)據(jù)庫緩沖區(qū)寫入數(shù)據(jù)文件里
master thread 主要負責將臟緩存頁刷新到數(shù)據(jù)文件,執(zhí)行purge操作,觸發(fā)檢查點,合并插入緩沖區(qū)
write theead 負責數(shù)據(jù)庫 讀寫操作,可配置多個寫線程

insert buffer thread 類似于  smon

系統(tǒng)監(jiān)控進程smon:

1,歷程恢復     

2,釋放臨時段的空間    

3,合并相鄰的空間碎片
insert buffer thread 負責插入緩沖區(qū)的合并操作

log theead  
日志寫進程lgwr:把數(shù)據(jù)由日志緩沖區(qū)寫入日志文件里
log theead 用于數(shù)據(jù)庫的重做日志刷新到logfile 中

上述基本是我總結的mysql和oracle的instace中進程線程的結構

現(xiàn)在分析mysql的內(nèi)存結構

共享池
shard pool 共享池:最近使用的sql語句(程序)和最近使用的數(shù)據(jù)字典的信息
QueryCache(下面簡稱QC)是根據(jù)SQL語句來cache的。一個SQL查詢?nèi)绻詓elect開頭,那么MySQL服務器將嘗試對其使用QC。每個Cache都是以SQL文本作為key來存的。在應用QC之前,SQL文本不會被作任何處理
mysql的QC 很簡陋啊只要數(shù)據(jù)進行更改就會清除qc里的數(shù)據(jù)。原來我非常不理解的東西?,F(xiàn)在明白了。不過深入解析沒有看

buffer cache 和innodb buffer cache
存儲數(shù)據(jù)的地方。mysql 是在innodb層處理這個問題。

      buffer cache  數(shù)據(jù)庫緩沖區(qū):最近使用的數(shù)據(jù),大小由db_cache_size決定redo log buffer 和innodb redo log buffer              

寫入數(shù)據(jù)庫時候先寫入redo log buffer  順序寫入內(nèi)存,刷新到硬盤,順序寫。最后通過寫進程刷新到datafile里面
保證寫入的io。
綜上所述:mysql 和mysql innodb的別也就上述幾點基本差不多。只是mysql簡陋了好多。
學習mysql是可以更好的了解數(shù)據(jù)庫。

關于怎樣解析mysql與oracle 體系結構就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


網(wǎng)站欄目:怎樣解析mysql與oracle體系結構
標題路徑:http://weahome.cn/article/iheisi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部