博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring cloud中微服务之间的调用以及eureka的自我保护机制
阅读量:7221 次
发布时间:2019-06-29

本文共 2147 字,大约阅读时间需要 7 分钟。

我自己搭建了一个客户端微服务:

spring cloud中微服务之间的调用以及eureka的自我保护机制
所以现在有两个微服务,我们所实现的就是微服务1和微服务2之间的调用

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

spring cloud中微服务之间的调用以及eureka的自我保护机制
在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:

@Controllerpublic class PageController {    @Autowired    private 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'

然后新建默认的目录:

spring cloud中微服务之间的调用以及eureka的自我保护机制
这里必须新建templates包,因为是默认的目录

然后index.html中:

spring cloud中微服务之间的调用以及eureka的自我保护机制
运行:
spring cloud中微服务之间的调用以及eureka的自我保护机制
成功!

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

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

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

当然是优点大于缺点的

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

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

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

感兴趣可以加Java架构师群获取Java工程化、高性能及分布式、高性能、深入浅出。高架构。性能调优、Spring,MyBatis,Netty源码分析和大数据等多个知识点高级进阶干货的直播免费学习权限 都是大牛带飞 让你少走很多的弯路的 群..号是:855801563 对了 小白勿进 最好是有开发经验

注:加群要求

1、具有工作经验的,面对目前流行的技术不知从何下手,需要突破技术瓶颈的可以加。

2、在公司待久了,过得很安逸,但跳槽时面试碰壁。需要在短时间内进修、跳槽拿高薪的可以加。

3、如果没有工作经验,但基础非常扎实,对java工作机制,常用设计思想,常用java开发框架掌握熟练的,可以加。

4、觉得自己很牛B,一般需求都能搞定。但是所学的知识点没有系统化,很难在技术领域继续突破的可以加。

5.阿里Java高级大牛直播讲解知识点,分享知识,多年工作经验的梳理和总结,带着大家全面、科学地建立自己的技术体系和技术认知!

转载于:https://blog.51cto.com/13981400/2329661

你可能感兴趣的文章
linux中断申请之request_threaded_irq 【转】
查看>>
3、使用Lucene实现千度搜索
查看>>
单链表逆序的几种方法
查看>>
Hardwood Species
查看>>
android 项目中log信息的正确处理
查看>>
C# 定时器运用
查看>>
【转载】NIO客户端序列图
查看>>
Maven单元测试报告及测试覆盖率
查看>>
做开发的目的是为了什么
查看>>
怎样为virtualbox添加新的分辨率
查看>>
HDU 1853Cyclic Tour(网络流之最小费用流)
查看>>
网络通信分享(二):外网ip和内网ip
查看>>
phpstudy2016最新版本mysql无法使用innodb的问题解决
查看>>
手动挡C1驾驶学车@长建驾校
查看>>
git fetch 拉取而不合并
查看>>
Node+Express+node-mysql 实战于演习 全套mysql(增删改查)
查看>>
EHcache经典配置
查看>>
深入解析Java中的装箱和拆箱
查看>>
Power Gating的设计(模块二)
查看>>
Unity3D 之3D游戏角色控制器运动
查看>>