学习材料
2024最新SpringCloud微服务开发与实战,java黑马商城项目微服务实战开发(涵盖MybatisPlus、Docker、MQ、ES、Redis高级等)
微服务
1.单体架构
2.JMeter
这其实在redis还是什么教程里面用过,不过忘记得差不多了。
复习一下。双击jmeter.bar开启。
3.微服务
5.服务拆分原则
拆分
1.商品相关拆分
数据库,然后就是各种文件拆分。
2.远程调用:RestTemplate
@RequiredArgsConstructor //必备参数构造函数
public class CartServiceImpl extends ServiceImpl<CartMapper, Cart> implements ICartService {
private final RestTemplate restTemplate; //final必须有构造函数
private void handleCartItems(List<CartVO> vos) {
// 1.获取商品id
Set<Long> itemIds = vos.stream().map(CartVO::getItemId).collect(Collectors.toSet());
// 2.查询商品
// List<ItemDTO> items = itemService.queryItemByIds(itemIds);
ResponseEntity<List<ItemDTO>> responce = restTemplate.exchange("http://localhost:8081/items?ids={ids}",
HttpMethod.GET,
null,
new ParameterizedTypeReference<List<ItemDTO>>() {
},
Map.of("ids", CollUtils.join(itemIds, ","))
);
if(!responce.getStatusCode().is2xxSuccessful()){
return;
}
List<ItemDTO> items = responce.getBody();
if (CollUtils.isEmpty(items)) {
return;
}
// 3.转为 id 到 item的map
Map<Long, ItemDTO> itemMap = items.stream().collect(Collectors.toMap(ItemDTO::getId, Function.identity()));
// 4.写入vo
for (CartVO v : vos) {
ItemDTO item = itemMap.get(v.getItemId());
if (item == null) {
continue;
}
v.setNewPrice(item.getPrice());
v.setStatus(item.getStatus());
v.setStock(item.getStock());
}
}
服务治理
RestTemplate不够好。
1.Nacos:部署,服务注册,服务发现
按照老师教的可能主机会访问不到,这时候需要关闭上网的一些工具。
配置多个实例,改端口的方法。
//开放对应端口
/sbin/iptables -I INPUT -p tcp --dport 9848 -j ACCEPT
服务发现
OpenFeign
1.自定义连接池
2.最佳实践
实例化:
日志