国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Redis:我是如何與客戶端進行通信的

網絡 網絡管理 Redis
我把創造出來的這種協議稱為 RESP (REdis Serialization Protocol)協議,它工作在 TCP 協議的上層,作為我和客戶端之間進行通訊的標準形式。

[[406813]]

江湖上說,天下武功,無堅不摧,唯快不破,這句話簡直是為我量身定制。

我是一個Redis服務,最引以為傲的就是我的速度,我的 QPS 能達到10萬級別。

在我的手下有數不清的小弟,他們會時不時到我這來存放或者取走一些數據,我管他們叫做客戶端,還給他們起了英文名叫 Redis-client。

有時候一個小弟會來的非常頻繁,有時候一堆小弟會同時過來,但是,即使再多的小弟我也能管理的井井有條。

有一天,小弟們問我。

想當年,為了不讓小弟們拖垮我傲人的速度,在設計和他們的通信協議時,我絞盡腦汁,制定了下面的三條原則:

  • 實現簡單
  • 針對計算機來說,解析速度快
  • 針對人類來說,可讀性強

為什么這么設計呢?先來看看一條指令發出的過程,首先在客戶端需要對指令操作進行封裝,使用網絡進行傳輸,最后在服務端進行相應的解析、執行。

圖片

這一過程如果設計成一種非常復雜的協議,那么封裝、解析、傳輸的過程都將非常耗時,無疑會降低我的速度。什么,你問我為什么要遵循最后一條規則?算是對于程序員們的饋贈吧,我真是太善良了。

我把創造出來的這種協議稱為 RESP (REdis Serialization Protocol)協議,它工作在 TCP 協議的上層,作為我和客戶端之間進行通訊的標準形式。

說到這,我已經有點迫不及待想讓你們看看我設計出來的杰作了,但我好歹也是個大哥,得擺點架子,不能我主動拿來給你們看。

所以我建議你直接使用客戶端發出一條向服務器的命令,然后取出這條命令對應的報文來直觀的看一下。話雖如此,不過我已經被封裝的很嚴實了,正常情況下你是看不到我內部進行通訊的具體報文的,所以,你可以偽裝成一個Redis的服務端,來截獲小弟們發給我的消息。

