91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring Cloud中Hystrix緩存與合并請求的示例分析

發布時間:2021-12-24 10:26:29 來源:億速云 閱讀:173 作者:小新 欄目:云計算

小編給大家分享一下Spring Cloud中Hystrix緩存與合并請求的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

緩存與合并請求

緩存注解

        在6.3章節中,講述了Hystrix的緩存功能,在Spring Cloud中,同樣支持使用緩存,并且可以通過注解來實現。根據前面章節可知,緩存與合并請求功能,需要先初始化請求上下文才能實現。新建一個javax.servlet.Filter,用于創建與銷毀Hystrix的請求上下文,請見代碼清單6-9。

        代碼清單6-19:

        codes\06\6.4\spring-hystrix-invoker\src\main\java\org\crazyit\cloud\HystrixFilter.java

@WebFilter(urlPatterns = "/*", filterName = "hystrixFilter")
public class HystrixFilter implements Filter {

    public void init(FilterConfig filterConfig) throws ServletException {
    }
    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {
        HystrixRequestContext context = HystrixRequestContext
                .initializeContext();
        try {
            chain.doFilter(request, response);
        } finally {
            context.shutdown();
        }
    }
    public void destroy() {
    }
}

        編寫服務方法,使用@CacheResult注解進行修飾,請見代碼清單6-20。

        代碼清單6-20:CacheService.java

@Component
public class CacheService {

    @CacheResult
    @HystrixCommand
    public Person getPerson(Integer id) {
        System.out.println("執行 getPerson 方法");
        Person p = new Person();
        p.setId(id);
        p.setName("angus");
        return p;
    }
}

        注意服務方法中,被調用一次就會進行一次控制臺輸出。在控制器的方法中,調用多次getPerson方法,控制器代碼請見代碼清單6-21。

        代碼清單6-21:

        codes\06\6.4\spring-hystrix-invoker\src\main\java\org\crazyit\cloud\InvokerController.java

    @RequestMapping(value = "/cache1/{personId}", method = RequestMethod.GET, 
            produces = MediaType.APPLICATION_JSON_VALUE)
    public Person testCacheResult(@PathVariable Integer personId) {
        // 調用多次服務
        for(int i = 0; i < 3; i++) {
            Person p = cacheService.getPerson(personId);
            System.out.println("控制器調用服務 " + i);
        }
        return new Person();
    }

        控制器中調用了多次服務方法,也就是用戶發送請求后,會執行多次服務方法,啟動“服務調用者”,訪問以下地址:http://localhost:9000/cache1/1,控制臺輸出如下:

執行 getPerson 方法
控制器調用服務 0
控制器調用服務 1
控制器調用服務 2

        根據輸出結果可知,在一次用戶請求的過程中,服務方法只執行了一次,緩存生效。緩存的注解主要有以下3個:

  • @CacheResult:該注解修飾方法,表示被修飾的方法返回結果將會被緩存,需要與@HystrixCommand一起使用。

  • @CacheRemove:用于修飾方法讓緩存失效,需要與@CacheResult的緩存key關聯。

  • @CacheKey:用于修飾方法參數,表示該參數作為緩存的key。

        前面的例子使用了@CacheResult注解,下面的代碼片斷,結合@CacheResult與@CacheRemove一起使用:

    @CacheResult()
    @HystrixCommand(commandKey = "removeKey")
    public String cacheMethod(String name) {
        return "hello";
    }

    @CacheRemove(commandKey = "removeKey")
    @HystrixCommand
    public String updateMethod(String name) {
        return "update";
    }

        以上代碼片斷中的cacheMethod方法,使用的緩存key為“removeKey”,方法updateMethod被調用后,將會刪除key為“updateMethod”的緩存。關于3個緩存注解更深入的使用,本小節不再贅述,讀者可以自行測試。

合并請求注解

        在Spring Cloud中,同樣支持合并請求,在一次HTTP請求的過程中,收集一段時間內的相同請求,放到一個批處理命令中執行。實現合并請求,同樣需要先初始化請求上下文,具體請參見6.4.4中的Filter。接下來,編寫服務類,請見代碼清單6-22。

        代碼清單6-22:CollapseService.java

public class CollapseService {

    // 配置收集1秒內的請求
    @HystrixCollapser(batchMethod = "getPersons", collapserProperties = 
        { 
            @HystrixProperty(name = "timerDelayInMilliseconds", value = "1000") 
        }
    )
    public Future<Person> getSinglePerson(Integer id) {
        System.out.println("執行單個獲取的方法");
        return null;
    }

    @HystrixCommand
    public List<Person> getPersons(List<Integer> ids) {
        System.out.println("收集請求,參數數量:" + ids.size());
        List<Person> ps = new ArrayList<Person>();
        for (Integer id : ids) {
            Person p = new Person();
            p.setId(id);
            p.setName("crazyit");
            ps.add(p);
        }
        return ps;
    }
}

        代碼清單中,最后真實執行的方法為“getPersons”,getSinglePerson方法使用了@HystrixCollapser注解來修飾,會收集1秒內調用getSinglePerson的請求,放到getPersons方法中進行批處理。控制器中調用多次getSinglePerson方法,如代碼清單6-23所示。

        代碼清單6-23:

        codes\06\6.4\spring-hystrix-invoker\src\main\java\org\crazyit\cloud\InvokerController.java

    @RequestMapping(value = "/collapse", method = RequestMethod.GET, 
            produces = MediaType.APPLICATION_JSON_VALUE)
    public String testCollapse() throws Exception {
        // 連續執行3次請求
        Future<Person> f1 = collapseService.getSinglePerson(1);
        Future<Person> f2 = collapseService.getSinglePerson(2);
        Future<Person> f3 = collapseService.getSinglePerson(3);
        Person p1 = f1.get();
        Person p2 = f2.get();
        Person p3 = f3.get();
        System.out.println(p1.getId() + "---" + p1.getName());
        System.out.println(p2.getId() + "---" + p2.getName());
        System.out.println(p3.getId() + "---" + p3.getName());        
        return "";
    }

        異步執行了3次getSinglePerson方法,啟動“服務調用者”,訪問以下地址:http://localhost:9000/collapse,控制臺輸出如下:

收集請求,參數數量:3
1---crazyit
2---crazyit
3---crazyit

        根據輸出結果可知,最終只執行了getPersons方法。相對于直接使用Hystrix,Spring Cloud中合并請求較為簡單,合并處理器已經由@HystrixCollapser注解幫我們實現,我們僅關心真正命令的執行即可。

以上是“Spring Cloud中Hystrix緩存與合并請求的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

徐水县| 姚安县| 竹溪县| 呈贡县| 文安县| 巩留县| 广水市| 油尖旺区| 姚安县| 绥芬河市| 白银市| 甘德县| 安徽省| 清镇市| 平定县| 澄城县| 沧源| 蛟河市| 永川市| 博客| 长子县| 张家港市| 梁平县| 南澳县| 綦江县| 息烽县| 威远县| 广宁县| 兴安盟| 桓仁| 沙湾县| 崇州市| 泰和县| 新巴尔虎左旗| 津南区| 波密县| 郧西县| 固原市| 扶绥县| 墨江| 尚义县|