婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Mysql邏輯架構(gòu)詳解

Mysql邏輯架構(gòu)詳解

熱門標(biāo)簽:南昌高頻外呼系統(tǒng)哪家公司做的好 淄博400電話申請(qǐng) 電話機(jī)器人市場(chǎng)趨勢(shì) 電銷機(jī)器人 行業(yè) 百度地圖標(biāo)注后不顯示 昆明電信400電話辦理 電銷機(jī)器人各個(gè)細(xì)節(jié)介紹 溫州瑞安400電話怎么申請(qǐng) 俄國(guó)地圖標(biāo)注app

1. 整體架構(gòu)圖

和其它數(shù)據(jù)庫(kù)相比,MySQL有點(diǎn)與眾不同,它的架構(gòu)可以在多種不同場(chǎng)景中應(yīng)用并發(fā)揮良好作用。主要體現(xiàn)在存儲(chǔ)引擎的架構(gòu)上,插件式的存儲(chǔ)引擎架構(gòu)將查詢處理和其它的系統(tǒng)任務(wù)以及數(shù)據(jù)的存儲(chǔ)提取相分離。這種架構(gòu)可以根據(jù)業(yè)務(wù)的需求和實(shí)際需要選擇合適的存儲(chǔ)引擎。

各層介紹:

1.1 連接層

最上層是一些客戶端和連接服務(wù),包含本地sock通信和大多數(shù)基于客戶端/服務(wù)端工具實(shí)現(xiàn)的類似于tcp/ip的通信。主要完成一些類似于連接處理、授權(quán)認(rèn)證、及相關(guān)的安全方案。在該層上引入了線程池的概念,為通過(guò)認(rèn)證安全接入的客戶端提供線程。同樣在該層上可以實(shí)現(xiàn)基于SSL的安全鏈接。服務(wù)器也會(huì)為安全接入的每個(gè)客戶端驗(yàn)證它所具有的操作權(quán)限。

1.2 服務(wù)層

1.3.引擎層

存儲(chǔ)引擎層,存儲(chǔ)引擎真正的負(fù)責(zé)了MySQL中數(shù)據(jù)的存儲(chǔ)和提取,服務(wù)器通過(guò)API與存儲(chǔ)引擎進(jìn)行通信。不同的存儲(chǔ)引擎具有的功能不同,這樣我們可以根據(jù)自己的實(shí)際需要進(jìn)行選取。

1.4.存儲(chǔ)層

數(shù)據(jù)存儲(chǔ)層,主要是將數(shù)據(jù)存儲(chǔ)在運(yùn)行于裸設(shè)備的文件系統(tǒng)之上,并完成與存儲(chǔ)引擎的交互。

2. show profile

利用show profile可以查看sql的執(zhí)行周期!

2.1 開(kāi)啟profile

查看profile是否開(kāi)啟:show variables  like '%profiling%'

如果沒(méi)有開(kāi)啟,可以執(zhí)行set profiling=1開(kāi)啟!

2.2 使用profile

執(zhí)行show prifiles命令,可以查看最近的幾次查詢。

根據(jù)Query_ID,可以進(jìn)一步執(zhí)行show profile cpu,block io for query Query_id來(lái)查看sql的具體執(zhí)行步驟。

2.3 大致的查詢流程

mysql的查詢流程大致是:

mysql客戶端通過(guò)協(xié)議與mysql服務(wù)器建連接,發(fā)送查詢語(yǔ)句,先檢查查詢緩存,如果命中,直接返回結(jié)果,否則進(jìn)行語(yǔ)句解析,也就是說(shuō),在解析查詢之前,服務(wù)器會(huì)先訪問(wèn)查詢緩存(query cache)——它存儲(chǔ)SELECT語(yǔ)句以及相應(yīng)的查詢結(jié)果集。如果某個(gè)查詢結(jié)果已經(jīng)位于緩存中,服務(wù)器就不會(huì)再對(duì)查詢進(jìn)行解析、優(yōu)化、以及執(zhí)行。它僅僅將緩存中的結(jié)果返回給用戶即可,這將大大提高系統(tǒng)的性能。

語(yǔ)法解析器和預(yù)處理:首先mysql通過(guò)關(guān)鍵字將SQL語(yǔ)句進(jìn)行解析,并生成一顆對(duì)應(yīng)的“解析樹(shù)”。mysql解析器將使用mysql語(yǔ)法規(guī)則驗(yàn)證和解析查詢;預(yù)處理器則根據(jù)一些mysql規(guī)則進(jìn)一步檢查解析數(shù)是否合法。

查詢優(yōu)化器當(dāng)解析樹(shù)被認(rèn)為是合法的了,并且由優(yōu)化器將其轉(zhuǎn)化成執(zhí)行計(jì)劃。一條查詢可以有很多種執(zhí)行方式,最后都返回相同的結(jié)果。優(yōu)化器的作用就是找到這其中最好的執(zhí)行計(jì)劃。。

然后,mysql默認(rèn)使用的BTREE索引,并且一個(gè)大致方向是:無(wú)論怎么折騰sql,至少在目前來(lái)說(shuō),mysql最多只用到表中的一個(gè)索引。

2.4 SQL的執(zhí)行順序

手寫的順序:

真正執(zhí)行的順序:

隨著Mysql版本的更新?lián)Q代,其優(yōu)化器也在不斷的升級(jí),優(yōu)化器會(huì)分析不同執(zhí)行順序產(chǎn)生的性能消耗不同而動(dòng)態(tài)調(diào)整執(zhí)行順序。下面是經(jīng)常出現(xiàn)的查詢順序:

2.5 MyISAM和InnoDB

show engines:查看所有的數(shù)據(jù)庫(kù)引擎

show variables like '%storage_engine%' 查看默認(rèn)的數(shù)據(jù)庫(kù)引擎

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

您可能感興趣的文章:
  • MySQL雙主(主主)架構(gòu)配置方案
  • 深入了解Mysql邏輯架構(gòu)
  • MySQL 整體架構(gòu)介紹
  • MySQL20個(gè)高性能架構(gòu)設(shè)計(jì)原則(值得收藏)
  • MySQL 4種常用的主從復(fù)制架構(gòu)
  • MySQL 學(xué)習(xí)總結(jié) 之 初步了解 InnoDB 存儲(chǔ)引擎的架構(gòu)設(shè)計(jì)
  • MySQL架構(gòu)體系知識(shí)點(diǎn)總結(jié)
  • MySQL數(shù)據(jù)庫(kù)體系架構(gòu)詳情

標(biāo)簽:拉薩 甘南 洛陽(yáng) 海口 吐魯番 嘉峪關(guān) 葫蘆島 安徽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql邏輯架構(gòu)詳解》,本文關(guān)鍵詞  Mysql,邏輯,架構(gòu),詳解,Mysql,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql邏輯架構(gòu)詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Mysql邏輯架構(gòu)詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 延安市| 宁夏| 桃江县| 运城市| 织金县| 宜州市| 鹿邑县| 北海市| 娄底市| 阿拉善右旗| 九龙县| 绥滨县| 开江县| 鲜城| 许昌市| 高邮市| 河曲县| 宣汉县| 介休市| 大埔县| 京山县| 浦县| 祁阳县| 张掖市| 崇礼县| 平顶山市| 汶川县| 渭南市| 利川市| 迁安市| 高碑店市| 阳原县| 阳曲县| 中卫市| 灵石县| 巴林左旗| 夏河县| 海伦市| 延寿县| 滕州市| 朝阳区|