利用Spring Cloud实现微服务(七)- 内部调用

1. 微服务之间内部调用实现方法介绍

系列三业务领域驱动微服务设计的文章中,我们初步划分了三个领域:身份认证限界上下文、打车管理限界上下文、运营报表限界上下文。其中运营报表限界上下文是打车管理上下文的下游。这意味着在落地中,运营报表微服务要调用打车管理微服务提供的接口,来统计业务数据,生成运营报表,运营报表微服务是打车管理微服务的内部消费者。


在微服务的开发中,我们还会碰到很多微服务之间内部相互调用的情况,特别是对数据服务的调用。在Spring Cloud中,有两种方式可以,一种是使用RestTemplate,另一种是使用Feign框架。

RestTemplate调用另一个微服务的接口我们在系列五负载均衡的文章中已经讲过具体的实现,本章不再累述。

Feign是声明式Web服务客户端,所谓声明式,指的是在代码中,将要调用的其它内部微服务提供的Restful API声明为自己的接口,该接口使用FeignClient注解。声明后,在本微服务中就可以通过接口注入的方式消费其它微服务的提供的Restful API了。

Feign也内置有负载均衡Ribbon,会采用轮训式的负载均衡方式。

2. 代码实现及验证

本次代码实现模拟两个场景:通过Feign实现内部调用;通过Feign实现负载均衡的内部调用;

2.1 新建一个项目:

在start.spring.io里新建一个名为“reports”的项目,在依赖项里额外增加对feign的依赖,下载并将该项目导入到NetBeans里。

2.2 通过Feign实现内部调用

1) 在主程序除添加@EnableEurekaClient注解外,同时添加@EnableFeignClients注解。@EnableFeignClients注解用于开启Feign的功能

2)  配置Feign Clients项目的属性,端口设为2266,微服务的名称为reporting-service,reporting-service和其它微服务一样注册在端口号为1111的Eureka Server上。具体配置如下所示:

3) 在BOOKINGCAR-SERVICE微服务的OrderController包里,新建一个数据服务的接口getOrderName,该接口通过Order ID来获取订单名称

4) 在REPORTING-SERVICE项目下新建一个package,名为"com.accenture.j2c.bookingcar.reports.clientinterface",在该package下新建一个OrderClient接口,在该接口里会将BOOKINGCAR-SERVICE提供的getOrderName的restful API声明为REPORTING-SERVICE里的OrderClient接口里的一个方法。

具体实现可以分为两步:

第一步:通过FeignClient注解,首先到Eureka Server找到名字为“BOOKINGCAR-SERVICE"的微服务;

第二步:使用RequestMapping注解声明BOOKINGCAR-SERVICE微服务提供的getOrderName的Restful API的入口, getOrderName的入口为”{BOOKINGCAR-SERVICE}/v1/order/name/{id}"。

代码如下:

5) 在REPORTING-SERVICE项目下新建一个Rest Controller的package,名字为“com.accenture.j2c.bookingcar.reports.controller”,在该包下新建一个OrderController类,注入REPORTING-SERVICE下的OrderClient接口,新建一个feign_getOrderName接口,在该接口里通过调用OrderClient接口中的getOrderName的方法实现对BOOKINGCAR-SERVICE微服务中getOrderName的Restful API接口的调用,代码如下:

6) 验证

启动Eureka Server, BOOKINGCAR-SERVICE, REPORTING-SERVICE,打开Eureka注册中心,显示如下:

BOOKINGCAR-SERVICE和REPORTINGCAR-SERVICE这两个微服务都已经启动,其中BOOKINGCAR-SERVICE的接口为2227,REPORTING-SERVICE微服务的端口为2266。

点击BOOKIGNCAR-SERVICE后提供的链接,输入请求参数“v1/order/name/1",获得id为1的订单名称

点击REPORTING-SERVICE后的提供的链接,输入请求参数“v1/order/1",结果为:

我们发现REPORTING-SERVICE里的结果同BOOKINGCAR-SERVICE里的结果保持一致,这说明了REPORTING-SERVICE已经能调用另一微服务BOOKINGCAR-SERVICE里开放的接口。

2.3 通过Feign实现内部调用的负载均衡

1) 在REPORTING-SERVICE的"com.accenture.j2c.bookingcar.reports.clientinterface"包下,新建一个接口LBTestClient,在该接口里会将BOOKINGCAR-SERVICE提供的findServicePort的restful API声明为REPORTING-SERVICE里的LBTestClient接口里的一个方法。BOOKINGCAR-SERVICE里的findServiceReport接口在之前已经定义好,本次示例继续使用该接口:

REPORTING-SERVICE里的LBTestClient接口声明如下:

2) 在REPORTING-SERVICE里的“com.accenture.j2c.bookingcar.reports.controller“包下,新建一个类LBTestController,在该控制器类中注入LBTestClient接口,新建一个feign_getPort接口,在该接口里通过调用LBTestClient接口中的方法实现对BOOKINGCAR-SERVICE微服务中findServicePort的Restful API接口的调用,代码如下:

3) 验证:

重新启动一个端口号为2228的BOOKINGCAR-SERVICE微服务实例,启动后,在EUREKA注册中心可以看到BOOKINGCAR-SERVICE有两个实例在运行,端口号分别为2227和2228,见下图:

点击REPORTING-SERVICE后提供的链接,输入负载均衡验证的参数"v1/port",运行后显示结果如下:

再次运行,结果如下:

上面结果验证了Feign内置的Ribbon负载均衡已经发挥作用

3. 总结

 在Spring Cloud里,微服务之间的相互调用可以通过RestTemplate和Feign两种方式实现。Feign同时内置了Ribbon负载均衡,代码更加清晰,推荐使用Feign来实现微服务间的相互调用。


代码:https://github.com/shuxingliu/microservices

利用Spring Cloud实现微服务(六)- 服务网关

利用Spring Cloud实现微服务(五)- 负载均衡

利用Spring Cloud实现微服务(四)- 微服务实现与注册

利用Spring Cloud实现微服务(三)- 业务领域驱动微服务设计

利用Spring Cloud实现微服务(二)--领域驱动设计

利用Spring Cloud实现微服务(一):Eureka服务器

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,783评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,360评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,942评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,507评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,324评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,299评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,685评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,358评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,652评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,704评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,465评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,318评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,711评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,991评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,265评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,661评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,864评论 2 335

推荐阅读更多精彩内容