如何将HttpClientFactory与Steeltoe结合来完成服务发现

发布时间:2022-01-14 09:18:14 作者:柒染
来源:亿速云 阅读:96

这篇文章主要为大家分析了如何将HttpClientFactory与Steeltoe结合来完成服务发现的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何将HttpClientFactory与Steeltoe结合来完成服务发现”的知识吧。

前言

用HttpClientFactory实现了简单的熔断降级。

下面就来简单说说用HttpClientFactory来实现服务发现。由于标题已经好明显的说了Steeltoe

因此这里会要求有Spring Clound的相关环境,也默认各位对这里有些许了解,所以不会涉及搭建过程的。

下面就开始正文了。

定义Service

这里的Service,其实可以比较简单的理解成对注册到Eureka的服务进行调用,然后进行后续处理。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

在上面的Service中,都是常规的不能再常规的HttpClient的用法!似乎也没有看到任何和服务发现相关的东西呀。

确实,就上面的代码,完成不了服务发现,因为我们的主角,HttpClientFactory还没有出场!

先定义好这个Service,是因为我们这里要用另一种client方式(Typed Client)。

下面就去Startup进行相关的配置了。

在Startup进行配置

在进行配置之前,我们要先添加Steeltoe.Discovery.ClientCore的引用。

<PackageReference Include="Steeltoe.Discovery.ClientCore" Version="2.1.0-rc1" />

再按照Steeltoe的配置说明,在appsettings.json中添加下面的配置

如何将HttpClientFactory与Steeltoe结合来完成服务发现

最后就是在ConfigureServices方法里面进行操作了。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

这里注册HttpClient,涉及到了两个点。一个是Typed Client,另一个是outgoing request middleware

Typed Client 主要是AddTypedClient<IMyService, MyService>(),表明注册的这个HttpClient是给这个类型用的。

DiscoveryHttpMessageHandler表明,使用这个HttpClient的时候,会使用这个Handler.

另外,这里指定的BaseAddress是http://bservicetest/api/values/。

这个是已经注册到Eureka的另外一个测试服务,我们就是要发现它,然后从这个服务里面取到结果。

然后,自然就是控制器了。

Controller和日志使用

Controller就是很简单的了,不需要多说。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

这里还加了一个日志,是为了方便发布后查看日志,所以添加了NLog来输出日志。

添加一个nlog.config,内容大致如下。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

然后在Program添一行使用NLog的代码。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

运行效果

发布之后,可以看到Eureka上面已经成功注册了我们的这个ClientTest服务

如何将HttpClientFactory与Steeltoe结合来完成服务发现

其中,上图两个箭头的地方就是我们用到的服务,CLIENTTEST就是我们刚才发布的。BSERVICETEST是另一个测试服务。

CLIENTTEST就是会调用BSERVICETEST这个测试服务拿数据。

下面请求看看效果。

如何将HttpClientFactory与Steeltoe结合来完成服务发现

从动图来看,是已经达到预期了,由于BSERVICETEST有两个实例,所以也可以看到上面的结果是,两个实例在随机返回结果。

最后看看日志

如何将HttpClientFactory与Steeltoe结合来完成服务发现

请求也确实是到了我们的BSERVICETEST,而不是直接通过这个service的直接地址去访问的。

关于“如何将HttpClientFactory与Steeltoe结合来完成服务发现”就介绍到这了,更多相关内容可以搜索亿速云以前的文章,希望能够帮助大家答疑解惑,请多多支持亿速云网站!

推荐阅读:
  1. sparkSQL来完成对Hive的操作
  2. hive 与 hbase 结合

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

httpclientfactory

上一篇:webgl中影像加载的示例分析

下一篇:springboot整合quartz定时任务框架的方法是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》