一.微服务拆分的标准
1.什么时候拆
<1>项目完成后拆(先易后难)
<2>直接选择微服务架构(先难后易)
2.重要标准
低藕和,高内聚
3.拆分方法
<1>按业务拆分(横向拆分)/按功能拆分(纵向拆分)
<2>完全解耦/Maven聚合
二.微服务的拆分实践核心解决办法-----黑马商城购物车模块
在购物车模块中,我们需要调用商品模块的方法,我们如果直接引入对象会让我们的耦合度过高,所以我们通过网洛进行远程调用。
在单体架构中,我们通常通过Retrofit框架来实现,这里我们通过restTemplate来实现微服务中的远程调用
1.远程调用的实现
<1>restTemplate对象加入spring容器
@Configuration
public class RemoteCallConfig {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
<2>远程调用
// 2.TODO 查询商品 通过商品id查询商品
ResponseEntity<List<ItemDTO>> response = restTemplate.exchange("http://localhost:8081/items?ids={ids}",
HttpMethod.GET,
null,
new ParameterizedTypeReference<List<ItemDTO>>() {
},
Map.of("ids", CollUtil.join(itemIds, ",")));
if (!response.getStatusCode().is2xxSuccessful()){
return;;
}
List<ItemDTO> items = response.getBody();
if (CollUtils.isEmpty(items)) {
return;
}
三.注册中心优化远程调用
1.注册中心原理

服务调用者:消费者
当服务提供者初始化服务时,注册中心会自动登记该服务,当服务调用者需要调用某个服务时,
注册中心会将服务推送给服务调用者,服务调用者通过负载均衡的算法选取一个服务,然后像服务提供者发起调用请求。
当服务提供者的服务kill时怎么办呢?
注册中心通过心跳机制检测服务提供者的服务是否存活,当某个服务超过合理期限无法检测到时,注册中心会自动注销该服务,并立刻推送变更给订阅过该服务的服务调用者。
2.Nacos服务注册中心
1.部署Nacos
docker run -d \
--name nacos \
--env-file ./nacos/custom.env \
-p 8848:8848 \
-p 9848:9848 \
-p 9849:9849 \
--restart=always \
nacos/nacos-server:v2.1.0-slim
运行不起来就降低版本,是因为虚拟机分配的内存太小。
http://192.168.150.101:8848/nacos/
2.引入依赖
<!--nacos 服务注册发现-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
3.配置Nacos
spring:
application:
name: item-service # 服务名称
cloud:
nacos:
server-addr: 192.168.150.101:8848 # nacos地址