hystrix应用 博客_使用Hystrix DSL创建弹性骆驼应用程序

hystrix应用 博客

Apache Camel是一个成熟的集成库(到现在已有9年的历史了),它实现了Enterprise Integration Patterns一书中的所有模式。 但是Camel不仅是EIP实现库,它还是一个不断发展,添加新模式并适应行业变化的现代框架。 除了每个版本中添加了数十个连接器之外,Camel还与Java语言新版本本身和其他Java框架提供的新功能紧密结合。 随着时间的流逝,诸如SOA和ESB之类的某些架构样式逐渐失去吸引力,而诸如REST之类的新架构样式则使微服务受到欢迎。

为了使开发人员能够利用这些新趋势进行集成,Camel通过添加诸如REST DSL之类的新DSL和诸如Circuit Breaker之类的新模式以及诸如Spring Boot之类的组件来做出响应。 这还不是全部,我们还远远没有完成。 借助Docker容器和Kubernetes等技术,IT行业现在正以更快的速度向前发展,而Camel也在不断发展以减轻开发人员的负担。 要了解某种工具,您需要在Docker和Kubernetes上开发和运行应用程序,请查看Fabric8项目,特别是工具,例如Docker Maven插件,Kubernetes CDI扩展,Kubernetes Java客户端,针对Kubernetes的Arquilian测试等。大量有趣的技术将带给您激动人心的时代,下面让我们看一下其中的一种:骆驼和基于Hystrix的断路器。

两座骆驼断路器,该选择哪一个?

两年前,当我第一次阅读Michael Nygard的Release It时 ,我无法停止在Camel中实现Circuit Breaker模式 。 通常,我会根据实际客户的需求来贡献自己的力量,但是断路器模式是如此优雅,我不得不这样做。 为了以非介入方式实现它,我将其添加为Camel负载均衡器策略。 这很简单:

<camelContext id="camel" xmlns="http://camel.apache.org/schema/spring"><route><from uri="direct:start"/><loadBalance><circuitBreaker threshold="2" halfOpenAfter="1000"><exception>MyCustomException</exception></circuitBreaker><to uri="mock:result"/></loadBalance></route>
</camelContext>

上面的DSL自我描述:如果模拟:结果端点抛出的MyCustomExceptions数量达到阈值数量,则CircuitBreaker进入打开状态并开始拒绝所有请求。 1000毫秒后,它将进入halfOpenAfter状态,并且在此状态下的第一个请求的结果将其下一个状态定义为已关闭或已打开。 您可以想象这是CircuitBreker的最简单的实现,但仍然有用。

屏幕截图2016-05-26 at 07.56.13

从那时起,Microseservices体系结构变得越来越流行,Circuit Breaker Pattern及其java实现Hystrix也是如此 。 劳尔·克里帕拉尼(RaúlKripalani)在某个时候开始在骆驼(Camel)实施Hystrix,并将所有基础工作落实到位,但是随着时间的流逝,它失去了动力。 然后一次又一次地看到来自不同客户的相同请求,我接下了继电器并继续进行工作,并将Hystrix组件推到了Camel。 看到社区的反馈,它仍然没有它应有的优雅。 然后, Claus介入并通过将Hystrix转变为EIP(而非组件)而使其成为Camel DSL的一部分。 那么现在在骆驼中创建基于Hystrix的断路器是什么样子呢?

