關(guān)于多級緩存使用(nginx本地緩存、JVM進(jìn)程緩存、redis緩存)
整體示意圖

1.nginx緩存

2.進(jìn)程緩存Caffeine示例


3.Lua語法(為了在nginx中做編程)






4.OpenResty

5.封裝向Tomcat發(fā)送的Http請求,獲取數(shù)據(jù)


封裝完函數(shù)之后,我們對nginx.conf進(jìn)行修改(請求進(jìn)來之后會(huì)去尋找item.lua)

item.lua文件內(nèi)容

上面的item.lua文件中需要進(jìn)行拼接數(shù)據(jù),我們需要JSON結(jié)果處理

6.Tomcat集群的負(fù)載均衡
在實(shí)際生產(chǎn)中tomcat是肯定以集群的方式存在
當(dāng)我們修改nginx.conf發(fā)送請求為集群的時(shí)候,如下圖

這個(gè)時(shí)候存在一個(gè)問題,集群的負(fù)載均衡算法是輪詢,會(huì)導(dǎo)致tomcat進(jìn)程緩存產(chǎn)生浪費(fèi),舉個(gè)例子
- 假如現(xiàn)在有兩臺(tái)Tomcat服務(wù)器,一臺(tái)端口為8080,一臺(tái)端口為8081
- 進(jìn)行訪問,查詢id為1的信息,第一次查詢8080端口的tomcat服務(wù)器,此時(shí)8080端口的tomcat服務(wù)器上有id為1信息的緩存,但是當(dāng)我們再次查詢id為1的信息,因?yàn)檩喸兊臋C(jī)制,會(huì)查詢8081端口的tomcat服務(wù)器,但是id為1的進(jìn)程緩存在8080端口的tomcat服務(wù)器上,并且進(jìn)程緩存在集群之間不會(huì)共享,這就導(dǎo)致會(huì)發(fā)生一種情況,有多少tomcat服務(wù)器,就會(huì)有多少份進(jìn)程緩存,這對資源是一種極大的浪費(fèi)
解決方法:
更換負(fù)載均衡算法為 hash $request_uri

這種負(fù)載均衡算法是通過對id值進(jìn)行hash運(yùn)算然后進(jìn)行對tomcat服務(wù)器數(shù)量取余來判斷訪問哪臺(tái)tomcat服務(wù)器,這樣就保證了同一個(gè)id訪問同一個(gè)tomcat服務(wù)器
7.redis緩存
兩個(gè)問題

緩存預(yù)熱代碼(邏輯代碼根據(jù)自己的更換即可)
public class CaffeineConfig implements InitializingBean {
@Autowired
private StringRedisTemplate redisTemplate;
@Autowired
private IItemService itemService;
@Autowired
private IItemStockService itemStockService;
private static final ObjectMapper MAPPER = new ObjectMapper();
@Override
public void afterPropertiesSet() throws Exception {
// 初始化緩存
// 1.查詢商品信息
List<Item> itemList = itemService.list();
// 2.放入緩存
for (Item item : itemList) {
// 2.1 item序列化為JSON
String json = MAPPER.writeValueAsString(item);
// 2.2 存入redis
redisTemplate.opsForValue().set("item:id:" + item.getId(),json);
}
// 3.查詢商品庫存信息
List<ItemStock> stockList = itemStockService.list();
// 2.放入緩存
for (ItemStock stock : stockList) {
// 2.1 item序列化為JSON
String json = MAPPER.writeValueAsString(stock);
// 2.2 存入redis
redisTemplate.opsForValue().set("item:stock:id:" + stock.getId(),json);
}
}
}API簡介
InitializingBean
- 一定要實(shí)現(xiàn)其中的afterPropertiesSet()方法
- 該方法會(huì)在創(chuàng)建Bean之后執(zhí)行,也就是項(xiàng)目啟動(dòng)的時(shí)候執(zhí)行,也就可以實(shí)現(xiàn)緩存預(yù)熱效果了
ObjectMapper
- spring自帶的json序列化工具
8.查詢Redis緩存



9.Nginx本地緩存


總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式
這篇文章主要介紹了Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式,Ubuntu下的配置會(huì)有一些不同之處,需要的朋友可以參考下2015-07-07
在Nginx服務(wù)器中配置mod_proxy反向代理的方法
這篇文章主要介紹了在Nginx服務(wù)器中配置mod_proxy反向代理的方法,Nginx服務(wù)器最大的特點(diǎn)就是作高性能反向代理使用,需要的朋友可以參考下2015-07-07
centos7系統(tǒng)下nginx安裝并配置開機(jī)自啟動(dòng)操作
這篇文章主要介紹了centos7系統(tǒng)下nginx安裝并配置開機(jī)自啟動(dòng)操作方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
nginx+lua+redis 灰度發(fā)布實(shí)現(xiàn)方案
在微服務(wù)化進(jìn)程中,利用nginx+lua+redis實(shí)現(xiàn)灰度發(fā)布至關(guān)重要,,通過nginx+lua反向代理,根據(jù)客戶端ip進(jìn)行路由控制,配合redis存儲(chǔ)允許訪問微服務(wù)的ip地址,可以有效地進(jìn)行用戶分流,感興趣的可以了解一下2024-10-10

