談一下我的理解,如果有不對的地方,請留言指正。
MySQL+RedisRedis自身是可以做數(shù)據(jù)持久化的,很多同學(xué)都會想Redis應(yīng)該可以替代MySQL,但是我們使用一項(xiàng)技術(shù)、一個(gè)框架的時(shí)候,不是看它能不能,而是要看它適合不適合。
所以大多數(shù)公司的存儲都是MySQL+Redis,MySQL(或者其他關(guān)系型數(shù)據(jù)庫)作為主存儲,Redis作為輔助存儲,被用作緩存,這樣可以加快訪問讀取的速度,提高性能。
Redis被用作緩存,以減少數(shù)據(jù)庫IO的讀操作,減輕數(shù)據(jù)庫的壓力,例如:
存儲熱點(diǎn)數(shù)據(jù):經(jīng)常會被查詢,但是不經(jīng)常被修改或者刪除的數(shù)據(jù);
計(jì)數(shù)器:諸如很多論壇用于統(tǒng)計(jì)點(diǎn)擊數(shù);
分布式鎖及單線程機(jī)制;
最新列表、排行榜:請不要使用select top 10 from xxxx。
劃重點(diǎn),下面介紹一下緩存穿透很多時(shí)候,程序員習(xí)慣先查詢Redis,查詢不到的話再去查詢數(shù)據(jù)庫,能查到的話再寫入Redis中,認(rèn)為這樣不僅緩解了數(shù)據(jù)庫的壓力,同時(shí)也能保證數(shù)據(jù)的準(zhǔn)確性。
但是由于緩存不命中就會查詢數(shù)據(jù)庫,如果一直查詢不到的話,就導(dǎo)致每次請求都會查詢數(shù)據(jù)庫,如果短時(shí)間內(nèi)有大量這樣的請求,那么數(shù)據(jù)庫可能會扛不住。
這就是緩存穿透。
其實(shí)應(yīng)對的方法也很簡單,查詢不到的數(shù)據(jù),也緩存到Redis中,并設(shè)置數(shù)據(jù)的過期時(shí)間。
舉個(gè)不一定恰當(dāng)?shù)睦樱鏡edis中緩存員工信息,提供接口根據(jù)工號查詢員工信息:
接口入?yún)⒐ぬ朅001。
系統(tǒng)先在Redis中查詢,查詢不到。
系統(tǒng)去數(shù)據(jù)庫中查詢,也查詢不到。
系統(tǒng)插入Redis,key=A001,value=null,設(shè)置過期時(shí)間五分鐘。
這樣,五分鐘之內(nèi)再根據(jù)A001查詢,不會穿透到數(shù)據(jù)庫。
四分鐘后,數(shù)據(jù)庫中插入了A001的數(shù)據(jù)。
五分鐘后,Redis中數(shù)據(jù)過期,下一次請求過來,會查詢數(shù)據(jù)庫,并把信息加載到Redis中。
希望我的回答,能夠幫助到你!
我會持續(xù)分享Java程序開發(fā)、架構(gòu)設(shè)計(jì)、職業(yè)發(fā)展等方面的知識和見解,希望能得到你的關(guān)注今日頭條【會點(diǎn)代碼的大叔】,轉(zhuǎn)載請注明出處。