spring cloud中微服务之间的调用以及eureka的自…
2018-07-19 05:38:43来源:博客园 阅读 ()
上篇讲了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 { @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'
然后新建默认的目录:
这里必须新建templates包,因为是默认的目录
然后index.html中:
运行:
成功!
下面简单的说一下spring cloud eureka注册中心的自我保护机制
优点:当服务与注册中心由于某个原因断开的时候,服务与服务之间还可以连接,这时候eureka不会立刻清理,依旧会对改微服的信息进行保存。
缺点:当服务与注册中心由于某个原因断开的时候,服务与服务之间也不可以连接,这时候可能会带坏其他服务器。
当然是优点大于缺点的
那eureka注册中心是怎么知道微服务还存活的呢?
其实每个服务每分钟都会对注册中心进行心跳,而注册中心会接受心跳,若注册中心没有接受到心跳则会认为该服务死亡
官方对于自我保护机制的定义:eureka官方自我保护机制
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:枚举应用demo
下一篇:nohup 简单运用
- Spring系列.ApplicationContext接口 2020-06-11
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- 给你一份超详细 Spring Boot 知识清单 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 掌握SpringBoot-2.3的容器探针:实战篇 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash