您所在的位置:首页 >行业 >
Hystrix请求合并的使用(一)

时间:2023-04-09 09:17:58    来源:腾讯云


(相关资料图)

在分布式系统中,有时我们需要同时发起多个请求,而这些请求可能需要在客户端进行合并。这可以减少网络开销和客户端线程使用量,并提高系统性能。Hystrix提供了请求合并功能,可以将多个请求合并为单个请求。

Hystrix请求合并的基本原理

在Hystrix中,请求合并是通过以下两个关键组件实现的:

HystrixCommandCollapser:此类用于收集多个请求并将它们合并为单个请求。HystrixCollapserProperties:此类用于配置合并请求的行为。

当我们向服务发出请求时,HystrixCommandCollapser将该请求收集到请求缓冲区中。如果在一定时间内(通过HystrixCollapserProperties设置)有多个请求被收集,则它们将被合并为一个请求。该请求将使用HystrixCommand来发出,然后将响应拆分为单个响应并返回给原始请求。这样,我们就可以减少网络通信和线程使用,并提高系统性能。

Hystrix请求合并的使用示例

在本节中,我们将通过一个示例来演示如何使用Hystrix请求合并。在这个示例中,我们将模拟向外部服务发送多个请求,并使用Hystrix请求合并将它们合并为单个请求。

步骤1:添加依赖

首先,我们需要添加Hystrix依赖。在我们的示例中,我们将使用Spring Boot作为我们的应用程序框架。因此,我们将添加以下依赖:

    org.springframework.cloud    spring-cloud-starter-netflix-hystrix

步骤2:创建外部服务

接下来,我们将创建一个模拟的外部服务,该服务将模拟耗时操作。为此,我们将创建一个名为“ExternalService”的类,并在其中添加一个“getData”方法:

@Componentpublic class ExternalService {    private final Logger logger = LoggerFactory.getLogger(ExternalService.class);    public String getData(String key) throws InterruptedException {        logger.info("getData: " + key);        Thread.sleep(1000);        return "Result for " + key;    }}

如上所述,我们的ExternalService类包含一个名为“getData”的方法,该方法需要一个字符串参数。该方法模拟了一个耗时操作,它会在睡眠1秒后返回一个字符串结果。

步骤3:创建Hystrix请求合并器

现在我们可以创建Hystrix请求合并器。在我们的示例中,我们将创建一个名为“GetDataCollapser”的类,并让它继承自HystrixCommandCollapser:

public class GetDataCollapser extends HystrixCommand> {    private final ExternalService externalService;    private final String key;    public GetDataCollapser(ExternalService externalService, String key) {        super(Setter.withCollapserKey(HystrixCollapserKey.Factory.asKey("GetDataCollapser"))                .andCollapserPropertiesDefaults(HystrixCollapserProperties.Setter()                        .withTimerDelayInMilliseconds(200)));        this.externalService = externalService;        this.key = key;    }    @Override    public Map run() throws Exception {        Map resultMap = new HashMap<>();        String result = externalService.getData(key);        resultMap.put(key, result);        return resultMap;    }    @Override    public String getRequestArgument() {        return key;    }}

如上所述,我们的GetDataCollapser类包含以下内容:

构造函数:该函数初始化HystrixCommandCollapser并将其与Hystrix线程池相关联。在此示例中,我们将HystrixCommandCollapser的键设置为“GetDataCollapser”,并将合并属性设置为延迟200毫秒。run()方法:该方法用于实际执行请求合并操作。在此示例中,我们调用ExternalService的“getData”方法,将其返回结果添加到一个HashMap中,并将其返回。getRequestArgument()方法:该方法返回用于标识请求的参数。在此示例中,我们将其设置为键值。
标签:
Hystrix请求合并的使用(一)

Hystrix请求合并的使用(一)

在分布式系统中,有时我们需要同时发起多个请求,而这些请求可能需要在客户端进行合并。这可以减少网络...

环球简讯:月亮与六便士书评视频_月亮与六便士书评

环球简讯:月亮与六便士书评视频_月亮与六便士书评

1、《月亮和六便士》的现代性首先表现在它的观念性上,在《月亮和六便士》中,毛姆表面上描写了主人公的...

夏天,教你如何选择高质感的短袖!这几个小技巧,基础耐穿又时髦

夏天,教你如何选择高质感的短袖!这几个小技巧,基础耐穿又时髦

春天都来了,夏天还会远吗?提早的选择短袖,等到夏天真正来了就不用手忙脚乱了,虽然短袖看起来平平无...

大学生为省事把饭卡改成手绳(大学生把饭卡改成手绳) 天天快报

大学生为省事把饭卡改成手绳(大学生把饭卡改成手绳) 天天快报

改造成为手绳,外观时尚更个性,可以加强使用者的安全感,也能节省时间和精力,在日常使用中更加方便。...

健康管理师就业前景

健康管理师就业前景

健康管理师作为近年来的新兴职业,其就业前景前景如何,有哪些就业方向,以下是整理的健康管理师就业前...

刘虹夺得世界田联竞走巡回赛女子20公里冠军

刘虹夺得世界田联竞走巡回赛女子20公里冠军

2023年全国竞走大奖赛(第2站)暨世界田联竞走巡回赛8日在江苏太仓市开赛,名将刘虹获得两项赛事的女子...

10000999发来短信说我号码存在安全风险_100009 世界球精选

10000999发来短信说我号码存在安全风险_100009 世界球精选

1、在此题中?=0 36 1000=36 100000=9 25000;?=038 1000=38 100000

