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

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

 更新時間:2024年08月02日 09:17:58   作者:棲遲于一丘  
這篇文章主要介紹了關(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)文章

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

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

    泛域名就是我們平常指的二級和三級域名等,這里我們來總結(jié)一下Nginx中泛域名解析配置的實例教程,包括正則匹配等細(xì)節(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設(shè)置HTTPS的方法步驟

    Nginx設(shè)置HTTPS的方法步驟

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

    windows7下安裝PHP+nginx的方法

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

    完全卸載nginx以及安裝的超詳細(xì)步驟

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

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

    這篇文章主要介紹了在Nginx服務(wù)器中配置mod_proxy反向代理的方法,Nginx服務(wù)器最大的特點就是作高性能反向代理使用,需要的朋友可以參考下
    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)方案

    在微服務(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
  • Nginx服務(wù)器中的GZip配置參數(shù)詳解

    Nginx服務(wù)器中的GZip配置參數(shù)詳解

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

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

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

最新評論