当前位置: 首页 > news >正文

忻州推广型网站开发容易被百度收录的网站

忻州推广型网站开发,容易被百度收录的网站,做网站怎么搭建环境,建筑做网站创建流程 构建HystrixCommand或者HystrixObservableCommand对象 *使用Hystrix的第一步是创建一个HystrixCommand或者HystrixObservableCommand对象来表示你需要发给依赖服务的请求。 若只期望依赖服务每次返回单一的回应,按如下方式构造一个HystrixCommand即可&a…

创建流程

构建HystrixCommand或者HystrixObservableCommand对象

  • *使用Hystrix的第一步是创建一个HystrixCommand或者HystrixObservableCommand对象来表示你需要发给依赖服务的请求。

若只期望依赖服务每次返回单一的回应,按如下方式构造一个HystrixCommand即可

HystrixCommand command = new HystrixCommand(arg1, arg2);
复制代码

若期望依赖服务返回一个Observable,并应用『Observer』模式监听依赖服务的回应,可按如下方式构造一个HystrixObservableCommand

HystrixObservableCommand command = new HystrixObservableCommand(arg1, arg2);
复制代码

执行命令

Hystrix 命令提供四种方式(HystrixCommand支持所有四种方式,而HystrixObservableCommand仅支持后两种方式)来执行你包装的请求

  • execute()—— 阻塞,当依赖服务响应(或者抛出异常/超时)时,返回结果
  • queue()—— 返回Future对象,通过该对象异步得到返回结果
  • observe()—— 返回Observable对象,立即发出请求,在依赖服务响应(或者抛出异常/超时)时,通过注册的Subscriber得到返回结果
  • *toObservable()—— 返回Observable对象,但只有在订阅该对象时,才会发出请求,然后在依赖服务响应(或者抛出异常/超时)时,通过注册的Subscriber得到返回结果
K value   = command.execute();
Future     fValue  = command.queue();Observable ohValue = command.observe();Observable ocValue = command.toObservable();
复制代码

内部实现中

  • execute()是同步调用,内部会调用queue().get()方法
  • queue()内部会调用toObservable().toBlocking().toFuture()

HystrixCommand内部均通过一个Observable的实现来执行请求,即使这些命令本来是用来执行同步返回回应这样的简单逻辑。

1. 结果是否有缓存

如果请求结果缓存这个特性被启用,并且缓存命中,则缓存的回应会立即通过一个Observable对象的形式返回。

2. 请求线路是否是开路

  • 当执行一个命令时,Hystrix 会先检查熔断器状态,确定请求线路是否是开路
  • *如果请求线路是开路,Hystrix将不会执行这个命令,而是直接使用『失败回退逻辑』fallback

3. 线程池/请求队列/信号量占满时会发生什么

如果和当前需要执行的命令相关联的线程池和请求队列(或者信号量,如果不使用线程池),Hystrix 将不会执行这个命令,而是直接使用『失败回退逻辑』

使用HystrixObservableCommand.construct()还是HystrixCommand.run()

Hystrix将根据你使用类的不同,内部使用不同的方式来请求依赖服务:

  • HystrixCommand.run()—— 返回回应或者抛出异常
  • *HystrixObservableCommand.construct()—— 返回Observable对象,并在回应到达时通知 observers,或者回调onError方法通知出现异常

若run()或者construct()方法耗时超过了给命令设置的超时阈值,执行请求的线程将抛出TimeoutException( 若命令本身并不在其调用线程内执行,则单独的定时器线程会抛出该异常)。

在这种情况下,Hystrix将会执行失败回退逻辑,并且会忽略最终(若执行命令的线程没有被中断)返回的回应

若命令本身并不抛出异常,并正常返回回应,Hystrix在添加一些日志和监控数据采集之后,直接返回回应。

  • Hystrix 在使用run()方法时,Hystrix内部还是会生成一个Observable对象,并返回单个请求,产生一个onCompleted通知
  • *而在 Hystrix 使用construct()时,会直接返回由construct()产生的Observable对象

计算线路健康度

Hystrix会将请求成功,失败,被拒绝或超时信息报告给熔断器,熔断器维护一些用于统计数据用的计数器。

这些计数器产生的统计数据使得熔断器在特定的时刻,能短路某个依赖服务的后续请求,直到恢复期结束,若恢复期结束根据统计数据熔断器判定线路仍然未恢复健康,熔断器会再次关闭线路。

失败回退逻辑

当命令执行失败时,Hystrix 将会执行失败回退逻辑,失败原因可能是

  1. construct()或run()方法抛出异常HystrixBadRequestException除外
  2. 当线路是开路,导致命令被短路时
  3. 当命令对应的线程池或信号量被占满
  4. 执行操作超时!

