国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

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

這篇具有很好參考價值的文章主要介紹了1.6 服務(wù)器處理客戶端請求。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

客戶端進(jìn)程向服務(wù)器進(jìn)程發(fā)送一段文本(MySQL語句),服務(wù)器進(jìn)程處理后再向客戶端進(jìn)程發(fā)送一段文本(處理結(jié)果)。

1.6 服務(wù)器處理客戶端請求,MySQL,服務(wù)器,運(yùn)維

從圖中我們可以看出,服務(wù)器程序處理來自客戶端的查詢請求大致需要經(jīng)過三個部分,分別是 連接管理 、 解析與優(yōu)化 、 存儲引擎 。

1.6.1 連接管理

客戶端進(jìn)程可以采用我們上邊介紹的 TCP/IP 、 命名管道或共享內(nèi)存 、 Unix域套接字 這幾種方式之一來與服務(wù)器進(jìn)程建立連接,每當(dāng)有一個客戶端進(jìn)程連接到服務(wù)器進(jìn)程時,服務(wù)器進(jìn)程都會創(chuàng)建一個線程來專門處理與這個客戶端的交互,當(dāng)該客戶端退出時會與服務(wù)器斷開連接,服務(wù)器并不會立即把與該客戶端交互的線程銷毀掉,而是把它緩存起來,在另一個新的客戶端再進(jìn)行連接時,把這個緩存的線程分配給該新客戶端。這樣就起到了不頻繁創(chuàng)建和銷毀線程的效果,從而節(jié)省開銷。從這一點大家也能看出, MySQL 服務(wù)器會為每一個連接進(jìn)來的客戶端分配一個線程,但是線程分配的太多了會嚴(yán)重影響系統(tǒng)性能,所以我們也需要限制一下可以同時連接到服務(wù)器的客戶端數(shù)量。

在客戶端程序發(fā)起連接的時候,需要攜帶主機(jī)信息、用戶名、密碼,服務(wù)器程序會對客戶端程序提供的這些信息進(jìn)行認(rèn)證,如果認(rèn)證失敗,服務(wù)器程序會拒絕連接。另外,如果客戶端程序和服務(wù)器程序不運(yùn)行在一臺計算機(jī)上,我們還可以采用使用了 SSL (安全套接字)的網(wǎng)絡(luò)連接進(jìn)行通信,來保證數(shù)據(jù)傳輸?shù)陌踩浴?/p>

當(dāng)連接建立后,與該客戶端關(guān)聯(lián)的服務(wù)器線程會一直等待客戶端發(fā)送過來的請求, MySQL 服務(wù)器接收到的請求只是一個文本消息,該文本消息還要經(jīng)過各種處理。

1.6.2 解析與優(yōu)化

1.6.2.1 查詢緩存

MySQL服務(wù)器處理查詢請求的時候,會把剛剛處理過的查詢請求和結(jié)果緩存起來,如果下次有一樣的請求過來,直接從緩存中查找結(jié)果就好了。這個查詢緩存可以在不同客戶端之間共享,也就是說如果客戶端A剛剛查詢了一個語句,而客戶端B之后發(fā)送了同樣的查詢請求,那么客戶端B的這次查詢就可以直接使用查詢緩存中的數(shù)據(jù)。

不過,如果兩個查詢請求在任何字符上的不同(例如:空格、注釋、大小寫),都會導(dǎo)致緩存不會命中。另外,如果查詢請求中包含某些系統(tǒng)函數(shù)、用戶自定義變量和函數(shù)、一些系統(tǒng)表,如mysql 、information_schema、 performance_schema 數(shù)據(jù)庫中的表,那這個請求就不會被緩存。

既然是緩存,那就有它緩存失效的時候。MySQL的緩存系統(tǒng)會監(jiān)測涉及到的每張表,只要該表的結(jié)構(gòu)或者數(shù)據(jù)被修改,如對該表使用了 INSERT 、 UPDATE 、 DELETE 、 TRUNCATE TABLE 、 ALTER TABLE 、 DROP TABLE 或DROP DATABASE 語句,那使用該表的所有高速緩存查詢都將變?yōu)闊o效并從高速緩存中刪除。

1.6.2.2 語法解析

如果查詢緩存沒有命中,接下來就需要進(jìn)入正式的查詢階段了。因為客戶端程序發(fā)送過來的請求只是一段文本而已,所以 MySQL 服務(wù)器程序首先要對這段文本做分析,判斷請求的語法是否正確,然后從文本中將要查詢的表、各種查詢條件都提取出來放到 MySQL 服務(wù)器內(nèi)部使用的一些數(shù)據(jù)結(jié)構(gòu)上來。

1.6.2.3 查詢優(yōu)化

