欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于多級緩存使用(nginx本地緩存、JVM進程緩存、redis緩存)

 更新時間:2024年08月02日 09:17:58   作者:棲遲于一丘  
這篇文章主要介紹了關于多級緩存使用(nginx本地緩存、JVM進程緩存、redis緩存),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

整體示意圖

1.nginx緩存

2.進程緩存Caffeine示例

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

4.OpenResty

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

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

item.lua文件內容

上面的item.lua文件中需要進行拼接數據,我們需要JSON結果處理

6.Tomcat集群的負載均衡

在實際生產中tomcat是肯定以集群的方式存在

當我們修改nginx.conf發(fā)送請求為集群的時候,如下圖

這個時候存在一個問題,集群的負載均衡算法是輪詢,會導致tomcat進程緩存產生浪費,舉個例子

  • 假如現(xiàn)在有兩臺Tomcat服務器,一臺端口為8080,一臺端口為8081
  • 進行訪問,查詢id為1的信息,第一次查詢8080端口的tomcat服務器,此時8080端口的tomcat服務器上有id為1信息的緩存,但是當我們再次查詢id為1的信息,因為輪詢的機制,會查詢8081端口的tomcat服務器,但是id為1的進程緩存在8080端口的tomcat服務器上,并且進程緩存在集群之間不會共享,這就導致會發(fā)生一種情況,有多少tomcat服務器,就會有多少份進程緩存,這對資源是一種極大的浪費

解決方法:

更換負載均衡算法為 hash $request_uri

這種負載均衡算法是通過對id值進行hash運算然后進行對tomcat服務器數量取余來判斷訪問哪臺tomcat服務器,這樣就保證了同一個id訪問同一個tomcat服務器

7.redis緩存

兩個問題

緩存預熱代碼(邏輯代碼根據自己的更換即可)

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)緩存預熱效果了

ObjectMapper

  • spring自帶的json序列化工具

8.查詢Redis緩存

9.Nginx本地緩存

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Nginx中泛域名配置的實例教程

    Nginx中泛域名配置的實例教程

    泛域名就是我們平常指的二級和三級域名等,這里我們來總結一下Nginx中泛域名解析配置的實例教程,包括正則匹配等細節(jié)的講解,需要的朋友可以參考下
    2016-05-05
  • Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式

    Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式

    這篇文章主要介紹了Ubuntu下Nginx配置ThinkPHP的Pathinfo和URl Rewrite模式,Ubuntu下的配置會有一些不同之處,需要的朋友可以參考下
    2015-07-07
  • Nginx設置HTTPS的方法步驟

    Nginx設置HTTPS的方法步驟

    本文主要介紹了NGINX設置HTTPS的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • windows7下安裝PHP+nginx的方法

    windows7下安裝PHP+nginx的方法

    這篇文章主要介紹了windows7下安裝PHP+nginx的方法,較為詳細的分析了Windows7環(huán)境下安裝php與nginx服務器環(huán)境的具體步驟與相關設置技巧,需要的朋友可以參考下
    2016-05-05
  • 完全卸載nginx以及安裝的超詳細步驟

    完全卸載nginx以及安裝的超詳細步驟

    由于之前下載太亂,找相關目錄半天找不對位置,所以決定卸載nginx并重新安裝,下面這篇文章主要給大家介紹了關于完全卸載nginx以及安裝的超詳細步驟,需要的朋友可以參考下
    2022-12-12
  • 在Nginx服務器中配置mod_proxy反向代理的方法

    在Nginx服務器中配置mod_proxy反向代理的方法

    這篇文章主要介紹了在Nginx服務器中配置mod_proxy反向代理的方法,Nginx服務器最大的特點就是作高性能反向代理使用,需要的朋友可以參考下
    2015-07-07
  • centos7系統(tǒng)下nginx安裝并配置開機自啟動操作

    centos7系統(tǒng)下nginx安裝并配置開機自啟動操作

    這篇文章主要介紹了centos7系統(tǒng)下nginx安裝并配置開機自啟動操作方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • nginx+lua+redis 灰度發(fā)布實現(xiàn)方案

    nginx+lua+redis 灰度發(fā)布實現(xiàn)方案

    在微服務化進程中,利用nginx+lua+redis實現(xiàn)灰度發(fā)布至關重要,,通過nginx+lua反向代理,根據客戶端ip進行路由控制,配合redis存儲允許訪問微服務的ip地址,可以有效地進行用戶分流,感興趣的可以了解一下
    2024-10-10
  • Nginx服務器中的GZip配置參數詳解

    Nginx服務器中的GZip配置參數詳解

    這篇文章主要介紹了Nginx服務器中的GZip配置參數詳解,即利用GZip來壓縮網站頁面數據,需要的朋友可以參考下
    2015-08-08
  • 一文帶你搞懂Nginx中的配置文件

    一文帶你搞懂Nginx中的配置文件

    Nginx(發(fā)音為“engine-x”)是一款高性能的?Web?服務器、反向代理服務器和負載均衡器,廣泛應用于全球各類網站和應用中,下面就跟隨小編一起來了解下如何配置?Nginx?以滿足不同的需求吧
    2025-01-01

最新評論