下文內(nèi)容主要給大家?guī)鞰ySQL architecture詳解,這里所講到的知識,與書籍略有不同,都是創(chuàng)新互聯(lián)專業(yè)技術(shù)人員在與用戶接觸過程中,總結(jié)出來的,具有一定的經(jīng)驗(yàn)分享價值,希望給廣大讀者帶來幫助。
創(chuàng)新互聯(lián)公司2013年至今,先為臺兒等服務(wù)建站,臺兒等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為臺兒企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
mysql architecture 說明
字段意義說明
Connectors:數(shù)據(jù)庫連接器
Native C API:C連接數(shù)據(jù)庫接口
JDBC:Java連接數(shù)據(jù)庫驅(qū)動
ODBC:開放數(shù)據(jù)庫互連
.NET:.NET連接數(shù)據(jù)庫驅(qū)動
PHP:PHP連接數(shù)據(jù)庫驅(qū)動
Perl:Perl連接數(shù)據(jù)庫驅(qū)動
Python:Python連接數(shù)據(jù)庫驅(qū)動
Ruby:Ruby連接數(shù)據(jù)庫驅(qū)動
Cobol:Cobol連接數(shù)據(jù)庫驅(qū)動
Connection Pool:
MySQL是單進(jìn)程多線程工作模式,所以必須維護(hù)一個線程池。管理大量線程對大量客戶端并發(fā)請求進(jìn)行并發(fā)響應(yīng)。
Authentication:認(rèn)證,用戶名密碼等。
Thread Reuse:線程重用。(當(dāng)一個用戶連接請求進(jìn)來之后,需要一個線程來進(jìn)行響應(yīng)。當(dāng)用戶退出,這個線程并不是被銷毀,而是清理此線程重新收歸到線程池當(dāng)中的空閑線程中)
Connection Limits:線程池的大小決定了連接并發(fā)數(shù)的上限。
Check Memory:線程內(nèi)存檢查
Caches:線程緩存。
SQL Interface:類似于mysql的shell,SQL命令的解釋器,支持過程式編程,支持視圖、存儲過程、存儲函數(shù)、觸發(fā)器,分析語法問題等等。
Parser:SQL語句分析器,并不分析語法問題,進(jìn)行語句的執(zhí)行分析。查詢翻譯,將一個查詢語句轉(zhuǎn)化成對應(yīng)的可以識別的語句,能在本地執(zhí)行的特定操作。分析是對某個對象有訪問權(quán)限等。
Optimizer:負(fù)責(zé)檢查多條路徑及每條路徑的開銷,評估開銷(開銷的計(jì)算依賴于索引,動態(tài)生產(chǎn)的統(tǒng)計(jì)數(shù)據(jù),內(nèi)部組件等)。生成統(tǒng)計(jì)數(shù)據(jù)等。
Caches&Buffers:MySQL的某些存儲引擎,將訪問到的頻繁的熱點(diǎn)數(shù)據(jù)裝入內(nèi)存,用戶直接訪問內(nèi)存便于訪問。所MySQL需要維護(hù)一個Caches&Buffers.
Pluggable Storage Engines:
插件式存儲引擎。MyISAM、InnoDB、NDB、Archive、Memory等,存儲引起負(fù)責(zé)把具體分析的結(jié)果(Optimizer),完成對磁盤上文件的路徑訪問的轉(zhuǎn)換。
存儲引擎需要把語句映射到磁盤塊,并將磁盤塊加載到內(nèi)存中。
FileSystem:物理視圖,在操作系統(tǒng)級別,MySQL的數(shù)據(jù)存儲為一個個文件。
Files&Logs:
Redo:重做日志
Undo:撤銷日志
Data:數(shù)據(jù)文件
Index:索引文件
Binary:二進(jìn)制日志文件
Error:錯誤日志
Query and Slow:查詢?nèi)罩竞吐樵內(nèi)罩?/p>
簡化架構(gòu)說明
流程說明:
1.各種客戶端通過連接器,交由連接線程處理。負(fù)載連接線程的創(chuàng)建、管理、銷毀等。
2.用戶發(fā)出語句后,由分析器進(jìn)行分析。如果是查詢語句,直接進(jìn)入查詢緩存。
3.如果命中,直接返回,如果未命中。則繼續(xù)交給優(yōu)化器。
4.優(yōu)化完成以后,交給存儲引擎負(fù)責(zé)對應(yīng)的文件系統(tǒng),取到相關(guān)的數(shù)據(jù)。加載到內(nèi)存中,由存儲引擎挑選出對應(yīng)的行或符合條件的行。
對于以上關(guān)于mysql architecture詳解,如果大家還有更多需要了解的可以持續(xù)關(guān)注我們創(chuàng)新互聯(lián)的行業(yè)推新,如需獲取專業(yè)解答,可在官網(wǎng)聯(lián)系售前售后的,希望該文章可給大家?guī)硪欢ǖ闹R更新。