电商的秒杀和抢购,对程序员来说,都不是一个陌生的东西。然而,从技术的角度来说,这对于Web系统是一个巨大的考验。当一个Web系统,在一秒钟内收到数以万计甚至更多请求时,系统的优化和稳定至关重要。

我们直接将请求放入队列Queue中的,采用FIFO(First Input First Output,先进先出),这样的话,我们就不会导致某些请求永远获取不到锁。这里有点强行将多线程变成单线程的感觉。

秒杀看似简单,但是可能会存在两个问题:高并发和超卖

高并发:比较火秒杀活动同时参与秒杀人数都是10w+的,如此之高的秒杀人数对于网站架构从前到后都是一种考验。

超卖:秒杀商品都会有固定的数量,如何避免成功下订单买到商品的人数不超过商品数量的上限,这是每个抢购活动都要面临的一大难题。

此代码简单说明问题,例如有10万个人秒杀10个商品,我们定义队列queueAll 存放并发的10万人,queueCur存放已经抢到的10个人

        private static int cnt =10;
private static Queue<string> queueAll = new Queue<string>();
private static Queue<string> queueCur = new Queue<string>();

购买代码

        public RetData Buy(string uid)
{
queueAll.Enqueue(uid); if (queueAll.Count > cnt){
return new RetData {Code = -1, Msg = "商品抢光了", Cnt = 0};
}
queueCur.Enqueue(uid);
return new RetData { Code = 1, Msg = "恭喜已抢到", Cnt = cnt - queueAll.Count };
}
public class RetData
{
public int Code { get; set; }
public string Msg { get; set; }
public int Cnt { get; set; }
}

处理订单

        public static void HandleQueue()
{
Task.Factory.StartNew(() =>
{
while (true) if (queueCur.Count > 0) HandleOrder();
});
} public static void HandleOrder()
{
while (queueCur.Count != 0)
{
Console.WriteLine("处理用户订单中:" + queueCur.Dequeue());
}
}

Parallel模拟10万用户并发请求

            var tt = new ThreadPar();
Parallel.For(0, 100000, (t, state) =>
{
var uid = "用户" + t;
var x = tt.Buy(uid);
if (x.Code == -1)
{
Console.WriteLine(uid + ":" + x.Msg);
//state.Break();
}
else
Console.WriteLine(uid + ":" + x.Msg + "还剩下:" + x.Cnt + "件");
});

处理中,由于数据太多看不到谁抢到了商品,后面注释了抢不到的输出

用户0、1、75000、50000、50001、50002 、50003 、50004、25000、75001 这10位抢到了商品,其他人都没有抢到,

全部代码示例:

    public class ThreadPar
{
private static int cnt =;
private static Queue<string> queueAll = new Queue<string>();
private static Queue<string> queueCur = new Queue<string>();
//private static object ol = new object(); static ThreadPar()
{
HandleQueue();
} public RetData Buy(string uid)
{
queueAll.Enqueue(uid); if (queueAll.Count > cnt){
return new RetData {Code = -, Msg = "商品抢光了", Cnt = };
}
queueCur.Enqueue(uid);
return new RetData { Code = , Msg = "恭喜已抢到", Cnt = cnt - queueAll.Count };
}
public class RetData
{
public int Code { get; set; }
public string Msg { get; set; }
public int Cnt { get; set; }
}
public static void HandleQueue()
{
Task.Factory.StartNew(() =>
{
while (true) if (queueCur.Count > ) HandleOrder();
});
} public static void HandleOrder()
{
while (queueCur.Count != )
{
Console.WriteLine("处理用户订单中:" + queueCur.Dequeue());
}
} }
    class Program
{
static void Main()
{
ThreadBuy(); Console.WriteLine("----------操作完成----------");
Console.ReadKey();
} //秒杀
static void ThreadBuy()
{
System.Threading.Thread.Sleep();
var tt = new ThreadPar();
Parallel.For(, , (t, state) =>
{
var uid = "用户" + t;
var x = tt.Buy(uid);
if (x.Code == -)
{
Console.WriteLine(uid + ":" + x.Msg);
//state.Break();
}
else
{
Console.WriteLine(uid + ":" + x.Msg + "还剩下:" + x.Cnt + "件");
} }); } }

控制台程序