环球热点!象声词和拟声词的区别_象声词

环球热点!象声词和拟声词的区别_象声词

1、爆炸声】劈里啪啦:又噼里啪啦,象声词,形容爆裂`的连续声音,如:鞭炮劈里啪啦地响。2、嘣:象声词...

世界快讯:为1.3万名老年人免费体检 相城区度假区启动体检工作

世界快讯:为1.3万名老年人免费体检 相城区度假区启动体检工作

为1 3万名老年人免费体检相城区度假区启动体检工作

路北区水机路小学组织开展“我在唐山仰望 放飞蓝天梦想”航模科技课程进校园活动-每日报道

路北区水机路小学组织开展“我在唐山仰望 放飞蓝天梦想”航模科技课程进校园活动-每日报道

为切实落实“双减”政策,提升学生的科学素养,让学生感受科技的魅力,开启学生的航天梦想,2023年4月6...

2023郑开马拉松4月16日鸣枪 参赛规模为49000人

2023郑开马拉松4月16日鸣枪 参赛规模为49000人

昨日,记者从河南省政府新闻办新闻发布会上获悉,2023郑开马拉松赛将于4月16日在郑州、开封两城举办。届...

86消毒液可以带上高铁吗?

86消毒液可以带上高铁吗?

不可以据介绍,为确保广大旅客平安出行,在旅客进站安检过程中,各车站严格落实“逢包必检,逢液必查,...

全球微动态丨亚马逊美国站:尽早为Prime Day准备 4月28日前创建交易

全球微动态丨亚马逊美国站:尽早为Prime Day准备 4月28日前创建交易

作者 亿邦动力图 壹览商业4月7日消息,亚马逊美国站发布公告称,提示卖家尽早为PrimeDay做准备。公告...

自述偷人的感觉怎么写_自述偷人的感觉 世界热点评

自述偷人的感觉怎么写_自述偷人的感觉 世界热点评

1、不知道这些对你有没帮助:你偷偷就知道了我知道所以你知道!。本文就为大家分享到这里,希望小伙伴们...

全球讯息:打造零售新业态 小店经济成为拉动经济发展的“毛细血管”

全球讯息:打造零售新业态 小店经济成为拉动经济发展的“毛细血管”

央视网消息:县城街头一家仅有60平方米的20年老店,在平台经济助力下成为连接千家万户、满足消费者“万...

原址原状!这个地铁站将建文物展厅!

原址原状!这个地铁站将建文物展厅!

2017年,在天津地铁4号线东南角站工程建设中发现天津古城墙基遗址与地铁施工范围的重叠,随后4年间,天...

国家卫计委员会_国家卫计委官网官网|每日消息

国家卫计委员会_国家卫计委官网官网|每日消息

1、一类承担公共卫生及基层的基本医疗服务,二类非赢利性医疗机构。2、所谓公益一类是指,承担义务教育...

天天快看:霸气签名女生高冷简短(个性签名霸气超拽高冷句子)

天天快看:霸气签名女生高冷简短(个性签名霸气超拽高冷句子)

扣扣个性签名霸气高冷签名最新版个性签名超拽冷酷1、大起大落时看清朋友,有钱没钱时看清女人。2、扭曲...

缅怀革命先烈,中石油菏泽分公司公司开展清明祭扫活动 世界热点

缅怀革命先烈,中石油菏泽分公司公司开展清明祭扫活动 世界热点

清明时节杨柳依,细雨纷纷祭先烈。4月4日,中国石油菏泽分公司组织机关和磐石党支部的党员到鲁西南烈士...

世界消息!太极股份2022年净利增1.2% 经营现金流净额降78%

世界消息!太极股份2022年净利增1.2% 经营现金流净额降78%

太极股份2022年净利增1 2%经营现金流净额降78%

退役公交变身“小菜场”,创意让服务更便民 天天精选

退役公交变身“小菜场”,创意让服务更便民 天天精选

发挥公交场站优势 补齐社区服务短板 公交车卖菜,成了北京市民津津乐道的话题。据本报报道,4月6日一早...

杞人忧天原文怎么读_杞人忧天原文

杞人忧天原文怎么读_杞人忧天原文

1、原文  杞国有人忧天地崩坠,身亡所寄,废寝食者。2、又有忧彼之所忧者,因往晓之,曰:“天,积气...

53岁王菲在巴黎被偶遇!穿风衣瘦得都能看见胸排骨,戴墨镜好霸气_全球球精选

53岁王菲在巴黎被偶遇!穿风衣瘦得都能看见胸排骨,戴墨镜好霸气_全球球精选

而且整身造型风格也很符合王菲一贯追求的休闲与随性感,比如在内搭的选择上就挑选了基础的黑色圆领打底...

谍战剧《薄冰》今晚开播,央视点名预热,湖南卫视又抽到黑马剧 焦点要闻

谍战剧《薄冰》今晚开播,央视点名预热,湖南卫视又抽到黑马剧 焦点要闻

《旗袍》《谍战深海之惊蛰》755-79000都是他写的,很厉害,也不是第一次和刘海波导演合作了。从预告片来...

今日聚焦!北京西城新增一养老餐集中配送中心 每日可配餐超千份

今日聚焦!北京西城新增一养老餐集中配送中心 每日可配餐超千份

人民网北京4月7日电(尹星云)4月6日,北京华方餐饮西城区养老餐集配中心正式启用,将为全区老人进行配餐...

广告

X 关闭

广告

X 关闭