四、应用通信

一、两种应用间的通信方式

两种应用间的通信方式

二、Spring Cloud中两种restful调用方式:(示例:用订单服务调用商品服务的接口)

Spring Cloud中两种restful调用方式

2.1 Spring Cloud中第一种restful调用方式:如下的示例,把商品服务理解为Server端,订单服务理解为Client端:用RestTemplate去调用另一个服务,这种的缺陷在于要硬编码url

订单调用商品服务

(1)商品服务定义为Server端

(2)新建ClientController,即Client端,此时Order去调用Product

2.2 Spring Cloud中第二种restful调用方式:通过loadBananceClient

!(1)查看Eureka中的服务,此时Product有两个服务

(2)通过serviceId来获取Host与Port

2.3 Spring Cloud中第三种restful调用方式:

(1)使用LocaBanance注解调用

(2)注入RestTemplate,然后应用/子url

三、负载均衡器:Ribbon

客户端向服务器,例如Eureka Server拉取可利用的服务,然后根据负载均衡策略直接命中 哪台服务器访问请求,整个过程都是在客户端进行的,SPring Cloud的客户端组件就是Ribbon组件,在二中实例中使用LoadBance注解或者LoadBananceClient,用到的就是Ribbon组件。添加LoadBalance注解后,Ribbon会基于某种规则自动实现负载均衡算法

Ribbon实现软负载均衡的核心

  • 通过ServerList发现所有可用的服务,通过ServerListFilter剔除无效的服务,然后通过IRule选择合适的服务
    流程

四、追踪负载均衡源码

五、使用Feign来实现应用间的通信

  • 1、在调用方引入依赖(这里就是Order)


    在调用方引入依赖
  • 2、在调用启动类上加注解


    在调用启动类上加注解
  • 3、定义调用哪些接口


    定义调用哪些接口
  • 4、使用服务端的方法


    使用

六、实战:在订单端调用商品的服务

6.1 开发商品的业务

商品端开发服务

6.2订单端调用

在order Client端定义接口

6.3调用接口

调用Product的方法

七、扣库存

在Product中定义实现,然后在Order服务中使用

八、解决问题:虽然实现了功能,在订单中调用商品服务,但是还是有如下的问题

8.1 服务端(Product暴漏了服务端的实体类(ProductInfo),这在远程调用里是不被允许的

服务端(Product暴漏了服务端的实体类(ProductInfo))

8.2 客户端重复定义服务端的类(客户端调用服务端,客户端需要依赖服务端的部分类,之前的解决方案是重复定义一遍,这是十分不好的。对象属于哪个服务就在哪个地方定义)

ProductInfo实际上是服务端的类,这里为了实现业务重复定义

8.3为了使用FeignClient,将服务端的接口定义在客户端里。这显然是不合理的。服务端应该定义接口,客户端直接调用即可。

8.4为了解决如上的问题,将服务端抽象为三个模块。

如下三个模块
  • productServer:所有的业务逻辑,Controller、Service
  • productClient:对外暴漏的接口
  • productCommon:被外部服务调用也会被自己调用的对象。


    模块的依赖关系

    九、异步服务调用

异步服务调用

常见的消息中间件

十、RabbitMQ的安装:在Docker中安装

十一、微服务和容器:天生的一对

天生一对

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

推荐阅读更多精彩内容

  • 掌执虎符铜砭 挥洒旷世奇才 胸怀乾坤万里 放眼无限未来 吾自与恩师广东一别,已两月有余,其间悉闻恩师夙兴夜寐传播砭...
    侍卫长阅读 6,666评论 3 35
  • 大众印象中的网红就是拥有淘宝店、长着锥子脸、嫁给富二代的网络红人。她们有着类似的外貌,浓妆艳抹,又经过美图磨皮以及...
    火迅云阅读 557评论 0 1
  • 两眼朦胧 渐行渐远渐无影 心中触觉,亦或是不一样的眼神另一番滋味 重要 重要亦或平淡 无法思索那片刻,因为根本没有...
    伈堇阅读 106评论 1 1
  • 在你的光辉中,我学会如何爱。在你的美中,我学会写诗。你在我的胸臆中起舞, 别人看不见你,...
    悦读漫笔阅读 420评论 0 1
  • 作业:二选一 一、请大家今天晚上就给自己做一个情绪按摩,做完之后,写下自己的心情和感受。 二、请大家参照原文写自己...
    MASTERJIANG阅读 155评论 0 0