日韩欧乱色一区二区三区在线_久久―日本道色综合久久_欧美日本一区二区_网曝91综合精品门事件在线

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 為什么不用redis做主數(shù)據(jù)庫(kù),只用它做緩存?

為什么不用redis做主數(shù)據(jù)庫(kù),只用它做緩存?

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-12 22:55:43 1697122543

一、為什么不用redis做主數(shù)據(jù)庫(kù),只用它做緩存

1.Redis的內(nèi)存架構(gòu)

Redis是內(nèi)存數(shù)據(jù)庫(kù),這意味著它將所有數(shù)據(jù)存儲(chǔ)在內(nèi)存中,而不是在硬盤上。這使得Redis的讀寫速度非常快,但也使得它非常適合存儲(chǔ)臨時(shí)數(shù)據(jù),而不是持久數(shù)據(jù)。如果我們將Redis用作主數(shù)據(jù)庫(kù),我們的數(shù)據(jù)將不能持久化,也就是說(shuō),如果服務(wù)器崩潰或斷電,我們將失去所有數(shù)據(jù)。這是因?yàn)镽edis的數(shù)據(jù)存儲(chǔ)在內(nèi)存中,一旦服務(wù)器重啟,內(nèi)存中的數(shù)據(jù)將被清空,所有的數(shù)據(jù)將丟失。

2.Redis的單線程架構(gòu)

Redis是單線程的,這意味著它一次只能處理一個(gè)請(qǐng)求。如果我們將Redis用作主數(shù)據(jù)庫(kù),當(dāng)并發(fā)請(qǐng)求增加時(shí),Redis將無(wú)法處理它們,從而導(dǎo)致性能問(wèn)題和響應(yīng)時(shí)間延遲。相比之下,像MySQL這樣的關(guān)系型數(shù)據(jù)庫(kù)可以處理多個(gè)請(qǐng)求。如果我們有大量的并發(fā)請(qǐng)求需要處理,Redis可能會(huì)成為性能瓶頸。

3.Redis不支持SQL查詢

Redis不支持SQL查詢,這意味著我們無(wú)法使用SQL語(yǔ)言來(lái)查詢數(shù)據(jù)。雖然Redis提供了一些基本的查詢功能,但它無(wú)法處理復(fù)雜的查詢請(qǐng)求。相比之下,像MySQL這樣的關(guān)系型數(shù)據(jù)庫(kù)提供了強(qiáng)大的SQL查詢功能。如果我們需要進(jìn)行復(fù)雜的查詢,Redis可能會(huì)無(wú)法勝任。

4.示例:Redis作為主數(shù)據(jù)庫(kù)可能會(huì)導(dǎo)致數(shù)據(jù)丟失

以下是一個(gè)簡(jiǎn)單的示例,主要說(shuō)明為什么使用Redis作為主數(shù)據(jù)庫(kù)可能會(huì)導(dǎo)致數(shù)據(jù)丟失。假設(shè)我們正在構(gòu)建一個(gè)在線商店,并使用Redis來(lái)存儲(chǔ)庫(kù)存量。我們將商品數(shù)量存儲(chǔ)在Redis中,并在每次銷售后減少庫(kù)存量。如果我們使用Redis作為主數(shù)據(jù)庫(kù),當(dāng)服務(wù)器崩潰時(shí),我們將失去所有庫(kù)存數(shù)據(jù)。如果我們使用MySQL等關(guān)系型數(shù)據(jù)庫(kù),我們可以將庫(kù)存數(shù)據(jù)持久化并在服務(wù)器崩潰后恢復(fù)它們。

import redis

r = redis.Redis(host=’localhost’, port=6379, db=0)

# 假設(shè)我們有100個(gè)商品

r.set(‘inventory’, 100)

# 當(dāng)有人購(gòu)買一個(gè)商品時(shí),我們減少庫(kù)存量

r.decr(‘inventory’)

# 當(dāng)服務(wù)器崩潰并重啟時(shí),我們將失去所有庫(kù)存數(shù)據(jù)

延伸閱讀:

二、主要的單機(jī)存儲(chǔ)引擎

