欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

node上的redis調(diào)用優(yōu)化示例詳解

 更新時間:2018年10月30日 14:34:09   作者:zjutkz  
這篇文章主要給大家介紹了關(guān)于node上redis調(diào)用優(yōu)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

如果一個 Node 應(yīng)用有多臺服務(wù)器或多個進(jìn)程在跑,每個進(jìn)程都擁有自己的內(nèi)存空間,各個進(jìn)程之間的數(shù)據(jù)共享就顯得非常重要。

使用數(shù)據(jù)庫是一個解決數(shù)據(jù)共享的方案,但一些臨時性、高并發(fā)的數(shù)據(jù)并不太適合直接寫入數(shù)據(jù)庫,比如 session。

引入 Redis 可以解決數(shù)據(jù)共享的問題,也因為 Redis 是基于內(nèi)存存儲的特點,有著非常高的性能,可以大大降低數(shù)據(jù)庫讀寫的壓力,提升應(yīng)用的整體性能。

Redis 還可以用來:緩存復(fù)雜的數(shù)據(jù)庫查詢結(jié)果,做自增長統(tǒng)計,暫存用戶操作狀態(tài)等功能。

最近負(fù)責(zé)的node項目在高并發(fā)的情況下性能表現(xiàn)非常的差,rt基本會在7 80ms甚至100ms以上,由于對外提供了dubbo接口,所以經(jīng)常導(dǎo)致上游應(yīng)用和自己的dubbo線程池耗盡,所以花了一點時間排查了一番,才發(fā)現(xiàn)原來自己的node功力還有很長的路要走啊~之后node的文章可能會越來越多~

最蠢的方式

先來看看我最早是怎么用的呢:

for(let i = 0; i < params.length; i++) {
 redisKey = getKey(params.id);
 let value = await redis.exec('get', redisKey);
}

這就是我最原始的調(diào)用方法,就是在for循環(huán)里不斷的去await結(jié)果的請求,這樣的結(jié)果就是每一個請求都需要等待上一個請求完成再去執(zhí)行,只要在高流量的時候有一部分請求rt很高,就會引起雪崩的反應(yīng)。

使用Promise.all優(yōu)化請求

經(jīng)過了一陣谷歌之后,我發(fā)現(xiàn)可以通過Promise.all的形式來進(jìn)行請求鏈路的優(yōu)化:

for(let i = 0; i < params.length; i++) {
redisKey = getKey(params.id);
 arr.push(redis.exec('get', redisKey))
}
await Promise.all(arr);

上面的第一種方式被我司的node大神嚴(yán)重吐槽了10分鐘,然后告訴我,使用Promise.all的方式可以很有效的優(yōu)化這種連續(xù)的網(wǎng)絡(luò)請求,我趕緊將代碼改完并上線。

自信滿滿的上線之后,迎來的確實現(xiàn)實無情的打擊,在高流量的時刻,報警依然不斷,我一邊和領(lǐng)導(dǎo)說“沒事,我再看看”,心里一邊想著辭職報告該怎么寫。

redis的正確使用姿勢

在繼續(xù)經(jīng)過了一系列的谷歌之后,我才發(fā)現(xiàn)原來的是對redis的理解太淺了,針對于業(yè)務(wù)上的需求,我不假思索的只知道使用最簡單的set和get,而redis對于set和get這樣的命令是一條命令一個tcp請求,在業(yè)務(wù)場景上確實不太合理,于是我使用谷歌告訴我的pipeline機制去改造現(xiàn)有的get請求:

let batch = await RedisClient.getClient().batch();
for(let i = 0; i < params.length; i++) {
 batch.get(redisKey);
}
batch.exec();

對于pipeline機制大家可以看這篇文章。在使用pipeline之后,便秘一下就通暢了,再也沒有報警過,終于可以不用辭職了。

再后面的日子里,我覺得認(rèn)真的研究一下redis這個東西,保證讓上面的問題不再發(fā)生,于是我發(fā)現(xiàn)其實還是有一種更加簡單的方案的,那就是使用mget:

