在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Redis的各項功能解決了哪些問題

電子工程師 ? 來源:fqj ? 2019-05-22 16:45 ? 次閱讀

先看一下Redis是一個什么東西。官方簡介解釋到:Redis是一個基于BSD開源的項目,是一個把結(jié)構(gòu)化的數(shù)據(jù)放在內(nèi)存中的一個存儲系統(tǒng),你可以把它作為數(shù)據(jù)庫,緩存和消息中間件來使用。同時支持strings,lists,hashes,sets,sorted sets,bitmaps,hyperloglogs和geospatial indexes等數(shù)據(jù)類型。它還內(nèi)建了復(fù)制,lua腳本,LRU,事務(wù)等功能,通過redis sentinel實現(xiàn)高可用,通過redis cluster實現(xiàn)了自動分片。以及事務(wù),發(fā)布/訂閱,自動故障轉(zhuǎn)移等等。

綜上所述,Redis提供了豐富的功能,初次見到可能會感覺眼花繚亂,這些功能都是干嘛用的?都解決了什么問題?什么情況下才會用到相應(yīng)的功能?那么下面從零開始,一步一步的演進來粗略的解釋下。

1 從零開始

最初的需求非常簡單,我們有一個提供熱點新聞列表的api,api的消費者抱怨說每次請求都要2秒左右才能返回結(jié)果。

隨后我們就著手于如何提升一下api消費者感知的性能,很快最簡單粗暴的第一個方案就出來了:為API的響應(yīng)加上基于HTTP的緩存控制cache-control:max-age=600,即讓消費者可以緩存這個響應(yīng)十分鐘。如果api消費者如果有效的利用了響應(yīng)中的緩存控制信息,則可以有效的改善其感知的性能(10分鐘以內(nèi))。但是還有2個弊端:第一個是在緩存生效的10分鐘內(nèi),api消費者可能會得到舊的數(shù)據(jù);第二個是如果api的客戶端無視緩存直接訪問API依然是需要2秒,治標(biāo)不治本吶。

2 基于本機內(nèi)存的緩存

為了解決調(diào)用API依然需要2秒的問題,經(jīng)過排查,其主要原因在于使用SQL獲取熱點新聞的過程中消耗了將近2秒的時間,于是乎,我們又想到了一個簡單粗暴的解決方案,即把SQL查詢的結(jié)果直接緩存在當(dāng)前api服務(wù)器的內(nèi)存中(設(shè)置緩存有效時間為1分鐘)。后續(xù)1分鐘內(nèi)的請求直接讀緩存,不再花費2秒去執(zhí)行SQL了。假如這個api每秒接收到的請求時100個,那么一分鐘就是6000個,也就是只有前2秒擁擠過來的請求會耗時2秒,后續(xù)的58秒中的所有請求都可以做到即使響應(yīng),而無需再等2秒的時間。

其他API的小伙伴發(fā)現(xiàn)這是個好辦法,于是很快我們就發(fā)現(xiàn)API服務(wù)器的內(nèi)存要爆滿了。。。

3 服務(wù)端的Redis

在API服務(wù)器的內(nèi)存都被緩存塞滿的時候,我們發(fā)現(xiàn)不得不另想解決方案了。最直接的想法就是我們把這些緩存都丟到一個專門的服務(wù)器上吧,把它的內(nèi)存配置的大大的。然后我們就盯上了redis。。。至于如何配置部署redis這里不解釋了,redis官方有詳細的介紹。隨后我們就用上了一臺單獨的服務(wù)器作為Redis的服務(wù)器,API服務(wù)器的內(nèi)存壓力得以解決。

3.1 持久化(Persistence)