語法解析之后,服務(wù)器程序獲得到了需要的信息,比如要查詢的列是哪些,表是哪個,搜索條件是什么等等。因為我們自己寫的效率不夠高,MySQL 的優(yōu)化程序會對我們的語句做一些優(yōu)化,如外連接轉(zhuǎn)換為內(nèi)連接、表達(dá)式簡化、子查詢轉(zhuǎn)為連接等,優(yōu)化的結(jié)果就是生成一個執(zhí)行計劃,這個執(zhí)行計劃表明了應(yīng)該使用哪些索引進(jìn)行查詢,表之間的連接順序是啥樣的。我們可以使用EXPLAIN 語句來查看某個語句的執(zhí)行計劃。

1.6.3 存儲引擎

截止到服務(wù)器程序完成了查詢優(yōu)化為止,還沒有真正的去訪問真實的數(shù)據(jù)表, MySQL 服務(wù)器把數(shù)據(jù)的存儲和提取操作都封裝到了一個叫 存儲引擎 的模塊里。我們知道 表 是由一行一行的記錄組成的,但這只是一個邏輯上的概念,物理上如何表示記錄,怎么從表中讀取數(shù)據(jù),怎么把數(shù)據(jù)寫入具體的物理存儲器上,這都是 存儲引擎 負(fù)責(zé)的事情。為了實現(xiàn)不同的功能, MySQL 提供了各式各樣的 存儲引擎 ,不同 存儲引擎 管理的表具體的存儲結(jié)構(gòu)可能不同,采用的存取算法也可能不同。

為了管理方便,人們把 連接管理 、 查詢緩存 、 語法解析 、 查詢優(yōu)化 這些并不涉及真實數(shù)據(jù)存儲的功能劃分為 MySQL server 的功能,把真實存取數(shù)據(jù)的功能劃分為 存儲引擎 的功能。各種不同的存儲引擎向上邊的 MySQLserver 層提供統(tǒng)一的調(diào)用接口(也就是存儲引擎API),包含了幾十個底層函數(shù),像"讀取索引第一條內(nèi)容"、"讀取索引下一條內(nèi)容"、"插入記錄"等等。

所以在 MySQL server 完成了查詢優(yōu)化后,只需按照生成的執(zhí)行計劃調(diào)用底層存儲引擎提供的API,獲取到數(shù)據(jù)后返回給客戶端就好了。

?文章來源地址http://www.zghlxwxcb.cn/news/detail-672974.html

