關(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)來之后會去尋找item.lua)
item.lua文件內(nèi)容
上面的item.lua文件中需要進(jìn)行拼接數(shù)據(jù),我們需要JSON結(jié)果處理
6.Tomcat集群的負(fù)載均衡
在實際生產(chǎn)中tomcat是肯定以集群的方式存在
當(dāng)我們修改nginx.conf發(fā)送請求為集群的時候,如下圖
這個時候存在一個問題,集群的負(fù)載均衡算法是輪詢,會導(dǎo)致tomcat進(jìn)程緩存產(chǎn)生浪費,舉個例子
- 假如現(xiàn)在有兩臺Tomcat服務(wù)器,一臺端口為8080,一臺端口為8081
- 進(jìn)行訪問,查詢id為1的信息,第一次查詢8080端口的tomcat服務(wù)器,此時8080端口的tomcat服務(wù)器上有id為1信息的緩存,但是當(dāng)我們再次查詢id為1的信息,因為輪詢的機制,會查詢8081端口的tomcat服務(wù)器,但是id為1的進(jìn)程緩存在8080端口的tomcat服務(wù)器上,并且進(jìn)程緩存在集群之間不會共享,這就導(dǎo)致會發(fā)生一種情況,有多少tomcat服務(wù)器,就會有多少份進(jìn)程緩存,這對資源是一種極大的浪費
解決方法:
更換負(fù)載均衡算法為 hash $request_uri
這種負(fù)載均衡算法是通過對id值進(jìn)行hash運算然后進(jìn)行對tomcat服務(wù)器數(shù)量取余來判斷訪問哪臺tomcat服務(wù)器,這樣就保證了同一個id訪問同一個tomcat服務(wù)器
7.redis緩存
兩個問題
緩存預(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
- 一定要實現(xiàn)其中的afterPropertiesSet()方法
- 該方法會在創(chuàng)建Bean之后執(zhí)行,也就是項目啟動的時候執(zhí)行,也就可以實現(xiàn)緩存預(yù)熱效果了
ObjectMapper
- spring自帶的json序列化工具
8.查詢Redis緩存
9.Nginx本地緩存
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式
這篇文章主要介紹了Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式,Ubuntu下的配置會有一些不同之處,需要的朋友可以參考下2015-07-07在Nginx服務(wù)器中配置mod_proxy反向代理的方法
這篇文章主要介紹了在Nginx服務(wù)器中配置mod_proxy反向代理的方法,Nginx服務(wù)器最大的特點就是作高性能反向代理使用,需要的朋友可以參考下2015-07-07centos7系統(tǒng)下nginx安裝并配置開機自啟動操作
這篇文章主要介紹了centos7系統(tǒng)下nginx安裝并配置開機自啟動操作方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02nginx+lua+redis 灰度發(fā)布實現(xiàn)方案
在微服務(wù)化進(jìn)程中,利用nginx+lua+redis實現(xiàn)灰度發(fā)布至關(guān)重要,,通過nginx+lua反向代理,根據(jù)客戶端ip進(jìn)行路由控制,配合redis存儲允許訪問微服務(wù)的ip地址,可以有效地進(jìn)行用戶分流,感興趣的可以了解一下2024-10-10