單臺的Redis服務(wù)器一個月總有那么幾天心情不好,心情不好就罷工了,導(dǎo)致所有的緩存都丟失了(redis的數(shù)據(jù)是存儲在內(nèi)存的嘛)。雖然可以把Redis服務(wù)器重新上線,但是由于內(nèi)存的數(shù)據(jù)丟失,造成了緩存雪崩,API服務(wù)器和數(shù)據(jù)庫的壓力還是一下子就上來了。所以這個時候Redis的持久化功能就派上用場了,可以緩解一下緩存雪崩帶來的影響。redis的持久化指的是redis會把內(nèi)存的中的數(shù)據(jù)寫入到硬盤中,在redis重新啟動的時候加載這些數(shù)據(jù),從而最大限度的降低緩存丟失帶來的影響。

3.2 哨兵(Sentinel)和復(fù)制(Replication)

Redis服務(wù)器毫無征兆的罷工是個麻煩事。那么怎辦辦?答曰:備份一臺,你掛了它上。那么如何得知某一臺redis服務(wù)器掛了,如何切換,如何保證備份的機器是原始服務(wù)器的完整備份呢?這時候就需要Sentinel和Replication出場了。Sentinel可以管理多個Redis服務(wù)器,它提供了監(jiān)控,提醒以及自動的故障轉(zhuǎn)移的功能;Replication則是負責(zé)讓一個Redis服務(wù)器可以配備多個備份的服務(wù)器。Redis也是利用這兩個功能來保證Redis的高可用的。此外,Sentinel功能則是對Redis的發(fā)布和訂閱功能的一個利用。

3.3 集群(Cluster)

單臺服務(wù)器資源的總是有上限的,CPU資源和IO資源我們可以通過主從復(fù)制,進行讀寫分離,把一部分CPU和IO的壓力轉(zhuǎn)移到從服務(wù)器上。但是內(nèi)存資源怎么辦,主從模式做到的只是相同數(shù)據(jù)的備份,并不能橫向擴充內(nèi)存;單臺機器的內(nèi)存也只能進行加大處理,但是總有上限的。所以我們就需要一種解決方案,可以讓我們橫向擴展。最終的目的既是把每臺服務(wù)器只負責(zé)其中的一部分,讓這些所有的服務(wù)器構(gòu)成一個整體,對外界的消費者而言,這一組分布式的服務(wù)器就像是一個集中式的服務(wù)器一樣(之前在解讀REST的博客中解釋過分布式于基于網(wǎng)絡(luò)的差異:基于網(wǎng)絡(luò)應(yīng)用的架構(gòu))。

在Redis官方的分布式方案出來之前,有twemproxy和codis兩種方案,這兩個方案總體上來說都是依賴proxy來進行分布式的,也就是說redis本身并不關(guān)心分布式的事情,而是交由twemproxy和codis來負責(zé)。而redis官方給出的cluster方案則是把分布式的這部分事情做到了每一個redis服務(wù)器中,使其不再需要其他的組件就可以獨立的完成分布式的要求。我們這里不關(guān)心這些方案的優(yōu)略,我們關(guān)注一下這里的分布式到底是要處理那些事情?也就是twemproxy和codis獨立處理的處理分布式的這部分邏輯和cluster集成到redis服務(wù)的這部分邏輯到底在解決什么問題?

如我們前面所說的,一個分布式的服務(wù)在外界看來就像是一個集中式的服務(wù)一樣。那么要做到這一點就面臨著有一個問題需要解決:既是增加或減少分布式服務(wù)中的服務(wù)器的數(shù)量,對消費這個服務(wù)的客戶端而言應(yīng)該是無感的;那么也就意味著客戶端不能穿透分布式服務(wù),把自己綁死到某一個臺的服務(wù)器上去,因為一旦如此,你就再也無法新增服務(wù)器,也無法進行故障替換。
解決這個問題有兩個路子:
第一個路子最直接,那就是我加一個中間層來隔離這種具體的依賴,即twemproxy采用的方式,讓所有的客戶端只能通過它來消費redsi服務(wù),通過它來隔離這種依賴(但是你會發(fā)現(xiàn)twermproxy會成為一個單點),這種情況下每臺redis服務(wù)器都是獨立的,它們之間彼此不知對方的存在
第二個路子是讓redis服務(wù)器知道彼此的存在,通過重定向的機制來引導(dǎo)客戶端來完成自己所需要的操作
比如客戶端鏈接到了某一個redis服務(wù)器,說我要執(zhí)行這個操作,redis服務(wù)器發(fā)現(xiàn)自己無法完成這個操作,那么就把能完成這個操作的服務(wù)器的信息給到客戶端,讓客戶端去請求另外的一個服務(wù)器,這時候你就會發(fā)現(xiàn)每一個redis服務(wù)器都需要保持一份完整的分布式服務(wù)器信息的一份資料,不然它怎么知道讓客戶端去找其他的哪個服務(wù)器來執(zhí)行客戶端想要的操作呢。