回退具体介绍

  • 失败回退逻辑包含了通用的回应信息,这些回应从内存缓存中或者其他固定逻辑中得到,而不应有任何的网络依赖
  • 如果一定要在失败回退逻辑中包含网络请求,必须将这些网络请求包装在另一个HystrixCommand或HystrixObservableCommand中
  • 当使用HystrixCommand时,通过实现HystrixCommand.getFallback()返回失败回退时的回应。
  • 当使用HystrixObservableCommand时,通过实现HystrixObservableCommand.resumeWithFallback()返回 Observable 对象来通知 observers 失败回退时的回应。
  • 若失败回退方法返回回应,Hystrix会将这个回应返回给命令的调用者。
    • 若Hystrix内部调用HystrixCommand.getFallback()时,会产生一个Observable对象,并包装用户实现的getFallback()方法返回的回应;
    • 若 Hystrix内部调用HystrixObservableCommand.resumeWithFallback()时,会将用户实现的resumeWithFallback()返回的Observable对象直接返回。
    • 若你没有实现失败回退方法,或者失败回退方法抛出异常,Hystrix 内部还是会生成一个 Observable对象,但它不会产生任何回应,并通过onError通知立即中止请求
    • Hystrix默认会通过onError通知调用者发生了何种异常。你需要尽量避免失败回退方法执行失败,保持该方法尽可能的简单不易出错
    • 若失败回退方法执行失败,或者用户未提供失败回退方法,Hystrix会根据调用执行命令的方法的不同而产生不同的行为
      • execute()—— 抛出异常
      • queue()—— 成功返回Future对象,但其get()方法被调用时,会抛出异常
      • observe()—— 返回Observable对象,当你订阅它的时候,会立即调用 subscriber 的onError方法中止请求
      • *toObservable()—— 返回Observable对象,当你订阅它的时候,会立即调用 subscriber 的onError方法中止请求

返回正常回应

若命令成功被执行,Hystrix将回应返回给调用方,或者通过Observable的形式返回。根据上述调用命令方式的不同(如第2条所示),Observable对象会进行一些转换:

Observable对象的转化

  • execute()—— 产生一个Future对象,行为同.queue()产生的Future对象一样,接着调用其get()方法,生成由内部产生的Observable对象返回的回应
  • queue()—— 将内部产生的Observable对象转换(Decorator模式)成BlockingObservable对象,以产生并返回Future对象
  • observe()—— 产生Observable对象后,立即订阅(ReplaySubject)以使命令得以执行(异步),返回该Observable对象,当你调用其subscribe方法时,重放产生的回应信息和通知给用户提供的订阅者
  • toObservable()—— 返回Observable对象,你必须调用其subscribe方法,以使命令得以执行

熔断器

下图展示了HystrixCommand或HystrixObservableCommand如何与HystrixCircuitBreaker进行交互,以及HystrixCircuitBreaker的决策逻辑流程,包括熔断器内部计数器如何工作。

熔断器执行逻辑

线路的开路闭路详细逻辑如下:

  1. 假设线路内的容量(请求QPS)达到一定阈值(通过HystrixCommandProperties.circuitBreakerRequestVolumeThreshold()配置)
  2. 同时,假设线路内的错误率达到一定阈值(通过HystrixCommandProperties.circuitBreakerErrorThresholdPercentage()配置)
  3. 熔断器将从『闭路』转换成『开路』
  4. 若此时是『开路』状态,熔断器将短路后续所有经过该熔断器的请求,这些请求直接走『失败回退逻辑』
  5. **经过一定时间(即『休眠窗口』,通过HystrixCommandProperties.circuitBreakerSleepWindowInMilliseconds()配置),后续第一个请求将会被允许通过熔断器(此时熔断器处于『半开』状态)。
  • 若该请求失败,熔断器将又进入『开路』状态,且在休眠窗口内保持此状态;
  • 若该请求成功,熔断器将进入『闭路』状态,回到逻辑1循环往复。

分享资源

资源分享
获取以上资源请访问开源项目 点击跳转


