学习材料
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.最佳实践

 
 实例化:
 
 日志
 
 

















