(更新时间)2021年6月3日 商城高并发秒杀系统(.NET Core版) 27-性能优化-事件总线的使用(流量削峰)

举报
愚公搬代码 发表于 2021/10/19 01:26:06 2021/10/19
【摘要】 一:相关依赖包 DotNetCore.CAP DotNetCore.CAP.Dashboard DotNetCore.CAP.InMemoryStorage DotNetCore.CAP.Kafka D...

一:相关依赖包

DotNetCore.CAP
DotNetCore.CAP.Dashboard
DotNetCore.CAP.InMemoryStorage
DotNetCore.CAP.Kafka
DotNetCore.CAP.MySql
DotNetCore.CAP.RabbitMQ

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

配置

// 8、添加事件总线cap
services.AddCap(x =>
{
    // 8.1 使用内存存储消息(消息发送失败处理)
    //x.UseInMemoryStorage();
    // 8.2 使用EntityFramework进行存储操作
    x.UseEntityFramework<SeckillAggregateServicesContext>();
    // 8.3 使用sqlserver进行事务处理
     x.UseMySql(Configuration.GetConnectionString("DefaultConnection"));
    // 8.4 使用RabbitMQ进行事件中心处理
    x.UseRabbitMQ(rb =>
    {
        // rb.HostName = "localhost"; // 本地主机
        //rb.HostName = "172.18.0.3";// 远程主机
        rb.HostName = "10.96.0.3";// K8s集群service
        rb.UserName = "guest";
        rb.Password = "guest";
        rb.Port = 5672;
        rb.VirtualHost = "/";
    });
	// 7.4 配置定时器尽早启动
    // x.FailedRetryInterval = 2;
    x.FailedRetryCount = 5; // 3 次失败 3分钟
    // 8.5添加cap后台监控页面(人工处理)
    x.UseDashboard();
});

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

生产者

/// <summary>
/// 3、创建订单(缓存库存扣减 + 消息队列)
/// </summary>
/// <param name="orderDto"></param>
[HttpPost]
public PaymentDto CreateOrder(SysUser sysUser, [FromForm] OrderPo orderPo)
{
    // 1、创建订单号
    string orderSn = OrderUtil.GetOrderCode();

    // 2、扣减库存(缓存)
    seckillStockCache.SubtractSeckillStock(orderPo.ProductId, orderPo.ProductCount);

    // 3、发送订单消息到rabbitmq
    SendOrderCreateMessage(sysUser.UserId, orderSn, orderPo);

    // 6、创建支付信息
    PaymentDto paymentDto = new PaymentDto();
    paymentDto.OrderSn = orderSn;
    paymentDto.OrderTotalPrice = orderPo.OrderTotalPrice;
    paymentDto.UserId = sysUser.UserId;
    paymentDto.ProductId = orderPo.ProductId;
    paymentDto.ProductName = orderPo.ProductName;

    return paymentDto;

}
/// <summary>
/// 3.1 发送创建订单消息
/// </summary>
/// <param name="ProductId"></param>
/// <param name="ProductCount"></param>
private void SendOrderCreateMessage(int userId,string orderSn, OrderPo orderPo)
{
    var configuration = new MapperConfiguration(cfg =>
    {
        cfg.CreateMap<OrderPo, Order>();
    });

    IMapper mapper = configuration.CreateMapper();

    // 2、设置订单
    Order order = mapper.Map<OrderPo, Order>(orderPo);
    order.OrderSn = orderSn;
    order.OrderType = "1";// 订单类型(1、为秒杀订单)
    order.UserId = userId;

    // 3、设置订单项
    OrderItem orderItem = new OrderItem();
    orderItem.ItemCount = orderPo.ProductCount;
    orderItem.ItemPrice = orderPo.OrderTotalPrice;
    orderItem.ItemTotalPrice = orderPo.OrderTotalPrice;
    orderItem.ProductUrl = orderPo.ProductUrl;
    orderItem.ProductId = orderPo.ProductId;
    orderItem.OrderSn = orderSn;

    List<OrderItem> orderItems = new List<OrderItem>();
    orderItems.Add(orderItem);
    order.OrderItems = orderItems;

    // 4、发送订单消息
    capPublisher.Publish<Order>("seckill.order", order);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63

消费者

/// <summary>
/// 创建订单
/// </summary>
/// <param name="Order"></param>
/// <returns></returns>
[NonAction]
[CapSubscribe("seckill.order")]
public ActionResult<Order> CapPostOrder(Order Order)
{
    // 1、创建订单
    Order.Createtime = new DateTime();
    OrderService.Create(Order);

    return CreatedAtAction("GetOrder", new { id = Order.Id }, Order);
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

二:优化效果

单台服务器:5000并发处理总时间12秒,0异常。
在这里插入图片描述

单台服务器:10000并发处理总时间18秒,0异常。
在这里插入图片描述
注释,这性能在数据库里,性能并不会高多少,需要把mq任务存储在缓存里,但会造成丢失,后续篇幅会说解决方案。

文章来源: codeboy.blog.csdn.net,作者:愚公搬代码,版权归原作者所有,如需转载,请联系作者。

原文链接:codeboy.blog.csdn.net/article/details/117512077

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。