一.通过RestTemplate远程调用
restTemplate是springmvc自带的一个远程调用类,他的底层是用httpClient来发送远程请求的
1.在配置类中配置一个bean
@LoadBalanced是进行负载均衡的
@Configuration
public class UserConfigure {
//创建一个RestTemplate
@Bean
//对restTemplate进行负载均衡
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
2.在需要调用的controller中自动注入restTemplate
@Autowired private RestTemplate restTemplate;
3.在方法中写好需要发送的地址
@GetMapping("/book")
public String getBook(){
String url = "http://bookservice/book/";
return restTemplate.getForObject(url+"/1",String.class);
}
发送请求即可
二.通过Feign来实现远程调用
1.引入OpenFeign依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.在启动类上加上注解@EnableFeignClients
@EnableFeignClients
3.创建一个接口,作为客户端
@FeignClient("book-service")
public interface BookServiceClient {
/**
* 该方法是远程调用book-service的根据id查询书本
* @param id 书本id
* @return 以字符串返回书本信息
*/
@RequestMapping(method = RequestMethod.GET,value = "/book/{id}")
String getOneBookById(@PathVariable("id")Integer id);
}
注意:这里的@FeignClient中的服务名称需要和配置文件中的spring.application.name一致,否则会报远程调用找不到的错误,也可以自己指定url
@FeignClient(value="book-servcie",url="http://localhost:8082/book")
4.在controller中自动注入bookservice
@Resource
private BookServiceClient bookServiceClient;
5.在方法中调用即可
/**
* 测试feign远程调用
* @return
*/
@GetMapping("/feign")
public String testFeign(){
return bookServiceClient.getOneBookById(2);
}
feign自动实现了负载均衡