public class ClientRoute extends RouteBuilder {@Overridepublic void configure() {from("timer:trigger?period=1s").log(" Client request: ${body}").hystrix().to("http://localhost:9090/service1")// use onFallback() to provide a repsonse message immediately: .transform().simple("Fallback ${body}")// use onFallbackViaNetwork() when there is a 2nd service call.onFallbackViaNetwork().to("http://localhost:7070/service2").end().log("Client response: ${body}");}
}

在上面的示例中,您几乎看不到断路器的所有可用选项,要查看所有这些选项,请检出官方文档并尝试放置在示例中的 Claus应用程序。

根据此示例,您可能认为Hystrix是Camel核心的一部分,但事实并非如此。 骆驼核心仍然是这样,没有第三方库的依赖。 如果要使用基于Hystrix的断路器,则需要像其他任何非核心组件一样,将camel-hystrix依赖项添加到依赖项中,并使其在运行时可用。

快速失败,后备,隔板,超时等

Hystrix库实现的不仅仅是断路器模式。 它也可以进行批量处理,请求缓存,超时,请求折叠等。Camel中的实现不支持请求折叠和缓存,因为这些已经使用Camel中可用的其他模式和组件完成了。 Camel中的请求折叠可以使用Aggregator EIP完成,而缓存可以使用Redis,Inifinspan,Hazelcast等缓存组件完成。Camel中的Hystrix DSL提供了Hystrix支持的大约30种配置选项,还通过JMX和/或公开了指标Hystrix仪表板的 REST。

hystrix-web-console

最后一点,不要忘记创建一个真正的弹性应用程序,您需要的不仅仅是Hystrix。 Hystrix将在线程池级别进行批量处理,但是如果您不在进程,主机和物理计算机级别应用相同的原理,那还不够。 要创建一个可恢复的分布式系统,您还需要使用Retry,Throttleing,Timeout…和其他好的技巧,我在Camel Design Patterns一书中已经描述了其中的一些技巧。

要了解新模式,请查看示例 ,然后开始使用Hystrix保护基于Camel的微服务。

翻译自: https://www.javacodegeeks.com/2016/06/create-resilient-camel-applications-hystrix-dsl.html

hystrix应用 博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/335731.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

notebook打开外部文件_CAD外部参照真是个好东西!

好课推荐&#xff1a;零基础CAD&#xff1a;点我CAD室内&#xff1a;点我 周站长CAD&#xff1a;点我CAD机械&#xff1a;点我 Bim教程&#xff1a;点我CAD建筑&#xff1a;点我CAD三维&#xff1a;点我全屋定制&#xff1a;点我 ps教程&#xff1a;点我苹果版CAD:点我 3dmax教…

JSP动作元素/活动元素

文章目录jsp:forwardjsp:includejsp:paramjsp:useBeanjsp:setPropertyjsp:setProperty name"" property"" value""jsp:setProperty name"" property"" param""jsp:setProperty name"" property"*&…

gradle groovy_适用于Java开发人员的Groovy吗? 认识Gradle,Grails和Spock

gradle groovyJava开发人员最感兴趣的Groovy用例有哪些&#xff1f; 尽管已经有一段时间了&#xff0c;但似乎只有Groovy最近才开始使用Groove。 对于某些人来说&#xff0c;它基本上只是另一种深奥的JVM语言&#xff0c;但是由于一些流行的工具可以帮助您使用Java&#xff0c…

JSP 指令元素

文章目录page 指令import 属性pageEncoding 属性contentType 属性session 属性isELIgnored 属性errorPage 属性isErrorPage 属性include 指令file 属性taglib 指令uri 属性prefix 属性jsp 源文件转换成对应的 .java 文件时&#xff0c;jsp 的指令会影响 Java 源代码的生成&…

indesign中调出字符样式快捷键_Word中十大黄金快捷键,你会用几个?

在使用Word文档时&#xff0c;熟练使用快捷键能够有效的提升我们的工作效率&#xff0c;但是&#xff0c;Word中快捷键也比较多&#xff0c;要想全部掌握&#xff0c;那不太现实&#xff0c;这里&#xff0c;易老师给大家挑选了10组黄金快捷键&#xff0c;非常实用。01 快速移动…

couchbase集群_使用CLI扩展和重新平衡Couchbase集群

couchbase集群Couchbase通过多种方式提供高可用性和灾难恢复 &#xff1a; 同质簇 复写 集群内复制 备份还原 机架区意识 该博客将展示如何使用Couchbase命令行界面&#xff08;CLI&#xff09;创建Couchbase集群。 此外&#xff0c;还可以使用Couchbase REST API和Couchba…

maya室内模型_C4d和3dmax、maya相比有什么优势?

C4D和3dmax、maya都是三维软件&#xff0c;功能都是非常的nice&#xff0c;很多新手小伙伴就在好奇它们有什么区别&#xff0c;对比之下&#xff0c;c4d有哪些优势&#xff1f;c4d和3dmax的主要应用领域就是区分它们的地方。C4D一般用于栏目包装&#xff0c;影视后期&#xff0…

HH SaaS电商系统的标签系统设计

文章目录打标规则公式打标公式变量修改标签删除标签标签实体标签与对象的关系标签和商品&#xff1a;标签和商城会员&#xff1a;标签和租户会员&#xff1a;打标规则公式 公式名称&#xff1a;近日销量创历史新高 规则公式&#xff1a;近$ {days}销量创历史新高 公式名称&a…

jvm高并发_在JVM上对高并发HTTP服务器进行基准测试

jvm高并发在第一篇关于HTTP客户端的文章 &#xff08;我将您重定向到JVM上的高效HTTP的介绍&#xff09;之后&#xff0c;现在让我们来谈谈HTTP 服务器 。 有一些关于HTTP服务器的基准测试&#xff0c;但通常受到诸如以下缺点的阻碍&#xff1a; 没有有效地执行高并发方案&am…

excel未完全加载怎么办_你知道如何改变Excel的打开姿势吗?

你是否曾经想过在启动Excel时自动打开某些特定的文档&#xff1f;当然&#xff0c;你永远都可以手动去打开任何一个文档&#xff0c;但是如果有那么一种可能&#xff0c;去每次省下那么几秒来自动完成这一操作&#xff0c;你会愿意尝试吗&#xff1f;今天&#xff0c;火箭君就和…

电商系统的售后模块设计

文章目录售后单实体方案一方案二服务类型可选售后服务判断规则退款类型售后截止时间金币和优惠券如何返还买家端订单列表的“售后按钮”逻辑说明服务端处理逻辑买家端操作“售后按钮”页面跳转逻辑商家管理后台订单列表的“售后处理”逻辑说明服务端处理逻辑商家端操作“售后处…

python中元组和列表转化_4.Python列表/元组/集合/字典

4.1 Python列表• 列表用 [ ] 标识&#xff0c;是Python 最通用的复合数据类型。• 列表用 [ ] 表示&#xff0c;列表具有可嵌套性4.1.1 Python列表截取• 列表可以使用 [头下标:尾下标] 截取相应的子列表&#xff0c; 从左到右索引默认 0 开始&#xff0c;从右到左索引默认-1开…

【WebRTC---源码篇】(十二)WebRTC/RTX协议

在SDP中可以查询到提前协商好的RTX信息 接受到RTCP NACK 重传RTX包,有效荷载前两个字节为原始seqnumber 如何知道重传的是哪个包 发送RTX

stackoverflow_Stackoverflow:您尚未发现的7个最佳Java答案

stackoverflow您可以在Stackoverflow上找到哪些最有趣的答案&#xff1f; Stackoverflow是开发人员的金矿。 它可以帮助我们找到遇到的特定问题的最有用答案&#xff0c;并且我们总是从中学习新事物。 在以下文章中&#xff0c;我们研究了最受欢迎的Java问题和答案&#xff0…

json请求 post vue_Spring Boot+Vueaxios异步请求数据的12种操作(上篇)

Java大联盟致力于最高效的Java学习关注Spring Boot Vue 前后端分离最核心的操作就是通过异步请求完成数据同步&#xff0c;这其中又可以分为很多种不同的情况&#xff0c;比如是 GET 请求还是 POST 请求&#xff1f;参数是普通变量还是 JSON&#xff1f;基于 RESTful 架构如何…

【WebRTC---源码篇】(十三)WebRTC/Pacer

pacer作用 NextSendTime Timestamp PacingController::NextSendTime() const {Timestamp now = CurrentTime();if (paused_) {return last_send_time_ + kPausedProcessInterval;}// If probing is active, that always takes priority.if (prober_.IsProbing()) {Timest…

全景视觉空间直线检测_视觉SLAM深度解读

近年来&#xff0c;SLAM技术取得了惊人的发展&#xff0c;领先一步的激光SLAM已成熟的应用于各大场景中&#xff0c;视觉SLAM虽在落地应用上不及激光SLAM&#xff0c;但也是目前研究的一大热点&#xff0c;今天我们就来详细聊聊视觉SLAM的那些事儿。视觉SLAM是什么&#xff1f;…

对象必须实现 iconvertible。_java面向对象最全入门笔记(通俗易懂,适合初学者)...

前言:面向对象的三大特征封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism)编程思想&#xff1a;面向过程&#xff1a;做某件事情都需要自己亲历亲为&#xff0c;按照步骤去完成面向对象&#xff1a;做某件事情不需要自己亲历亲为&#xff0c;只需指定特定的对象去完…

HH SaaS电商系统的结算系统设计

文章目录一、第三方卖家销售货款结算流程说明&#xff1a;销售货款结算逻辑流程图预期收入如何统计二、第三方卖家推广分销佣金结算佣金结算逻辑流程图逾期佣金收入如何统计三、采购货款结算租户采购货款结算流程说明商城采购货款结算流程说明店铺商家的采购货款结算流程说明四…

postgresql删除索引_PostgreSQL 13 发布,索引和查找有重大改进

9月24日&#xff0c;PostgreSQL全球开发组宣布PostgreSQL 13正式发布&#xff0c;作为世界上使用最多的开源数据库之一&#xff0c;PostgresSQL 13是目前的最新版本。PostgreSQL 13 在索引和查找方面进行了重大改进&#xff0c;有利于大型数据库系统&#xff0c;改进包括索引的…