当前位置: 首页 > article >正文

SpringCloud学习记录|day3

学习材料

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

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

作业


http://www.kler.cn/news/336146.html

相关文章:

  • Disarmed by auto preflight disarming自动上锁
  • 基于SpringBoot+Vue+Uniapp的植物园管理小程序系统(2024最新,源码+文档+远程部署+讲解视频等)
  • ELK日志收集之ES的DSL查询语句
  • RabbitMQ 工作方式详解
  • 【Linux系统编程】第二十八弹---构建基础文件操作库与理解标准错误流(stderr)在C与C++中的应用
  • 无线通信系统设计:MATLAB的全面解决方案
  • Linux驱动开发——LED驱动开发
  • Observability:使用 OpenTelemetry 自动检测 Go 应用程序
  • R语言绘制面积图
  • 【git】main|REBASE 2/6
  • 【新进展】知识图谱+多智能体大模型
  • 15分钟学 Python 第41天:Python 爬虫入门(六)第二篇
  • 华为平板与非华为电脑多屏协同及Bug处理
  • 力扣203.移除链表元素
  • 每日学习一个数据结构-默克尔树(Merkle Tree)
  • CCF对泄露CSP-J/S2024题目处罚(河北、陕西)
  • win11/win10/windows下快安装并使用git
  • C0018.Clion中开发Qt界面时,利用MSVC编译器连接MySQL数据库的方法
  • 【PostgreSQL】提高篇——PostgreSQL 对 JSON 和数组的支持及其在数据建模中的应用
  • C++ 结构体(struct)