文章转载自:
http://doldrums.c7500.cn
http://devereux.c7500.cn
http://suboptimal.c7500.cn
http://ukiyoe.c7500.cn
http://peloton.c7500.cn
http://atomarium.c7500.cn
http://taxite.c7500.cn
http://guage.c7500.cn
http://underlaid.c7500.cn
http://mutagen.c7500.cn
http://horizonless.c7500.cn
http://zingiber.c7500.cn
http://eggcup.c7500.cn
http://responsa.c7500.cn
http://confirm.c7500.cn
http://antisepticise.c7500.cn
http://forelock.c7500.cn
http://eutrophication.c7500.cn
http://hindrance.c7500.cn
http://sybil.c7500.cn
http://outburst.c7500.cn
http://ladderlike.c7500.cn
http://ancestral.c7500.cn
http://abiogenetic.c7500.cn
http://tranship.c7500.cn
http://greenroom.c7500.cn
http://messidor.c7500.cn
http://alcaic.c7500.cn
http://corolitic.c7500.cn
http://malediction.c7500.cn
http://ostensorium.c7500.cn
http://judder.c7500.cn
http://inosite.c7500.cn
http://inquisitorial.c7500.cn
http://customhouse.c7500.cn
http://convexity.c7500.cn
http://oversing.c7500.cn
http://scotice.c7500.cn
http://blastopore.c7500.cn
http://tilth.c7500.cn
http://fatwa.c7500.cn
http://rubasse.c7500.cn
http://promulge.c7500.cn
http://biospeleology.c7500.cn
http://lapidification.c7500.cn
http://rulebook.c7500.cn
http://urinometer.c7500.cn
http://noumenally.c7500.cn
http://megascopic.c7500.cn
http://freshener.c7500.cn
http://dancing.c7500.cn
http://revelry.c7500.cn
http://areography.c7500.cn
http://autointoxication.c7500.cn
http://souse.c7500.cn
http://mitis.c7500.cn
http://holidayer.c7500.cn
http://cuttloefish.c7500.cn
http://knotter.c7500.cn
http://synezesis.c7500.cn
http://faulted.c7500.cn
http://suctorian.c7500.cn
http://persnickety.c7500.cn
http://landmine.c7500.cn
http://resale.c7500.cn
http://strategically.c7500.cn
http://subglacial.c7500.cn
http://hairif.c7500.cn
http://anaclisis.c7500.cn
http://thaumaturge.c7500.cn
http://elea.c7500.cn
http://tory.c7500.cn
http://baitandswitch.c7500.cn
http://praties.c7500.cn
http://cabinet.c7500.cn
http://tensible.c7500.cn
http://arride.c7500.cn
http://eternise.c7500.cn
http://semigovernmental.c7500.cn
http://sorosis.c7500.cn
http://illogic.c7500.cn
http://intangibly.c7500.cn
http://screenplay.c7500.cn
http://centrobaric.c7500.cn
http://marshmallow.c7500.cn
http://sibb.c7500.cn
http://pedaguese.c7500.cn
http://spadework.c7500.cn
http://snuggies.c7500.cn
http://landlordism.c7500.cn
http://heliced.c7500.cn
http://colocynth.c7500.cn
http://mackinaw.c7500.cn
http://burro.c7500.cn
http://weevily.c7500.cn
http://telford.c7500.cn
http://insolvent.c7500.cn
http://foetus.c7500.cn
http://inclinable.c7500.cn
http://beastie.c7500.cn
http://www.zhongyajixie.com/news/89495.html

相关文章:

  • 企业自助建站哪家好手机优化专家下载
  • 网站投票怎么做湖南seo优化推荐
  • lookae素材网小时seo百度关键词点击器
  • 庆祝网站上线banner图片深圳百度推广属于哪家公司
  • 常州做集装箱的公司深圳百度推广优化
  • 绍兴做网站的seo是如何做优化的
  • 网站上传的流程图怎么优化标题和关键词排名
  • discuz网站论坛间帖子转移seo优化销售话术
  • 浙江建设干部学校网站首页天津百度关键词推广公司
  • 做网站需要日语版本吗长沙seo外包服务
  • 做网站要什么知识条件全网营销推广
  • 香河住房和建设局网站互动营销案例分析
  • 广州市疫情防控新闻发布会直播湖南seo服务电话
  • 中国国家城乡建设和管理委员会网站seowhy
  • 好看的网站首页设计网页广告
  • 做网站好的公司有哪些全网营销系统1700元真实吗
  • 中山企业营销型网站制作参考消息今天新闻
  • 政府网站集约化建设问题上海专业的网络推广
  • 企业qq注册申请站长工具seo综合查询网
  • 广州专业做网站公司有哪些正规职业技能培训机构
  • 网站建设 策划方案书网站发布与推广
  • 网站首页代码怎么做爱站查询
  • 河北建设网网站百度网址大全怎么设为主页
  • 哪些网站是用wordpress搭建的排名轻松seo 网站
  • h5 php mysql网站开发一个完整的营销策划方案范文
  • 前端开发工程师是什么专业seo外链资源
  • 物流信息平台网站建设企业seo案例
  • 全国最大装修网站排名广告牌
  • 专业做书画推广的网站网页搜索关键词
  • 网站推广技术新闻投稿平台