认识微服务二(微服务远程调用)
1.微服务结构
微服务这种方案需要技术框架来落地,全球的互联网公司都在积极尝试自己的微服务落地技术。在国内最知名的就是SpringCloud和阿里巴巴的Dubbo。
1.1微服务技术对比
2.企业需求
3. SpringCloud
-
SpringCloud 是目前国内使用最广泛的微服务框架。官网:https://spring.io/projects/spring-cloud SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的开箱即用体验:
-
SpringCloud与SpringBoot的版本兼容关系如下:
4.服务拆分及远程调用
4.1服务拆分
服务拆分注意事项:
- 不同微服务,不要重复开发相同业务
- 微服务数据独立,不要访问其它微服务的数据库
- 微服务可以将自己的业务暴露为接口,使其它微服务调用
总结
- 微服务需要根据业务模块拆分,做到单一职责,不要重复开发相同业务
- 微服务可以将业务暴露为接口,使其它微服务使用
- 不同微服务都应该有自己独立的数据库
4.2服务间调用
- 注册RestTemplate
/** * 创建RestTemplate并注入Spring容器 * @return */ @Bean public RestTemplate restTemplate(){ return new RestTemplate(); }
- 服务远程调用RestTemplate
package cn.itcast.order.service; import cn.itcast.order.mapper.OrderMapper; import cn.itcast.order.pojo.Order; import cn.itcast.order.pojo.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.client.RestTemplate; @Service public class OrderService { @Autowired private OrderMapper orderMapper; @Autowired private RestTemplate restTemplate; public Order queryOrderById(Long orderId) { // 1.查询订单 Order order = orderMapper.findById(orderId); // 2. 利用RestTemplate发起http请求,查询用户 // 2.1 url请求 String url="http://localhost:8081/user/"+order.getUserId(); // 2.2 发送http请求,实现远程调用 User user = restTemplate.getForObject(url, User.class); //3. 封装user到Order order.setUser(user); // 4.返回 return order; } }
总结
1.微服务调用方式
-
基于RestTemplate发起的http请求实现远程调用 http请求做远程调用是与语言无关的调用,只要知道对方的ip、端口、接口路径、请求参数即可。
下一篇:
服务的拆分和远程调用