上面這一大段解釋了這么多,不知有沒有發(fā)現(xiàn)不管是第一個路子還是第二個路子,都有一個共同的東西存在,那就是分布式服務(wù)中所有服務(wù)器以及其能提供的服務(wù)的信息。這些信息無論如何也是要存在的,區(qū)別在于第一個路子是把這部分信息單獨來管理,用這些信息來協(xié)調(diào)后端的多個獨立的redis服務(wù)器;第二個路子則是讓每一個redis服務(wù)器都持有這份信息,彼此知道對方的存在,來達成和第一個路子一樣的目的,優(yōu)點是不再需要一個額外的組件來處理這部分事情。

Redis Cluster的具體實現(xiàn)細節(jié)則是采用了Hash槽的概念,即預(yù)先分配出來16384個槽:在客戶端通過對Key進行CRC16(key)% 16384運算得到對應(yīng)的槽是哪一個;在redis服務(wù)端則是每個服務(wù)器負責(zé)一部分槽,當(dāng)有新的服務(wù)器加入或者移除的時候,再來遷移這些槽以及其對應(yīng)的數(shù)據(jù),同時每個服務(wù)器都持有完整的槽和其對應(yīng)的服務(wù)器的信息,這就使得服務(wù)器端可以進行對客戶端的請求進行重定向處理。

4 客戶端的Redis

上面的第三小節(jié)主要介紹的是Redis服務(wù)端的演進步驟,解釋了Redis如何從一個單機的服務(wù),進化為一個高可用的、去中心化的、分布式的存儲系統(tǒng)。這一小節(jié)則是關(guān)注下客戶端可以消費的redis服務(wù)。

4.1 數(shù)據(jù)類型

redis支持豐富的數(shù)據(jù)類型,從最基礎(chǔ)的string到復(fù)雜的常用到的數(shù)據(jù)結(jié)構(gòu)都有支持:

string:最基本的數(shù)據(jù)類型,二進制安全的字符串,最大512M。

list:按照添加順序保持順序的字符串列表。

set:無序的字符串集合,不存在重復(fù)的元素。

sorted set:已排序的字符串集合。

hash:key-value對的一種集合。

bitmap:更細化的一種操作,以bit為單位。

hyperloglog:基于概率的數(shù)據(jù)結(jié)構(gòu)。

這些眾多的數(shù)據(jù)類型,主要是為了支持各種場景的需要,當(dāng)然每種類型都有不同的時間復(fù)雜度。其實這些復(fù)雜的數(shù)據(jù)結(jié)構(gòu)相當(dāng)于之前我在《解讀REST》這個系列博客基于網(wǎng)絡(luò)應(yīng)用的架構(gòu)風(fēng)格中介紹到的遠程數(shù)據(jù)訪問(Remote Data Access = RDA)的具體實現(xiàn),即通過在服務(wù)器上執(zhí)行一組標(biāo)準(zhǔn)的操作命令,在服務(wù)端之間得到想要的縮小后的結(jié)果集,從而簡化客戶端的使用,也可以提高網(wǎng)絡(luò)性能。
比如如果沒有l(wèi)ist這種數(shù)據(jù)結(jié)構(gòu),你就只能把list存成一個string,客戶端拿到完整的list,操作后再完整的提交給redis,會產(chǎn)生很大的浪費。

