(更新时间)2021年6月3日 商城高并发秒杀系统(.NET Core版) 27-性能优化-事件总线的使用(流量削峰)
        【摘要】 
                    
                        
                    
                    一:相关依赖包 
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)