Mysql 服務(wù)器處理客戶端請求

服務(wù)器處理客戶端請求


其實不論客戶端進程和服務(wù)器進程是采用哪種方式進行通信坎匿,最后實現(xiàn)的效果都是:客戶端進程向服務(wù)器進程發(fā)送一段文本(MySQL語句),服務(wù)器進程處理后再向客戶端進程發(fā)送一段文本(處理結(jié)果)吭净。那服務(wù)器進程對客戶端進程發(fā)送的請求做了什么處理,才能產(chǎn)生最后的處理結(jié)果呢肴甸?客戶端可以向服務(wù)器發(fā)送增刪改查各類請求寂殉,我們這里以比較復雜的查詢請求為例來畫個圖展示一下大致的過程:

  • 連接管理
  • 客戶端進程可以采用TCP/IP命名管道或共享內(nèi)存原在、Unix域套接字這幾種方式之一來與服務(wù)器進程建立連接友扰,每當有一個客戶端進程連接到服務(wù)器進程時,服務(wù)器進程都會創(chuàng)建一個線程來專門處理與這個客戶端的交互庶柿,當該客戶端退出時會與服務(wù)器斷開連接村怪,服務(wù)器并不會立即把與該客戶端交互的線程銷毀掉,而是把它緩存起來浮庐,在另一個新的客戶端再進行連接時甚负,把這個緩存的線程分配給該新客戶端。這樣就起到了不頻繁創(chuàng)建和銷毀線程的效果审残,從而節(jié)省開銷梭域。從這一點大家也能看出,MySQL服務(wù)器會為每一個連接進來的客戶端分配一個線程搅轿,但是線程分配的太多了會嚴重影響系統(tǒng)性能病涨,所以我們也需要限制一下可以同時連接到服務(wù)器的客戶端數(shù)量。
    在客戶端程序發(fā)起連接的時候璧坟,需要攜帶主機信息没宾、用戶名、密碼沸柔,服務(wù)器程序會對客戶端程序提供的這些信息進行認證循衰,如果認證失敗,服務(wù)器程序會拒絕連接褐澎。另外会钝,如果客戶端程序和服務(wù)器程序不運行在一臺計算機上,我們還可以采用使用了SSL(安全套接字)的網(wǎng)絡(luò)連接進行通信,來保證數(shù)據(jù)傳輸?shù)陌踩浴?br>當連接建立后迁酸,與該客戶端關(guān)聯(lián)的服務(wù)器線程會一直等待客戶端發(fā)送過來的請求先鱼,MySQL服務(wù)器接收到的請求只是一個文本消息,該文本消息還要經(jīng)過各種處理奸鬓。

  • 解析與優(yōu)化
    解析與優(yōu)化的過程具體可以劃分為三個步驟:查詢緩存焙畔、語法解析查詢優(yōu)化
  • (1)查詢緩存
    MySQL的緩存系統(tǒng)會監(jiān)測涉及到的每張表,只要該表的結(jié)構(gòu)或者數(shù)據(jù)被修改串远,如對該表使用了INSERT宏多、 UPDATE、DELETE澡罚、TRUNCATE TABLE伸但、ALTER TABLE、DROP TABLE或 DROP DATABASE語句留搔,那使用該表的所有高速緩存查詢都將變?yōu)闊o效并從高速緩存中刪除更胖!從MySQL 5.7.20開始,不推薦使用查詢緩存隔显,并在MySQL 8.0中刪除却妨。
    (2)語法解析
    如果查詢緩存沒有命中,接下來就需要進入正式的查詢階段了括眠。因為客戶端程序發(fā)送過來的請求只是一段文本而已彪标,所以MySQL服務(wù)器程序首先要對這段文本做分析,判斷請求的語法是否正確哺窄,然后從文本中將要查詢的表捐下、各種查詢條件都提取出來放到MySQL服務(wù)器內(nèi)部使用的一些數(shù)據(jù)結(jié)構(gòu)上來萌业。
  • (3)查詢優(yōu)化
    語法解析之后,服務(wù)器程序獲得到了需要的信息奸柬,比如要查詢的列是哪些生年,表是哪個廓奕,搜索條件是什么等等桌粉,但光有這些是不夠的铃肯,因為我們寫的MySQL語句執(zhí)行起來效率可能并不是很高,MySQL的優(yōu)化程序會對我們的語句做一些優(yōu)化惦界,如外連接轉(zhuǎn)換為內(nèi)連接咙冗、表達式簡化沾歪、子查詢轉(zhuǎn)為連接吧啦吧啦的一堆東西。優(yōu)化的結(jié)果就是生成一個執(zhí)行計劃雾消,這個執(zhí)行計劃表明了應(yīng)該使用哪些索引進行查詢灾搏,表之間的連接順序是啥樣的。我們可以使用EXPLAIN語句來查看某個語句的執(zhí)行計劃仪或,關(guān)于查詢優(yōu)化這部分的詳細內(nèi)容我們后邊會仔細嘮叨确镊,現(xiàn)在你只需要知道在MySQL服務(wù)器程序處理請求的過程中有這么一個步驟就好了。
  • 存儲引擎
    截止到服務(wù)器程序完成了查詢優(yōu)化為止范删,還沒有真正的去訪問真實的數(shù)據(jù)表蕾域,MySQL服務(wù)器把數(shù)據(jù)的存儲和提取操作都封裝到了一個叫存儲引擎的模塊里。我們知道表是由一行一行的記錄組成的到旦,但這只是一個邏輯上的概念旨巷,物理上如何表示記錄,怎么從表中讀取數(shù)據(jù)添忘,怎么把數(shù)據(jù)寫入具體的物理存儲器上采呐,這都是存儲引擎負責的事情。為了實現(xiàn)不同的功能搁骑,MySQL提供了各式各樣的存儲引擎斧吐,不同存儲引擎管理的表具體的存儲結(jié)構(gòu)可能不同,采用的存取算法也可能不同仲器。
    為了管理方便煤率,人們把連接管理、查詢緩存乏冀、語法解析蝶糯、查詢優(yōu)化這些并不涉及真實數(shù)據(jù)存儲的功能劃分為MySQL server的功能,把真實存取數(shù)據(jù)的功能劃分為存儲引擎的功能辆沦。各種不同的存儲引擎向上邊的MySQL server層提供統(tǒng)一的調(diào)用接口(也就是存儲引擎API)昼捍,包含了幾十個底層函數(shù),像”讀取索引第一條內(nèi)容”肢扯、”讀取索引下一條內(nèi)容”妒茬、”插入記錄”等等。
    所以在MySQL server完成了查詢優(yōu)化后蔚晨,只需按照生成的執(zhí)行計劃調(diào)用底層存儲引擎提供的API乍钻,獲取到數(shù)據(jù)后返回給客戶端就好了。
  • ?

    最后編輯于
    ?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
    • 序言:七十年代末,一起剝皮案震驚了整個濱河市团赁,隨后出現(xiàn)的幾起案子育拨,更是在濱河造成了極大的恐慌,老刑警劉巖欢摄,帶你破解...
      沈念sama閱讀 211,884評論 6 492
    • 序言:濱河連續(xù)發(fā)生了三起死亡事件熬丧,死亡現(xiàn)場離奇詭異,居然都是意外死亡怀挠,警方通過查閱死者的電腦和手機析蝴,發(fā)現(xiàn)死者居然都...
      沈念sama閱讀 90,347評論 3 385
    • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绿淋,“玉大人闷畸,你說我怎么就攤上這事⊥讨停” “怎么了佑菩?”我有些...
      開封第一講書人閱讀 157,435評論 0 348
    • 文/不壞的土叔 我叫張陵,是天一觀的道長裁赠。 經(jīng)常有香客問我殿漠,道長,這世上最難降的妖魔是什么佩捞? 我笑而不...
      開封第一講書人閱讀 56,509評論 1 284
    • 正文 為了忘掉前任绞幌,我火速辦了婚禮,結(jié)果婚禮上一忱,老公的妹妹穿的比我還像新娘莲蜘。我一直安慰自己,他們只是感情好帘营,可當我...
      茶點故事閱讀 65,611評論 6 386
    • 文/花漫 我一把揭開白布票渠。 她就那樣靜靜地躺著,像睡著了一般仪吧。 火紅的嫁衣襯著肌膚如雪庄新。 梳的紋絲不亂的頭發(fā)上鞠眉,一...
      開封第一講書人閱讀 49,837評論 1 290
    • 那天薯鼠,我揣著相機與錄音,去河邊找鬼械蹋。 笑死出皇,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的哗戈。 我是一名探鬼主播郊艘,決...
      沈念sama閱讀 38,987評論 3 408
    • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了纱注?” 一聲冷哼從身側(cè)響起畏浆,我...
      開封第一講書人閱讀 37,730評論 0 267
    • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎狞贱,沒想到半個月后刻获,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
      沈念sama閱讀 44,194評論 1 303
    • 正文 獨居荒郊野嶺守林人離奇死亡瞎嬉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
      茶點故事閱讀 36,525評論 2 327
    • 正文 我和宋清朗相戀三年蝎毡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氧枣。...
      茶點故事閱讀 38,664評論 1 340
    • 序言:一個原本活蹦亂跳的男人離奇死亡沐兵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出便监,到底是詐尸還是另有隱情扎谎,我是刑警寧澤,帶...
      沈念sama閱讀 34,334評論 4 330
    • 正文 年R本政府宣布烧董,位于F島的核電站簿透,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏解藻。R本人自食惡果不足惜老充,卻給世界環(huán)境...
      茶點故事閱讀 39,944評論 3 313
    • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望螟左。 院中可真熱鬧啡浊,春花似錦、人聲如沸胶背。這莊子的主人今日做“春日...
      開封第一講書人閱讀 30,764評論 0 21
    • 文/蒼蘭香墨 我抬頭看了看天上的太陽钳吟。三九已至廷粒,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間红且,已是汗流浹背坝茎。 一陣腳步聲響...
      開封第一講書人閱讀 31,997評論 1 266
    • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留暇番,地道東北人嗤放。 一個月前我還...
      沈念sama閱讀 46,389評論 2 360
    • 正文 我出身青樓,卻偏偏與公主長得像壁酬,于是被迫代替她去往敵國和親次酌。 傳聞我的和親對象是個殘疾皇子恨课,可洞房花燭夜當晚...
      茶點故事閱讀 43,554評論 2 349