欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

spring cloud eureka微服务之间的调用详解

时间:2021-04-03 07:47:29|栏目:JAVA代码|点击:

微服务之间的调用如何实现

首先 你需要两个或以上的微服务模块 至于怎么创建可以参考我上一篇博客 spring cloud eureka注册中心

如果想在页面显示 那么需要先加上

compile 'org.springframework.boot:spring-boot-starter-thymeleaf'

这个thymeleaf依赖 springboot推荐使用thymeleaf模板 它的最大好处就是原型即是模板 后缀是html

html文件 需要放在resources/templates文件夹下 因为thymeleaf自动配置的就是这个地址 当然也可以自己改

还需要配置一个属性

spring:
 thymeleaf:
  cache: false #开发时关闭缓存 否则无法看到实时页面

然后在html页面加上这个

就可以使用thymeleaf模板了

然后在消费端的启动类中 加上此方法

@Bean // 自动扫描
@LoadBalanced //这个注解的意思是在启动时先加载注册中心的域名列表 
public RestTemplate restTemplate() //这个方法用来发http请求
{
RestTemplate restTemplate=new RestTemplate();
return restTemplate;
}

看一下controller中的代码

@Autowired
private RestTemplate restTemplate; 
@RequestMapping(value = "index")
public String toIndex(Model model){
String msg=restTemplate.getForEntity("http://PROJECT-POPPY-SOLR/search",String.class).getBody(); 
model.addAttribute("msg",msg);
return "index";
}

它的getForEntity方法中 传入的想要调用的方法以及它所在的地址 注意 这里不能直接写ip地址 必须写往注册中心注册过之后的项目名 要想直接写项目名必须在启动类上面的方法中加上@LoadBalaced注解

否则ip地址如果发生变化 就需要更改 特别麻烦 作为一个优秀的程序员 当然是不能这么干的

然后把它放到model中发到页面 就可以调用另一个微服务的方法 实现了微服务间的调用

还有一个调用的方法是feign 以后会讲解

上一篇:Springboot解决ajax+自定义headers的跨域请求问题

栏    目:JAVA代码

下一篇:Spring中使用atomikos+druid实现经典分布式事务的方法

本文标题:spring cloud eureka微服务之间的调用详解

本文地址:http://www.codeinn.net/misctech/93737.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有