4.2 事務(wù)

上述數(shù)據(jù)類型中,每一個數(shù)據(jù)類型都有獨立的命令來進行操作,很多情況下我們需要一次執(zhí)行不止一個命令,而且需要其同時成功或者失敗。redis對事務(wù)的支持也是源自于這部分需求,即支持一次性按順序執(zhí)行多個命令的能力,并保證其原子性。

4.3 Lua腳本

在事務(wù)的基礎(chǔ)上,如果我們需要在服務(wù)端一次性的執(zhí)行更復(fù)雜的操作(包含一些邏輯判斷),則lua就可以排上用場了(比如在獲取某一個緩存的時候,同時延長其過期時間)。redis保證lua腳本的原子性,一定的場景下,是可以代替redis提供的事務(wù)相關(guān)的命令的。相當(dāng)于基于網(wǎng)絡(luò)應(yīng)用的架構(gòu)風(fēng)格中介紹到的遠程求值(Remote Evluation = REV)的具體實現(xiàn)。

4.4 管道

因為redis的客戶端和服務(wù)器的連接時基于TCP的, 默認每次連接都時只能執(zhí)行一個命令。管道則是允許利用一次連接來處理多條命令,從而可以節(jié)省一些tcp連接的開銷。管道和事務(wù)的差異在于管道是為了節(jié)省通信的開銷,但是并不會保證原子性。

4.5 分布式鎖

官方推薦采用Redlock算法,即使用string類型,加鎖的時候給的一個具體的key,然后設(shè)置一個隨機的值;取消鎖的時候用使用lua腳本來先執(zhí)行獲取比較,然后再刪除key。具體的命令如下:

SET resource_name my_random_value NX PX 30000if redis.call("get",KEYS[1]) == ARGV[1] then return redis.call("del",KEYS[1])else return 0end

總結(jié)

本篇著重從抽象層面來解釋下redis的各項功能以及其存在的目的,而沒有關(guān)心其具體的細節(jié)是什么。從而可以聚焦于其解決的問題,依據(jù)抽象層面的概念可以使得我們在特定的場景下選擇更合適的方案,而非局限于其技術(shù)細節(jié)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • BSD
    BSD
    +關(guān)注

    關(guān)注

    0

    文章

    31

    瀏覽量

    10519
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    381

    瀏覽量

    11205

原文標(biāo)題:Redis 的各項功能解決了哪些問題?

文章出處:【微信號:DBDevs,微信公眾號:數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    redis三種集群方案詳解

    Redis中提供的集群方案總共有三種(一般一個redis節(jié)點不超過10G內(nèi)存)。
    的頭像 發(fā)表于 03-31 10:46 ?310次閱讀
    <b class='flag-5'>redis</b>三種集群方案詳解

    Redis實戰(zhàn)筆記

    在目前的技術(shù)選型中,Redis 儼然已經(jīng)成為了系統(tǒng)高性能緩存方案的事實標(biāo)準(zhǔn),因此現(xiàn)在?Redis 也成為了后端開發(fā)的基本技能樹之一。 ? 基于上述情況,今天給大家分享一份?杰哥?親筆撰寫的內(nèi)部
    的頭像 發(fā)表于 02-09 09:12 ?246次閱讀
    <b class='flag-5'>Redis</b>實戰(zhàn)筆記

    華為云 Flexus X 加速 Redis 案例實踐與詳解

    Redis 加速鏡像,更是為開發(fā)者提供極大的便利。本文將詳細介紹如何利用華為云 Flexus X 實例自帶的 Redis 鏡像,快速部署并配置 Redis,以及通過實際案例展示其
    的頭像 發(fā)表于 01-23 17:52 ?216次閱讀
    華為云 Flexus X 加速 <b class='flag-5'>Redis</b> 案例實踐與詳解

    Redis Cluster之故障轉(zhuǎn)移

    1. Redis Cluster 簡介 Redis Cluster 是 Redis 官方提供的 Redis 集群功能。 為什么要實現(xiàn)
    的頭像 發(fā)表于 01-20 09:21 ?618次閱讀
    <b class='flag-5'>Redis</b> Cluster之故障轉(zhuǎn)移

    云服務(wù)器 Flexus X 實例,Docker 集成搭建 Redis 集群

    Redis 集群是一種分布式的 Redis 解決方案,能夠在多個節(jié)點之間分片存儲數(shù)據(jù),實現(xiàn)水平擴展和高可用性。與傳統(tǒng)的主從架構(gòu)不同,Redis 集群支持數(shù)據(jù)自動分片、主節(jié)點故障自動切換,并可以在多臺
    的頭像 發(fā)表于 01-13 13:37 ?250次閱讀
    云服務(wù)器 Flexus X 實例,Docker 集成搭建 <b class='flag-5'>Redis</b> 集群

    華為云Flexus X實例,Redis性能加速評測及對比

    隨著云計算技術(shù)的飛速發(fā)展,Redis 作為一種高性能的內(nèi)存數(shù)據(jù)庫,在各種應(yīng)用場景中發(fā)揮著越來越重要的作用。為了滿足不同用戶對 Redis 性能的高要求,華為云推出了 Flexus X 實例,并提供
    的頭像 發(fā)表于 12-29 15:47 ?362次閱讀
    華為云Flexus X實例,<b class='flag-5'>Redis</b>性能加速評測及對比

    華為云 Flexus X 輕松實現(xiàn) Redis 一主多從高效部署

    前言 ????????華為云 Flexus?X 是一款專為高性能計算設(shè)計的云服務(wù)器實例,其搭載的 X-Turbo 加速技術(shù)和智能應(yīng)用調(diào)優(yōu)算法,能夠大幅提升 Redis 的處理能力和響應(yīng)速度。此外
    的頭像 發(fā)表于 12-27 13:45 ?389次閱讀
    華為云 Flexus X 輕松實現(xiàn) <b class='flag-5'>Redis</b> 一主多從高效部署

    Redis使用重要的兩個機制:Reids持久化和主從復(fù)制

    今天這篇文章,我們一起了解 Redis 使用中非常重要的兩個機制:Reids 持久化和主從復(fù)制。 我們都知道Redis是一個內(nèi)存數(shù)據(jù)庫,在學(xué)習(xí)主從同步之前,我們首先要想到 Redis 是如何做數(shù)據(jù)
    的頭像 發(fā)表于 12-18 10:33 ?287次閱讀
    <b class='flag-5'>Redis</b>使用重要的兩個機制:Reids持久化和主從復(fù)制

    Redis緩存與Memcached的比較

    Redis和Memcached都是廣泛使用的內(nèi)存數(shù)據(jù)存儲系統(tǒng),它們主要用于提高應(yīng)用程序的性能,通過減少對數(shù)據(jù)庫的直接訪問來加速數(shù)據(jù)檢索。以下是對Redis和Memcached的比較,涵蓋了它們的一些
    的頭像 發(fā)表于 12-18 09:33 ?423次閱讀

    opa830的各項參數(shù)是什么啊?

    opa830的各項參數(shù)是什么啊
    發(fā)表于 09-25 07:50

    MCU的主要模塊及其功能解

    MCU的主要模塊及其功能解析: 微控制器:微控制器的主要任務(wù)是控制電壓源逆變器(VSI),將來自電池的電能轉(zhuǎn)換為所需的形式。它接收駕駛員的油門指令作為主要輸入,并通過調(diào)整脈寬調(diào)制(PWM)信號
    的頭像 發(fā)表于 08-12 18:12 ?1122次閱讀

    工業(yè)通信網(wǎng)關(guān)的各項功能解

    在工業(yè)自動化和智能制造的浪潮中,工業(yè)通信網(wǎng)關(guān)作為連接工業(yè)現(xiàn)場與互聯(lián)網(wǎng)的重要橋梁,發(fā)揮著至關(guān)重要的作用。它不僅實現(xiàn)不同網(wǎng)絡(luò)協(xié)議之間的轉(zhuǎn)換,還在數(shù)據(jù)采集、設(shè)備控制、網(wǎng)絡(luò)管理等方面展現(xiàn)出強大的功能。本文
    的頭像 發(fā)表于 07-15 16:27 ?514次閱讀
    工業(yè)通信網(wǎng)關(guān)的<b class='flag-5'>各項</b><b class='flag-5'>功能解</b>析

    K8S學(xué)習(xí)教程(二):在 PetaExpress KubeSphere容器平臺部署高可用 Redis 集群

    前言 Redis 是在開發(fā)過程中經(jīng)常用到的緩存中間件,為了考慮在生產(chǎn)環(huán)境中穩(wěn)定性和高可用,Redis通常采用集群模式的部署方式。 在制定Redis集群的部署策略時,常規(guī)部署在虛擬機上的方式配置繁瑣
    的頭像 發(fā)表于 07-03 15:30 ?1014次閱讀
    K8S學(xué)習(xí)教程(二):在 PetaExpress KubeSphere容器平臺部署高可用 <b class='flag-5'>Redis</b> 集群

    Redis 開源協(xié)議調(diào)整,我們怎么辦?

    2 024 年 3 月 20 日, Redis 官方宣布,從 Redis 7.4 版本開始,Redis 將獲得源可用許可證 ( RSALv2 ) 和服務(wù)器端公共許可證 ( SSPLv1 ) 的雙重
    的頭像 發(fā)表于 05-09 22:59 ?557次閱讀
    <b class='flag-5'>Redis</b> 開源協(xié)議調(diào)整,我們怎么辦?

    Redis 開源社區(qū)持續(xù)壯大,華為云為 Valkey 項目注入新的活力

    華為云云原生中間件產(chǎn)品團隊在過去的幾年里,通過向 Redis 開源社區(qū)提交代碼優(yōu)化、性能改進和安全性增強的建議,以及積極參與社區(qū)討論和貢獻文檔,為 Redis 的發(fā)展做出了積極的貢獻。作為
    的頭像 發(fā)表于 05-09 22:59 ?910次閱讀
    <b class='flag-5'>Redis</b> 開源社區(qū)持續(xù)壯大,華為云為 Valkey 項目注入新的活力
    主站蜘蛛池模板: 国产丝袜va丝袜老师 | 亚洲ay | 傲视影院午夜毛片 | 午夜嘿嘿 | 亚洲欧美成人网 | 色婷婷在线观看视频 | 日韩1| 欧美成人猛男性色生活 | 中文三级视频 | 资源新版在线天堂 | 日韩免费一级毛片 | 91精品久久久久含羞草 | www.欧美色图 | 美女张开腿露出尿口让男人桶 | 欧美一级欧美一级高清 | 扛着高跟鞋丝袜腿呻吟视频 | 欧美 亚洲 国产 丝袜 在线 | 国产亚洲自在精品久久 | 午夜亚洲国产精品福利 | 啪啪免费看视频 | 51视频在线观看免费国产 | 亚洲人成网站在线观看妞妞网 | 色综合天天综合网国产成人 | 天堂网最新版www | xxxx69日本hd| 欧美一区二区三区精品 | 狠狠色婷婷丁香综合久久韩国 | 曰本a | 国产精品一区二区三 | 国产乱码一区二区三区四川人 | 精品国模 | 曰本女人一级毛片看一级毛 | 色天天综合色天天碰 | 国产亚洲婷婷香蕉久久精品 | 天天噜天天干 | 手机在线完整视频免费观看 | 亚洲一二三区视频 | 日本免费不卡视频一区二区三区 | 国产区一区二区三 | 四只虎免费永久观看 | 天堂中文字幕在线观看 |