C#队列Queue实现一个简单的电商网站秒杀程序的更多相关文章

  1. 使用队列queue实现一个简单的生产者消费者模型

    一.生产者消费者模型 我们去超市商店等地购买商品时,我们大部分人都会说自己是消费者,而超市的各大供货商.工厂等,自然而然地也就成了我们的生产者.如此一来,生产者有了,消费者也有了,那么将二者联系起来的 ...

  2. 用JS做一个简单的电商产品放大镜功能

    使用js制作一个简单的产品放大图 购物网站的产品页经常会放有一个产品展示图区.该图区有一个功能就是产品图的放大功能,移动左侧的焦点区域,可以放大细节部分观看,详情如下图.实现该功能的方法也非常简单. ...

  3. PHP大型电商网站秒杀思路

    秒杀/抢购 技术:高可用,高并发 市场:用户体验,曝光度,促销 秒杀放单独服务器,这样即使崩溃不影响网站其他功能. 高可用:双活. 高并发:负载均衡,安全过滤. 阿里云:云监控 分流,CDN加速 业务 ...

  4. [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(二)

    一步步打造一个简单的 MVC 电商网站 - BooksStore(二) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore 前: ...

  5. [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(三)

    一步步打造一个简单的 MVC 电商网站 - BooksStore(三) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...

  6. [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(四)

    一步步打造一个简单的 MVC 电商网站 - BooksStore(四) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...

  7. [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(一)

    一步步打造一个简单的 MVC 电商网站 - BooksStore(一) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...

  8. [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(一) (转)

    http://www.cnblogs.com/liqingwen/p/6640861.html 一步步打造一个简单的 MVC 电商网站 - BooksStore(一) 本系列的 GitHub地址:ht ...

  9. 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念

    一.前言     DDD(领域驱动设计)的一些介绍网上资料很多,这里就不继续描述了.自己使用领域驱动设计摸滚打爬也有2年多的时间,出于对知识的总结和分享,也是对自我理解的一个公开检验,介于博客园这个平 ...

随机推荐

  1. HTML5 学习01——浏览器问题、新元素

    Internet Explorer 浏览器问题 问题:Internet Explorer 8 及更早 IE 版本的浏览器不支持HTML5的方式. <!--[if lt IE 9]> < ...

  2. 【性能提升神器】Covering Indexes

    可能有小伙伴会问,Covering Indexes到底是什么神器呢?它又是如何来提升性能的呢?接下来我会用最通俗易懂的语言来进行介绍,毕竟不是每个程序猿都要像DBA那样深刻理解数据库,知道如何用以及如 ...

  3. iOS:解决UITextView自适应高度粘贴大量文字导致显示不全的问题

    一.描述 在UITextView输入框中粘贴大量的文字时,UITextView内容自适应高度计算出现误差,导致整块文字上移消失. 二.方案 在UITextView文字改变的监听中添加如下方法即可. [ ...

  4. iOS:类似于网易云音乐的刷新条目显示弹框

    一.介绍 在app中使用刷新控件或者第三方刷新库是最常见的功能,在请求服务器时,获取数据的过程是处于不可见状态的,那么通过这个刷新状态可以给用户以直观的感受,这是增强用户体验的一个相当好的方法.我个人 ...

  5. [rtsp]海康IPC监控摄像头远程外网监控配置(DDNS)

        本来这个DDNS服务正是我想要的,但是配置了之后海康提示不再提供这个服务了,以后统一使用萤石云了,看来有必要去学习下萤石开放平台的api,看都提供哪些服务. 海康威视网络摄像机出厂的默认IP地 ...

  6. SpringBoot企业级框架

    Zebra 微服务框架 springBoot GitHub地址:https://github.com/ae6623/Zebra OSCGit地址:http://git.oschina.net/ae66 ...

  7. 自动化运维之PSSH

    1.PSSH简介 PSSH提供OpenSSH和相关工具的并行版本.包括pssh,pscp,prsync,pnuke和pslurp.该项目包括psshlib,可以在自定义应用程序中使用. pssh是py ...

  8. easyui combox 手动添加项

    $('#comzwcf').combobox({ valueField: 'id', textField: 'text', }); $.ajax({ url: '/Provider/HandlerIr ...

  9. 关于python单例的常用几种实现方法

    这两天在看自己之前写的代码,所以正好把用过的东西整理一下,单例模式,在日常的代码工作中也是经常被用到, 所以这里把之前用过的不同方式实现的单例方式整理一下 装饰器的方式 这种方式也是工作中经常用的一种 ...

  10. Xilinx的ISE14.7和PlanAhead与win10系统的兼容性问题解决方案

    Xilinx的ISE14.7和PlanAhead与win10系统的兼容性问题解决方案 2018年07月03日 18:27:57 feq123 阅读数:4495   今天在新电脑的win10系统上安装I ...