for(let i = 0; i < params.length; i++) {
 redisKey = getKey(params.id);
 arr.push(redisKey);
}
let value = await redis.exec('mget', arr);

使用mget進(jìn)行批量的查詢,這是redis里比較常見的一種方式了~

總結(jié)一下

在對以上四種方式進(jìn)行了對比之后得出了數(shù)據(jù)上的結(jié)論:

在一個200次的循環(huán)中調(diào)用redis請求,第一種最蠢的方案大概是8000ms左右,第二種Promise.all的方案大概在2000ms左右,而第三和第四種方案,大概只需要幾十ms就能完成,這真的是質(zhì)的飛躍啊。

這個線上血淋淋的案例讓我決定真的要好好的研究一下redis,不能再輕視它導(dǎo)致犯錯。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Node.js+pm2+ssh2模塊實現(xiàn)簡單的自動化部署腳本

    Node.js+pm2+ssh2模塊實現(xiàn)簡單的自動化部署腳本

    本文將介紹如何使用Node.js和ssh2模塊實現(xiàn)一個簡單的部署腳本,將本地的項目文件上傳到遠(yuǎn)程服務(wù)器上,我們將使用dotenv模塊來管理環(huán)境變量,以及child_process模塊來執(zhí)行命令行操作
    2023-10-10
  • express 項目分層實踐詳解

    express 項目分層實踐詳解

    這篇文章主要介紹了express 項目分層實踐詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Node.js處理HTTP請求的示例代碼

    Node.js處理HTTP請求的示例代碼

    Node.js是一個基于Chrome V8引擎的JavaScript運行環(huán)境,它使得JavaScript可以脫離瀏覽器在服務(wù)器端運行,Node.js的非阻塞I/O模型和事件驅(qū)動特性使其在處理HTTP請求時表現(xiàn)出色,本文將探討Node.js如何處理HTTP請求,并提供示例代碼,需要的朋友可以參考下
    2024-09-09
  • Node.js websocket使用socket.io庫實現(xiàn)實時聊天室

    Node.js websocket使用socket.io庫實現(xiàn)實時聊天室

    這篇文章主要為大家詳細(xì)介紹了Node.js websocket使用socket.io庫實現(xiàn)實時聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Node.js多文件Stream合并,串行和并發(fā)兩種模式的實現(xiàn)方式

    Node.js多文件Stream合并,串行和并發(fā)兩種模式的實現(xiàn)方式

    這篇文章主要介紹了Node.js多文件Stream合并,串行和并發(fā)兩種模式的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • NVM管理Node.js實現(xiàn)不同版本Angular環(huán)境切換

    NVM管理Node.js實現(xiàn)不同版本Angular環(huán)境切換

    Node Version Manager(NVM)是一個用于管理多個Node.js版本的工具,它允許用戶在同一臺機器上安裝和使用多個Node.js版本,本文將給大家介紹NVM管理Node.js實現(xiàn)不同版本Angular環(huán)境切換的流程步驟,需要的朋友可以參考下
    2024-05-05
  • nodejs個人博客開發(fā)第五步 分配數(shù)據(jù)

    nodejs個人博客開發(fā)第五步 分配數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了nodejs個人博客開發(fā)的分配數(shù)據(jù),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 解決node-sass偶爾安裝失敗的方法小結(jié)

    解決node-sass偶爾安裝失敗的方法小結(jié)

    這篇文章主要介紹了解決node-sass偶爾安裝失敗的方法小結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Node中解決接口跨域問題詳解

    Node中解決接口跨域問題詳解

    在 Node 中編寫接口時,我們常常會遇到跨域問題,通過本篇文章,我們來聊聊如何解決 Node 中接口的跨域問題,文中代碼示例介紹了非常詳細(xì),需要的朋友可以借鑒一下
    2023-04-04
  • Node.js net模塊功能及事件監(jiān)聽用法分析

    Node.js net模塊功能及事件監(jiān)聽用法分析

    這篇文章主要介紹了Node.js net模塊功能及事件監(jiān)聽用法,結(jié)合實例形式分析了net模塊功能及事件監(jiān)聽相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01

最新評論