1、哈希存儲(chǔ):hash的CRUD是非常快的。但缺點(diǎn)是不支持順序掃描。bitcask是一個(gè)基于hash表結(jié)構(gòu)的存儲(chǔ)系統(tǒng)。他將寫操作(包括刪除標(biāo)識(shí))追加到文件尾。并定期合并新老文件&記錄。

2、B樹:既支持隨機(jī)讀取又支持范圍查找的系統(tǒng)。查找時(shí)間復(fù)雜度為logd(n)(d為每個(gè)節(jié)點(diǎn)的出度)。Mysql的InnoDB的引擎和OS的文件系統(tǒng)使用的就是B+樹。(為什么選擇使用B樹的變種B+樹,讀者有興趣可以去探究下。提示:磁盤讀?。?/p>

3、LSM樹(Log Structured Merge Tree):由B+數(shù)改進(jìn)而來(lái)。其思想為:將增量寫操作保存在內(nèi)存中,超過(guò)閾值時(shí)刷入磁盤,從而減少隨機(jī)寫磁盤操作。讀操作則需要合并磁盤數(shù)據(jù)和內(nèi)存中的寫操作。通過(guò)Memtable/SSTable實(shí)現(xiàn),實(shí)現(xiàn)細(xì)節(jié)在此不做深入探究。比較適合寫操作較多的業(yè)務(wù)場(chǎng)景。BigTable/HBase/Cassandra中的列簇的數(shù)據(jù)存儲(chǔ)方式采用的即是LSM樹。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
Web前端用來(lái)做什么?

一、網(wǎng)頁(yè)開發(fā)Web前端在網(wǎng)頁(yè)開發(fā)中起到了至關(guān)重要的作用。它負(fù)責(zé)將網(wǎng)頁(yè)設(shè)計(jì)師設(shè)計(jì)的界面轉(zhuǎn)化為可交互的頁(yè)面。通過(guò)HTML、CSS和JavaScript等技術(shù),...詳情>>

2023-10-12 23:57:56
為什么要用flow?

一、用flow的原因Flow是一種靜態(tài)類型檢查工具,用于JavaScript代碼。它的主要目的是幫助開發(fā)者在編寫JavaScript代碼時(shí)發(fā)現(xiàn)和預(yù)防類型相關(guān)的錯(cuò)誤...詳情>>

2023-10-12 23:46:58
OceanBase、TiDB這類NewSQL的定位是什么?

一、OceanBase、TiDB這類NewSQL的定位oceanbase tidb spanner是share nothing的架構(gòu),單個(gè)分區(qū)有paxos保證可用性的前提下,還有近乎線性的擴(kuò)展...詳情>>

2023-10-12 23:36:12
linux有什么優(yōu)點(diǎn)?

1、開源Linux的主要優(yōu)點(diǎn)之一是它是一個(gè)開放源代碼的操作系統(tǒng),即每個(gè)人都可以輕松獲得其源代碼。任何有編程能力的人都可以出于任何目的貢獻(xiàn),修...詳情>>

2023-10-12 23:08:52
Python特點(diǎn)及應(yīng)用?

一、Python的特點(diǎn)Python是一種高級(jí)編程語(yǔ)言,由Guido van Rossum于上世紀(jì)90年代初開發(fā),它具有以下特點(diǎn):1、語(yǔ)法簡(jiǎn)潔易讀Python使用縮進(jìn)來(lái)表示...詳情>>

2023-10-12 23:00:52
快速通道
主站蜘蛛池模板: 汝城县| 重庆市| 罗甸县| 阿克陶县| 固始县| 营口市| 英德市| 梁平县| 广宗县| 沅江市| 新野县| 邵东县| 剑河县| 集安市| 宜良县| 龙里县| 达尔| 灵丘县| 安义县| 龙游县| 巧家县| 中阳县| 资中县| 怀仁县| 张家川| 和平区| 井研县| 沭阳县| 自治县| 乌海市| 陆丰市| 宝山区| 如东县| 醴陵市| 高州市| 中山市| 喀喇| 墨玉县| 册亨县| 肇州县| 赫章县|