上篇讲了spring cloud注册中心及客户端的注册,所以这篇主要讲一下服务和服务之间是怎样调用的

不会搭建的小伙伴请参考我上一篇博客:idea快速搭建spring cloud-注册中心与注册

基于上一篇的搭建我又自己搭建了一个客户端微服务:

所以现在有两个微服务,我们所实现的就是微服务1和微服务2之间的调用

注册中心就不用多说了,具体看一下两个微服务

application.yml配置也不用说了,不知道怎么配置的请参考我上篇博客

在project-solr中的constroller中:

@RestController//这里使此Constroller中所有的方法返回的不是页面
public class SolrSearchConstroller {@RequestMapping("/SolrSearch")public String SolrSearch(){return "这里是Solr";}}

这里是为了让另一个服务调用

在另一个微服务project-shopping-mall 启动类中,我们 必须定义一个方法:

@SpringBootApplication
@EnableDiscoveryClient //表示eureka客户端
public class ShoppingMallProvider {@Bean@LoadBalanced//在注册中心里进行查找微服务,负载均衡public RestTemplate restTemplate(){RestTemplate restTemplate=new RestTemplate();return  restTemplate;}public static void main(String[] args) {SpringApplication.run(ShoppingMallProvider.class,args);}
}

然后在project-shopping-mall里的Controller中调用project-solr中的constroller:

@Controller
public class PageController {@Autowiredprivate RestTemplate restTemplate;@RequestMapping("/toIndex")public String toIndex(Model model){String msg=restTemplate.getForEntity("http://project-solr/SolrSearch",String.class).getBody();//project-solr是调用注册中心里的名字model.addAttribute("msg",msg);return "/index";}
}

这里的project-solr是配置里每个服务注册到注册中心的名字,根据名字调用服务的ip地址,可以实现动态微服务调用效果,它不会因为更换电脑而出错

下面接着建设页面,这里我用的是thymeleaf组件

我们先在build.gradle中添加依赖:

//thymeleaf组件compile  'org.springframework.boot:spring-boot-starter-thymeleaf'

然后新建默认的目录:

这里必须新建templates包,因为是默认的目录

然后index.html中:

运行:

成功!

下面简单的说一下spring cloud eureka注册中心的自我保护机制

优点:当服务与注册中心由于某个原因断开的时候,服务与服务之间还可以连接,这时候eureka不会立刻清理,依旧会对改微服的信息进行保存。

缺点:当服务与注册中心由于某个原因断开的时候,服务与服务之间也不可以连接,这时候可能会带坏其他服务器。

当然是优点大于缺点的

那eureka注册中心是怎么知道微服务还存活的呢?

其实每个服务每分钟都会对注册中心进行心跳,而注册中心会接受心跳,若注册中心没有接受到心跳则会认为该服务死亡

官方对于自我保护机制的定义:eureka官方自我保护机制

转载于:https://www.cnblogs.com/itgaofei/p/9334741.html

spring cloud中微服务之间的调用以及eureka的自我保护机制相关推荐

  1. eureka自我保护时间_spring cloud中微服务之间的调用以及eureka的自我保护机制详解...

    上篇讲了spring cloud注册中心及客户端的注册,所以这篇主要讲一下服务和服务之间是怎样调用的 基于上一篇的搭建我又自己搭建了一个客户端微服务: 所以现在有两个微服务,我们所实现的就是微服务1和 ...

  2. Spring Cloud之微服务之间相互调用、如何让一个微服务调用另外一个微服务

    在使用微服务架构中,可能遇到一些业务情况会涉及服务之间相互调用,下面通过一个简单的demo给大家演示下,演示的是oms服务需要调用ump服务. 代码如下: 1.oms服务提供者 主要是这个注解: @E ...

  3. 《深入理解 Spring Cloud 与微服务构建》第八章 声明式调用 Feign

    ·# <深入理解 Spring Cloud 与微服务构建>第八章 声明式调用 Feign 文章目录 一.Feign 简介 1.简介 2.工作原理 二.写一个 Feign 客户端 三.Fei ...