到了這里,關(guān)于1.6 服務(wù)器處理客戶端請求的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • MYSQL連接報錯:客戶端不支持服務(wù)器請求的身份驗證協(xié)議;考慮升級MYSQL客戶端數(shù)據(jù)庫

    在進(jìn)行MYSQL數(shù)據(jù)庫連接時,有時候可能會遇到如上所述的錯誤:“客戶端不支持服務(wù)器請求的身份驗證協(xié)議;考慮升級MYSQL客戶端數(shù)據(jù)庫”。這個錯誤通常發(fā)生在客戶端使用的MYSQL版本與服務(wù)器所要求的身份驗證協(xié)議不兼容的情況下。幸運(yùn)的是,您可以通過升級MYSQL客戶端來解

    2024年02月03日
    瀏覽(24)
  • HTTP介紹 原理 消息結(jié)構(gòu) 客戶端請求 服務(wù)器響應(yīng) HTTP狀態(tài)碼

    HTTP介紹 原理 消息結(jié)構(gòu) 客戶端請求 服務(wù)器響應(yīng) HTTP狀態(tài)碼

    HTTP協(xié)議 是Hyper Text Transfer Protocol(超文本傳輸協(xié)議)的縮寫,是用于萬維網(wǎng)(www.world wide web)服務(wù)器傳輸超文本到本地瀏覽器的傳送協(xié)議 HTTP 是基于TCP/IP(三次握手,四次揮手)通信協(xié)議來傳輸數(shù)據(jù)(HTML文件,圖片文件,查詢結(jié)果等) TCP:可靠的,丟包重傳 UTP:不可靠的,直播,

    2024年02月05日
    瀏覽(28)
  • 【Navicat 連接MySQL時出現(xiàn)錯誤1251:客戶端不支持服務(wù)器請求的身份驗證協(xié)議;請考慮升級MySQL客戶端】

    【Navicat 連接MySQL時出現(xiàn)錯誤1251:客戶端不支持服務(wù)器請求的身份驗證協(xié)議;請考慮升級MySQL客戶端】

    使用Navicat連接時報1251錯誤,如下圖: Navicat是一款流行的數(shù)據(jù)庫管理工具,它能夠方便地連接和管理各種數(shù)據(jù)庫。然而,有時候當(dāng)我們嘗試連接MySQL數(shù)據(jù)庫時,可能會遇到錯誤1251:客戶端不支持服務(wù)器請求的身份驗證協(xié)議的問題。這個問題可能會讓一些用戶感到困惑,影響到

    2024年02月13日
    瀏覽(26)
  • 后端服務(wù)器的響應(yīng)為什么能夠精準(zhǔn)的返回給請求它的那個客戶端

    正向代理位于客戶端和目標(biāo)服務(wù)器之間,代表客戶端發(fā)送請求;–》代理客戶端 反向代理位于目標(biāo)服務(wù)器和客戶端之間,代表目標(biāo)服務(wù)器接收請求。–》代理服務(wù)端 當(dāng)客戶端發(fā)送請求到反向代理服務(wù)器時,反向代理服務(wù)器會在轉(zhuǎn)發(fā)請求給后端服務(wù)器之前,記錄請求的源IP地址

    2024年02月12日
    瀏覽(24)
  • Flask框架小程序后端分離開發(fā)學(xué)習(xí)筆記《3》客戶端向服務(wù)器端發(fā)送請求

    Flask框架小程序后端分離開發(fā)學(xué)習(xí)筆記《3》客戶端向服務(wù)器端發(fā)送請求

    Flask是使用python的后端,由于小程序需要后端開發(fā),遂學(xué)習(xí)一下后端開發(fā)。 可以看到上述代碼構(gòu)建了一個HTTP請求,在發(fā)送之前需要將發(fā)送之前,使用http_request.encode(‘utf-8’)。 這是因為我們在這構(gòu)建的請求是字符串文本,而電腦只認(rèn)識二進(jìn)制0和1,所以需要將其數(shù)據(jù)類型轉(zhuǎn)換

    2024年01月22日
    瀏覽(39)
  • S7-1200中通過MODBUS TCP客戶端在一次請求中實現(xiàn)從服務(wù)器讀寫一個或多個保持性寄存器的具體方法

    S7-1200中通過MODBUS TCP客戶端在一次請求中實現(xiàn)從服務(wù)器讀寫一個或多個保持性寄存器的具體方法

    TIA博途V17中增加了MODBUS TCP客戶端功能碼 23,可以在一次請求作業(yè)下實現(xiàn)從服務(wù)器讀取和寫入一個或多個保持性寄存器,這樣省去了輪詢的編程工作量,提高了工作效率,如下圖所示, 使用該指令的前提條件: ? TIA Portal V17 及以上版本 ? CPU 固件 V4.2 及以上版本 具體操作方

    2024年02月12日
    瀏覽(24)
  • 服務(wù)器異步客戶端

    internal class MessageManagerT:SingletonMessageManagerT { ? ? Dictionaryint, ActionT MsgDic = new Dictionaryint, ActionT(); ? ? public void OnAddListen(int id,ActionT action) ? ? { ? ? ? ? if(MsgDic.ContainsKey(id)) ? ? ? ? { ? ? ? ? ? ? MsgDic[id] += action; ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? MsgDic.Add(id, ac

    2024年04月09日
    瀏覽(24)
  • ZeroTier客戶端連接服務(wù)器

    ZeroTier客戶端連接服務(wù)器 下載客戶端 https://www.zerotier.com/download/ 加入新的網(wǎng)絡(luò)(例如d5e04297a16fa690,由管理員提供) 管理員授權(quán)并告知服務(wù)器IP 測試連接:ping 服務(wù)器IP 使用putty, pycharm, vscode等工具連接即可 官方文檔 https://docs.zerotier.com/getting-started/getting-started 注: 若路由器無法

    2024年02月09日
    瀏覽(27)
  • UDP客戶端和服務(wù)器

    UDP客戶端和服務(wù)器

    UDP客戶端,也就是首先主動發(fā)送數(shù)據(jù)的一方,也就是發(fā)起服務(wù)請求的一方。 UDP服務(wù)器,也就是首先等待接收數(shù)據(jù),并對接收的數(shù)據(jù)進(jìn)行處理,返回計算結(jié)果的一方,也就是提供服務(wù)的一方。 在下面實驗中使用到的函數(shù) 測試代碼? UDP接收端(服務(wù)器) 執(zhí)行代碼: ?? 實驗解析?

    2024年02月13日
    瀏覽(33)
  • UDP通訊(服務(wù)器/客戶端)

    UDP通訊(服務(wù)器/客戶端)

    前言:UDP通訊實現(xiàn)比較簡單,單某些情況下也會使用,建議先看一下說明,然后運(yùn)行代碼感受一下。 ????????傳輸層主要應(yīng)用的協(xié)議模型有兩種,一種是TCP協(xié)議,另外一種則是UDP協(xié)議。TCP協(xié)議在網(wǎng)絡(luò)通信中占主導(dǎo)地位,絕大多數(shù)的網(wǎng)絡(luò)通信借助TCP協(xié)議完成數(shù)據(jù)傳輸。但U

    2024年02月03日
    瀏覽(31)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包