SpringCloud学习记录|day3

发布于:2024-10-08 ⋅ 阅读:(190) ⋅ 点赞:(0)

学习材料

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.最佳实践

在这里插入图片描述
在这里插入图片描述
实例化:
在这里插入图片描述
日志
在这里插入图片描述
在这里插入图片描述

作业


网站公告

今日签到

点亮在社区的每一天
去签到