  4. 从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(三) (mini-cloud) 搭建认证服务(认证/资源分离版) oauth2.0 (中)

    本文承接上文<从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(三) (mini-cloud) 搭建认证服务(认证/资源分离版) oauth2.0 (上)> ...

  5. 基于Spring Boot和Spring Cloud实现微服务架构学习--转

    原文地址:http://blog.csdn.net/enweitech/article/details/52582918 看了几周spring相关框架的书籍和官方demo,是时候开始总结下这中间的学习 ...

  6. 基于 Spring Boot 和 Spring Cloud 实现微服务架构

    前言 首先,最想说的是,当你要学习一套最新的技术时,官网的英文文档是学习的最佳渠道.因为网上流传的多数资料是官网翻译而来,很多描述的重点也都偏向于作者自身碰到的问题,这样就很容易让你理解和操作出现偏差 ...

  7. 基于Spring Cloud实现微服务前后端系统

    基于Spring Cloud实现微服务前后端系统 1.使用的技术栈 2.项目架构图 3.系统各模块介绍 4.占用的端口 5.如何运行该系统? 6.系统特性 7.系统体验 8.系统截图 (架构升级)新版 ...

  8. 基于Spring Boot和Spring Cloud实现微服务架构学习

    目录 Spring 顶级框架 Spring cloud子项目 WHAT - 什么是微服务 微服务简介 微服务的具体特征 SOA vs Microservice HOW - 怎么具体实践微服务 客户端如 ...

  9. 干货|基于 Spring Cloud 的微服务落地

    转载自 干货|基于 Spring Cloud 的微服务落地 微服务架构模式的核心在于如何识别服务的边界,设计出合理的微服务.但如果要将微服务架构运用到生产项目上,并且能够发挥该架构模式的重要作用,则需 ...

  10. Spring Cloud构建微服务架构:服务容错保护(Hystrix依赖隔离)【Dalston版】

    前言 在上一篇<Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)>中,我们已经体验了如何使用@HystrixCommand来为一个依赖资源定义服务降级逻辑.实 ...

最新文章

  1. 【浙大网新图灵通讯】无废话简单高效C#编码规范20100611
  2. 使用gin和gorm框架完成的bubble小清单项目
  3. c#中如何实现拷贝对象
  4. hadoop上lzop的安装
  5. udp协议服务器客户端流程图,UDP 协议通信服务器端客户端.doc
  6. 别太单纯,也别太不单纯
  7. 设置韩澳大利亚sinox弄winxp清除字体和界面美观
  8. SPLUNK 安装配置及常用语法
  9. 查询字符串中子字符串所有出现位置
  10. 我的世界手机版javaui材质包_我的世界手机版大乱斗卡比模组
  11. 前端HTML学习之案例--学生信息表
  12. 2022新版小额借贷系统源码+新增APP下载页面/内附教程
  13. 学历真的重要吗?当然非常非常非常重要。
  14. 在android studio中启动模拟器的时候报错...keeps shopping
  15. 可以用云服务器挂机传奇吗,蜂窝云挂机划算吗 游戏蜂窝云挂机怎么用
  16. 谷歌动态验证码二次验证ssh
  17. IT168 CIO频道11月28日至12月01日文章精选
  18. 全面了解ADSL/Cable共享路由器
  19. npm install -D 和-S的意思
  20. 山东大学数据结构课程设计实验五(低风险出行系统)

热门文章

  1. hdoj1000解题报告
  2. 关于Sliverlight的一些问题
  3. 艾伟:C#类和接口、虚方法和抽象方法及值类型和引用类型的区别
  4. 2006年博客之星(小废物点评版)
  5. hikaripool信息_聊聊hikari连接池的fixed pool design
  6. springboot mybatis 事务_真香——Github上的优秀SpringBoot框架
  7. php框架启动过程,框架启动方式 - CrossPHP 框架文档
  8. C#中@字符的三个作用
  9. 抽象高于实现 ——unity框架提取
  10. Redis 最大客户端连接数,你了解吗?