實現起來也很簡單,我和小弟之間是基于 Socket 進行通訊,所以在本地先啟動一個ServerSocket,用來監聽Redis服務的6379端口:

  1. public static void server() throws IOException { 
  2.     ServerSocket serverSocket = new ServerSocket(6379); 
  3.     Socket socket = serverSocket.accept(); 
  4.     byte[] bytes = new byte[1024]; 
  5.     InputStream input = socket.getInputStream(); 
  6.     while(input.read(bytes)!=0){ 
  7.         System.out.println(new String(bytes)); 
  8.     } 

然后啟動redis-cli客戶端,發送一條命令:

  1. set key1 value1 

這時,偽裝的服務端就會收到報文了,在控制臺打印了:

  1. *3 
  2. $3 
  3. set 
  4. $4 
  5. key1 
  6. $6 
  7. value1 

看到這里,隱隱約約看到了剛才輸入的幾個關鍵字,但是還有一些其他的字符,要怎么解釋呢,是時候讓我對協議報文中的格式進行一下揭秘了。

我對小弟們說了,對大哥說話的時候得按規矩來,這樣吧,你們在請求的時候要遵循下面的規則:

  1. *<參數數量> CRLF 
  2. $<參數1的字節長度> CRLF 
  3. <參數1的數據> CRLF 
  4. $<參數2的字節長度> CRLF 
  5. <參數2的數據> CRLF 
  6. ... 
  7. $<參數N的字節長度> CRLF 
  8. <參數N的數據> CRLF 

首先解釋一下每行末尾的CRLF,轉換成程序語言就是\r\n,也就是回車加換行。看到這里,你也就能夠明白為什么控制臺打印出的指令是豎向排列了吧。

在命令的解析過程中,set、key1、value1會被認為是3個參數,因此參數數量為3,對應第一行的*3。

第一個參數set,長度為3對應$3;第二個參數key1,長度為4對應$4;第三個參數value1,長度為6對應$6。在每個參數長度的下一行對應真正的參數數據。

看到這,一條指令被轉換為協議報文的過程是不是就很好理解了?

圖片

當小弟對我發送完請求后,作為大哥,我就要對小弟的請求進行指令回復了,而且我得根據回復內容進行一下分類,要不然小弟該搞不清我的指示了。

簡單字符串

簡單字符串回復只有一行回復,回復的內容以+作為開頭,不允許換行,并以\r\n結束。有很多指令在執行成功后只會回復一個OK,使用的就是這種格式,能夠有效的將傳輸、解析的開銷降到最低。

錯誤回復

在RESP協議中,錯誤回復可以當做簡單字符串回復的變種形式,它們之間的格式也非常類似,區別只有第一個字符是以-作為開頭,錯誤回復的內容通常是錯誤類型及對錯誤描述的字符串。

錯誤回復出現在一些異常的場景,例如當發送了錯誤的指令、操作數的數量不對時,都會進行錯誤回復。在客戶端收到錯誤回復后,會將它與簡單字符串回復進行區分,視為異常。

整數回復

整數回復的應用也非常廣泛,它以:作為開頭,以\r\n結束,用于返回一個整數。例如當執行incr后返回自增后的值,執行llen返回數組的長度,或者使用exists命令返回的0或1作為判斷一個key是否存在的依據,這些都使用了整數回復。

批量回復

批量回復,就是多行字符串的回復。它以$作為開頭,后面是發送的字節長度,然后是\r\n,然后發送實際的數據,最終以\r\n結束。如果要回復的數據不存在,那么回復長度為-1。

多條批量回復

當服務端要返回多個值時,例如返回一些元素的集合時,就會使用多條批量回復。它以*作為開頭,后面是返回元素的個數,之后再跟隨多個上面講到過的批量回復。

到這里,基本上我和小弟之間的通訊協議就介紹完了。剛才你嘗試了偽裝成一個服務端,這會再來試一試直接寫一個客戶端來直接和我進行交互吧。

  1. private static void client() throws IOException { 
  2.     String CRLF="\r\n"
  3.  
  4.     Socket socket=new Socket("localhost", 6379); 
  5.     try (OutputStream out = socket.getOutputStream()) { 
  6.         StringBuffer sb=new StringBuffer(); 
  7.         sb.append("*3").append(CRLF) 
  8.                 .append("$3").append(CRLF).append("set").append(CRLF) 
  9.                 .append("$4").append(CRLF).append("key1").append(CRLF) 
  10.                 .append("$6").append(CRLF).append("value1").append(CRLF); 
  11.         out.write(sb.toString().getBytes()); 
  12.         out.flush(); 
  13.  
  14.         try (InputStream inputStream = socket.getInputStream()) { 
  15.             byte[] buff = new byte[1024]; 
  16.             int len = inputStream.read(buff); 
  17.             if (len > 0) { 
  18.                 String ret = new String(buff, 0, len); 
  19.                 System.out.println("Recv:" + ret); 
  20.             } 
  21.         } 
  22.     } 

運行上面的代碼,控制臺輸出:

  1. Recv:+OK 

上面模仿了客戶端發出set命令的過程,并收到了回復。依此類推,你也可以自己封裝其他的命令,來實現一個自己的Redis客戶端,作為小弟,來和我進行通信。

不過記住,要叫我大哥。

 

責任編輯:姜華 來源: 碼農參上
相關推薦

2010-03-18 17:39:46

Java Socket

2009-08-21 16:14:52

服務端與客戶端通信

2009-08-21 15:59:22

服務端與客戶端通信

2010-01-05 14:32:01

JSON 數據

2010-06-01 14:35:16

SVN倉庫導出

2018-01-12 09:20:55

2010-12-17 10:16:33

OpenVAS

2010-05-31 10:11:32

瘦客戶端

2009-08-01 22:47:58

2014-12-08 14:54:56

hadoop框架線程網絡

2013-03-20 11:01:37

Redis客戶端連接

2020-09-14 11:27:32

工具代碼開發

2021-09-22 15:46:29

虛擬桌面瘦客戶端胖客戶端

2010-03-16 15:50:59

Java遠程控制

2010-03-18 17:47:07

Java 多客戶端通信

2013-03-13 10:51:44

瘦客戶端VDI

2010-12-31 14:23:57

Exchange Se

2010-05-23 23:36:38

思科統一通信

2021-08-01 23:18:21

Redis Golang命令

2012-04-23 09:51:09

點贊
收藏

51CTO技術棧公眾號

日韩欧美亚洲日产国| 中文字幕久精品免| 欧美家庭影院| 久久蜜桃一区二区| av资源一区二区| 麻豆一区在线| 欧美精品一区二区三区视频| 真不卡电影网| 久久精品亚洲精品国产欧美 | 久草一区二区| 亚洲宅男网av| 中文字幕综合在线| 中文字幕在线三区| 亚洲福利一二三区| 另类小说第一页| 国产在线看一区| 国产区二精品视| 欧美一区二区麻豆红桃视频| 欧美老女人xx| 免费福利视频一区二区三区| 欧美一级在线视频| 免费一级在线观看| 亚洲国产精品一区二区www在线| 免费在线观看的av网站| 国产麻豆精品在线观看| 日本一区二区三区免费看| 欧美激情综合| 亚洲va欧美va国产综合久久| 国产欧美日韩在线一区二区| 欧美第一页在线| 婷婷久久免费视频| 亚洲人成在线一二| 亚洲美女尤物影院| 亚洲黄色有码视频| 日本电影在线观看| 欧美成人伊人久久综合网| 免费黄色在线| 在线播放国产精品二区一二区四区 | a一区二区三区亚洲| 亚洲国产日韩欧美在线图片| 在线黄色网页| 日韩三级视频在线看| 午夜在线观看视频| 欧美精品高清视频| 国产福利在线播放麻豆| 欧美人伦禁忌dvd放荡欲情| a黄色在线观看| 51午夜精品国产| 免费不卡视频| 日韩精品免费综合视频在线播放| 免费电影日韩网站| 欧美精品免费在线观看| 色婷婷久久久| 成人国产精品一区| 欧美日本一区二区高清播放视频| 国产精品.com| 麻豆91在线播放| 国产一区二区网| 亚洲欧美在线另类| 中文在线а天堂av| 午夜国产不卡在线观看视频| 国产欧美一区二区三区国产幕精品| 国产综合久久久久久| 国产精品专区一| 成人国产一区| 色与欲影视天天看综合网| 国产精品免费精品自在线观看| 欧美亚洲日本网站| 中文精品电影| 女女同性女同一区二区三区91| 日本在线播放一区二区三区| 欧美一级片免费播放| 中文字幕中文在线不卡住| 午夜国产视频| 欧美老女人第四色| 国产激情欧美| 26uuu亚洲伊人春色| 欧美黄色免费| 亚洲国产一二三精品无码| 中文字幕中文乱码欧美一区二区| 国产区在线视频| 亚洲欧美一区二区三区在线| 第四色中文综合网| 久久大片网站| 国产亲近乱来精品视频| 国产日产精品久久久久久婷婷| 亚洲国产精品va在线观看黑人| 自拍偷拍亚洲| 99理论电影网| a在线欧美一区| 久久久资源网| 一本久久综合亚洲鲁鲁| 欧美一区二区三区激情视频| 无码人妻aⅴ一区二区三区日本| 国产精品久久午夜| 91se在线| 欧美黑人性视频| 国产亚洲亚洲| 999www成人| 亚洲国产日韩欧美在线图片| 美女久久久久| 综合网五月天| 天天av天天翘天天综合网色鬼国产 | 在线视频亚洲欧美| 成人久久综合| av久久久久久| 日韩欧美999| 亚洲精品在线国产| 性欧美精品一区二区三区在线播放| 亚洲欧美日韩国产一区二区三区| 午夜影院在线播放| 亚洲xxx视频| 欧美激情一区不卡| 免费v片在线观看| 丁香五月网久久综合| 国产精品久久久久一区二区三区| 成av人片在线观看www| 亚洲a∨日韩av高清在线观看| 2020日本不卡一区二区视频| 日本在线观看大片免费视频| 亚洲bt天天射| 中文字幕第一页久久| 中文在线а√天堂| 国产女人水真多18毛片18精品 | 国内精品伊人久久久久av一坑| www.1024| 极品中文字幕一区| 黄色特一级视频| 无需播放器亚洲| 丰满少妇被猛烈进入高清播放| 欧美日韩性生活| 亚洲bt欧美bt精品777| 久久亚洲精品无码va白人极品| 91久久香蕉国产日韩欧美9色| 国产主播性色av福利精品一区| 波多野结衣三级在线| 欧美日韩国产在线播放网站| 经典一区二区| 亚洲欧美在线精品| 尤物99国产成人精品视频| 国产精品美女| 美女毛片在线看| 国产精品影院在线观看| 亚洲视频网在线直播| 欧美视频日韩视频在线观看| 成人jjav| 激情四房婷婷| 欧美xxxx吸乳| av一区二区三区四区电影| 不卡视频免费播放| 亚洲激情二区| 禁久久精品乱码| 国产在线不卡一区二区三区| 夜色福利资源站www国产在线视频| 国产女主播在线| 国产区视频在线观看| xxxx视频在线| 日韩免费小视频| 95精品视频| 成人免费在线播放| 久久99最新地址| 偷窥自拍亚洲色图精选| 亚洲综合好骚| 国产欧美一区二区精品秋霞影院| 亚洲主播在线观看| 色婷婷综合久久久久| 成人a在线视频| 国产精品一区二区电影| 电影一区二区三| 欧美成人hd| 色与欲影视天天看综合网| 成人免费高清视频在线观看| 日韩不卡在线| 日韩一区免费观看| 国产91精品高潮白浆喷水| www国产精品视频| 欧美xxx久久| 亚洲成人av电影在线| 国产在线精品不卡| 影音先锋久久久| 婷婷亚洲成人| 成人午夜毛片| 日本在线人成| 一区二区三区 欧美| 91成人在线观看喷潮教学| 欧美重口乱码一区二区| 精品一区二区久久久久久久网站| 久久久精品国产网站| 色哟哟入口国产精品| 91麻豆精品国产91| 欧美日韩免费视频| 7777精品久久久大香线蕉| 久久久久久久久岛国免费| 中日韩视频在线观看| 欧美日韩视频| 蜜桃久久久久| 欧美理论视频| 天堂精品久久久久| 日韩精品一级| 中文有码一区|