91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis如何使用pipeline

發布時間:2022-03-08 09:40:56 來源:億速云 閱讀:355 作者:小新 欄目:開發技術

這篇文章主要介紹Redis如何使用pipeline,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

使用 pipeline

Redis 是基于請求-響應模型的 TCP 服務器。意味著單次請求 RTT(往返時間),取決于當前網絡狀況 。這會導致單個 Redis 請求可能非常快,比如通過本地環路網卡。可能非常慢,比如處于網絡狀況不佳的環境。

另一方面,Redis 每次請求-響應,都涉及到 read 和 write 系統調用。甚至會觸發多次 epoll_wait 系統調用(Linux 平臺)。這導致 Redis 不斷在用戶態和內核態進行切換。

static int connSocketRead(connection *conn, void *buf, size_t buf_len) {
    // read 系統調用
    int ret = read(conn->fd, buf, buf_len);}static int connSocketWrite(connection *conn, const void *data, size_t data_len) {
    // write 系統調用
    int ret = write(conn->fd, data, data_len);}int aeProcessEvents(aeEventLoop *eventLoop, int flags) {
    // 事件觸發,Linux 下為 epoll_wait 系統調用
    numevents = aeApiPoll(eventLoop, tvp);}

那么,如何節省往返時間和系統調用次數呢?批處理是一個好的辦法。

為此,Redis 提供了 「pipeline」。pipeline 的原理很簡單,將多個命令打包成「一個命令」發送。Redis 收到后,解析成多個命令執行。最終將多個結果打包返回。

「pipeline 可以有效的提升 Redis 性能」

但是,使用 pipeline 有幾點需要你留意

  1. 「pipeline 不能保證原子性」。在一次 pipeline 命令執行期間,可能會執行其它 client 發起的命令。請記住,pipeline 只是批量處理命令。想要保證原子性,使用 MULTI 或者 Lua 腳本。

  2. 「單次 pipeline 命令不宜過多」。當使用 pipeline 時,Redis 會將 pipeline 命令的響應結果,暫存在內存 Reply buffer 中,等待所有命令執行完畢后返回。如果 pipeline 命令過多,可能會導致占用較多內存。可以將單個 pipeline 拆分成多個 pipeline。

以上是“Redis如何使用pipeline”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兰溪市| 曲阳县| 新乐市| 南康市| 云龙县| 金川县| 余庆县| 盐源县| 白玉县| 三门峡市| 新巴尔虎左旗| 安达市| 高邑县| 竹山县| 嘉义市| 郎溪县| 新兴县| 武清区| 通山县| 论坛| 温州市| 施甸县| 微博| 尚义县| 马公市| 武强县| 南汇区| 无为县| 西乌珠穆沁旗| 根河市| 巴彦淖尔市| 蓬溪县| 麻栗坡县| 葵青区| 东兴市| 将乐县| 衢州市| 鄯善县| 江达县| 五河县| 防城港市|