微服务架构是What??
微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。
每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。
每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
SpringCloud
SpringCloud更像是分布式微服务架构的一站式解决方案,是多种微服务架构落地技术的集合体,俗称微服务全家桶
其中包括了:服务注册与发现、服务调用、服务熔断、负载均衡、服务降级、服务消息队列、配置中心管、服务网关、服务监控、全链路追踪、自动化构建部署、服务定时任务调度操作
SpringCloud 技术栈
创建SpringCloud
通常由一个大的maven项目中包括子项目:
maven主项目:
springboot项目2(集成SpringCloud等jar包);
springboot项目2(集成SpringCloud等jar包);
当所有子项目组合起来就是SpringCloud;
SpringCloud项目的版本控制非常严苛。请依据版本来管理其他所依赖框架的版本
RestTemplate
- HttpClient 的实现接口
使用restTemplate访问restful接口非常的简单粗暴无脑
(url,requestMap,ResponseBean.class)这三个参数分别代表:
- REST请求地址
- 请求参数
- HTTP响应转换被转换成的对象类型
java
@Slf4j
@RestController
public class OrderController {
public static final String PAYMNT_URL = "http://localhost:8001";
@Resource
private RestTemplate restTemplate;
@GetMapping("/consumer/payment/create")
public CommonResult<Payment> create(Payment payment){
return restTemplate.postForObject(PAYMNT_URL+"/payment/create",payment,CommonResult.class);
}
@GetMapping("/consumer/payment/get/{id}")
public CommonResult<Payment> getPayment(@PathVariable("id") Long id){
return restTemplate.getForObject(PAYMNT_URL+"/payment/get/"+id,CommonResult.class);
}
}
踩坑
发送请求,提示请求成功
json
{
"code": 200,
"message": "插入数据库成功",
"data": 1
}
但是数据为回填为null
请注意在对数据库操作前,两个模块之间接收参数是否使用RequestBody注解接收了!
两模块之间接收消息走的是json,若不使用注解,将会造成数据丢失
java
@PostMapping("/create")
public CommonResult create(@RequestBody Payment payment){
int result = paymentService.create(payment);
log.info("********插入结果:"+result);
if (result>0){
return new CommonResult(200,"插入数据库成功",result);
}else
{
return new CommonResult(500,"插入数据库失败",null);
}
}