.Net Redis的秒杀Dome和异步执行

news/2024/5/5 18:43:36/文章来源:https://blog.csdn.net/weixin_45381269/article/details/127069242

1.先到官网下载Redis部署好 Redis 教程 | 菜鸟教程

2.创建一个上游业务项目(这里用控制台项目了,Framwork4.7.2)

NuGet包下载SerivceStack.Redis

 创建一个RedisMessgaeQueue(Redis连接帮助类)

using ServiceStack.Redis;
using System;namespace RedisUP
{class RedisMessgaeQueue:IDisposable{private RedisClient redisClient { get; }/// <summary>/// 构造函数/// </summary>/// <param name="redisHost"></param>public RedisMessgaeQueue(string redisHost){redisClient = new RedisClient(redisHost);}/// <summary>/// 入队/// </summary>/// <param name="QKey"></param>/// <param name="QMessgae"></param>/// <returns></returns>public long EnQueue(string QKey,string QMessgae) {//1.编码字符串byte[] bytes = System.Text.Encoding.UTF8.GetBytes(QMessgae);//2.redis消息队列入队long count = redisClient.LPush(QKey, bytes);return count;}/// <summary>/// 出队(非阻塞)==拉/// </summary>/// <param name="QKey"></param>/// <returns></returns>public string DeQueue(string QKey){//1.redis消息出队byte[] bytes = redisClient.RPop(QKey);string QMessgae = null;//2.字节转stringif (bytes==null){Console.WriteLine("队列中数据为空");}else{QMessgae = System.Text.Encoding.UTF8.GetString(bytes);}return QMessgae;}/// <summary>/// 出队(阻塞)==推/// </summary>/// <param name="QKey"></param>/// <param name="timeSpan">阻塞超时时间(根据时间自动解除阻塞)</param>/// <returns></returns>public string BDeQueue(string QKey,TimeSpan? timeSpan){//1.redis消息出队string QMessgae = redisClient.BlockingPopItemFromList(QKey, timeSpan);return QMessgae;}/// <summary>/// 获取队列数/// </summary>/// <param name="QKey">队列key</param>/// <returns></returns>public long GetQueueCount(string QKey){//1.获取队列数return redisClient.GetListCount(QKey);}/// <summary>/// 关闭redis/// </summary>public void Dispose() { //1.关闭redisredisClient.Dispose();}}
}

Program

using System;
using System.Threading;namespace RedisUP
{class Program{static void Main(string[] args){using (RedisMessgaeQueue redisClient = new RedisMessgaeQueue("localhost:6379")){Console.WriteLine("秒杀上游消息....");while (true){string rm_sum=redisClient.BDeQueue("rm_skills", TimeSpan.FromSeconds(60));Console.WriteLine("************************开始秒杀下游业务调用****************************");//消费秒杀上游消息//秒杀业务处理HandlerRequest(rm_sum);Console.WriteLine("************************开始秒杀业务调用完成****************************");}}}/// <summary>/// 处理请求    /// </summary>/// <param name="requestCount"></param>public static void HandlerRequest(string requestCount){Thread.Sleep(20);//创建订单Console.WriteLine("秒杀订单创建成功");//扣减库存Console.WriteLine("秒杀订单库存扣减生成");//扣减余额Console.WriteLine("用户余额扣减成功");Console.WriteLine($"处理的请求数:{requestCount}");}}
}

 3.创建一个下游业务项目(这里用控制台项目了,Framwork4.7.2)

 NuGet包下载SerivceStack.Redis

 创建一个RedisMessgaeQueue(Redis连接帮助类)

using ServiceStack.Redis;
using System;namespace RedisDown
{class RedisMessgaeQueue:IDisposable{private RedisClient redisClient { get; }/// <summary>/// 构造函数/// </summary>/// <param name="redisHost"></param>public RedisMessgaeQueue(string redisHost){redisClient = new RedisClient(redisHost);}/// <summary>/// 入队/// </summary>/// <param name="QKey"></param>/// <param name="QMessgae"></param>/// <returns></returns>public long EnQueue(string QKey,string QMessgae) {//1.编码字符串byte[] bytes = System.Text.Encoding.UTF8.GetBytes(QMessgae);//2.redis消息队列入队long count = redisClient.LPush(QKey, bytes);return count;}/// <summary>/// 出队(非阻塞)==拉/// </summary>/// <param name="QKey"></param>/// <returns></returns>public string DeQueue(string QKey){//1.redis消息出队byte[] bytes = redisClient.RPop(QKey);string QMessgae = null;//2.字节转stringif (bytes==null){Console.WriteLine("队列中数据为空");}else{QMessgae = System.Text.Encoding.UTF8.GetString(bytes);}return QMessgae;}/// <summary>/// 出队(阻塞)==推/// </summary>/// <param name="QKey"></param>/// <param name="timeSpan">阻塞超时时间(根据时间自动解除阻塞)</param>/// <returns></returns>public string BDeQueue(string QKey,TimeSpan? timeSpan){//1.redis消息出队string QMessgae = redisClient.BlockingPopItemFromList(QKey, timeSpan);return QMessgae;}/// <summary>/// 获取队列数/// </summary>/// <param name="QKey">队列key</param>/// <returns></returns>public long GetQueueCount(string QKey){//1.获取队列数return redisClient.GetListCount(QKey);}/// <summary>/// 关闭redis/// </summary>public void Dispose() { //1.关闭redisredisClient.Dispose();}}
}

Program

using System;namespace RedisDown
{class Program{static void Main(string[] args){CreateSkillOrder(5000);Console.ReadKey();}/// <summary>/// 秒杀方法/// </summary>/// <param name="RequestCount">请求的数量</param>public static void CreateSkillOrder(int RequestCount) {using (RedisMessgaeQueue redisClient = new RedisMessgaeQueue("localhost:6379")){int HandlerRequestCounts = 2000;//允许请求的数量for (int i = 0; i < RequestCount; i++){long count = redisClient.GetQueueCount("rm_skills");//当前的请求数量为多少if (count > HandlerRequestCounts)//判断当前的请求数量是否大于允许请求的数量{Console.WriteLine("系统繁忙请稍后....");}else{//当前请求数量小于允许请求数量,代表还能请求Console.WriteLine("入队成功");redisClient.EnQueue("rm_skills", i + "Test");}}}}}
}

启动下游服务

 ​​

启动上游服务

秒杀服务dome结束

4.异步执行

4.1先创建一个控制台FramWork项目RedisOne(命名随意)>NuGet包下载ServiceStack.Redis>添加RedisMessgaeQueue(Redis连接帮助类)>这个类代码在上面

Program

using System;namespace RedisOne
{class Program{static void Main(string[] args){using (RedisMessgaeQueue redisClient = new RedisMessgaeQueue("localhost:6379")){string order_sn = "123456";redisClient.EnQueue("Messgar1", order_sn);redisClient.EnQueue("Messgar2", order_sn);Console.WriteLine("写入成功");}Console.ReadKey();}}
}

4.2跟上面一样再创建两个控制台项目分别为Messgae1和Messgae2

4.3两个项目都NuGet包下载ServiceStack.Redis

4.4两个项目都添加RedisMessgaeQueue(Redis连接帮助类)>这个类代码在上面

Messgae1的Program

using System;namespace Messgae1
{class Program{static void Main(string[] args){using (RedisMessgaeQueue redisClient = new RedisMessgaeQueue("localhost:6379")){Console.WriteLine("Message1.....");while (true){string mesg1 = redisClient.BDeQueue("Messgar1", TimeSpan.FromSeconds(60));if (mesg1!=null){//消费Message1Console.WriteLine($"消费成功:{mesg1}");}else{Console.WriteLine($"消费失败!");}}}}}
}

 Messgae2的Program

using System;namespace Messgae2
{class Program{static void Main(string[] args){using (RedisMessgaeQueue redisClient = new RedisMessgaeQueue("localhost:6379")){Console.WriteLine("Message2.....");while (true){string mesg2 = redisClient.BDeQueue("Messgar2", TimeSpan.FromSeconds(60));if (mesg2 != null){//消费Message2Console.WriteLine($"消费成功:{mesg2}");}else{Console.WriteLine($"消费失败!");}}}}}}

4.5代码部署完成后分别给项目Messgae1,Messgae2,RedisOne重新生成

4.6生成完后打开Messgae1,Messgae2项目的路径>运行Messgae1.exe,Messgae2.exe

 运行

 4.7开启RedisOne.exe

 完结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_203655.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PCIe系列专题之三:3.0 数据链路层概述

一、故事前传 之前我们讲了对PCIe的一些基础概念作了一个宏观的介绍&#xff0c;了解了PCIe是一种封装分层协议&#xff08;packet-based layered protocol),主要包括事务层&#xff08;Transaction layer), 数据链路层&#xff08;Data link layer)和物理层&#xff08;Physi…

MySQL 常用数据类型说明

目录 MySQL中常用的数据类型 整型 整型声明 整型属性 整型的选择 浮点型 定点数类型 浮点数和定点数的区别 时间日期类型 DATE类型 TIME类型 DATETIME类型 YEAR类型 文本字符串 CHAR与VARCHAR类型 TEXT类型 ​编辑 枚举类型(ENUM) MySQL中常用的数据类型 数据类…

直播平台怎么搭建,实现js开光灯效果

直播平台怎么搭建,实现js开光灯效果<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>点击切换灯亮</t…

Spring容器与依赖注入(DI)

1 Spring框架简介 1.1 什么是Spring Spring框架是一个开源的轻量级的DI和AOP容器框架&#xff0c;致力于简化企业级应用开发&#xff0c;让开发者使用简单的Java Bean来实现从前只有EJB才能实现的功能。 1.2 为什么要使用Spring Spring堪称Java世界中最强大的框架&#xff0c;…

单调栈题目:柱状图中最大的矩形

文章目录题目标题和出处难度题目描述要求示例数据范围解法思路和算法代码复杂度分析题目 标题和出处 标题&#xff1a;柱状图中最大的矩形 出处&#xff1a;84. 柱状图中最大的矩形 难度 7 级 题目描述 要求 给定整数数组 heights\texttt{heights}heights 表示柱状图中…

正弦信号发生器的设计

目 录 1 引言 1 2 总体结构设计 2 2.1 单片机概述 2 2.1.1 单片机的发展 2 2.1.2 单片机的用途 3 2.2 系统设计的功能 3 2.3 波形发生和输出频率的方法 4 2.3.1 波形发生的方法 4 2.3.2 输出频率的方法 4 3 系统硬件设计 5 3.1 硬件电路芯片的选择 5 3.1.1 CPU芯片 AT89C51 5 3…

MyBatis中的复杂映射

上一章中实现的MyBatis对象映射较为简单&#xff0c;对象中的属性和数据库中的表字段是一一对应的&#xff08;无论数量和名称都完全一样&#xff09;&#xff0c;如果对象中的属性名和表中的字段名不一致怎么办&#xff1f;又或者Java对象中存在复杂类型属性&#xff08;即类似…

百分点数据科学产教融合计划继续扩大招募

从全球发展来看&#xff0c;数字经济已经成为重组全球要素资源、重塑全球经济结构、改变全球竞争格局的关键力量&#xff0c;是全球共同的发展战略。作为新经济中的数据科学&#xff0c;伴随社会各领域对数字人才需求的与日俱增&#xff0c;也成为了这一波科技革命中的人才竞争…

中国新出海故事:人、疫情与纽带

【潮汐商业评论/原创】 《枪炮、病菌与钢铁》中对人类社会发展的洞察与新千禧年发生了奇妙的呼应&#xff0c;战争、疫情成为了这十年的历史注脚&#xff0c;但时代的车轮总是滚滚向前的&#xff0c;新的世界版图里&#xff0c;全球化、数字化的浪潮构成了新世界跳动的脉搏&am…

第2章 ROS 通信机制 4 —— 常用命令

文章目录1 应用场景2 rosnode 功能包 plumbing_pub_sub编译执行3 rostopic 功能包 plumbing_pub_sub编译执行4 rosservice (服务通信) 功能包 plumbing_server_client编译执行5 rosmsg (话题通信) 功能包 plumbing_pub_sub编译执行6 rossrv (服务通信) 功能包 plumbing_server_…

常见网络知识面试题总结

&#x1f353;个人主页&#xff1a;个人主页 &#x1f352;系列专栏&#xff1a;C/C基础与进阶 &#x1f4ac;推荐一款模拟面试、刷题神器&#xff0c;从基础到大厂面试题&#x1f449;点击跳转刷题网站进行注册学习 目录 1、OSI七层模型与TCPIP四层模型是什么&#xff1f; 2…

核爆!字节跳动算法大佬手写1000页数据算法笔记:Github已标星79k

数据结构是什么 数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下&#xff0c;精心选择的数据结构可以带来更高的运行或者存储效率。数据结构往往同高效的检索算法和索引技术有关。 算法是什么 算法是对解题方案…

PC 端网页特效

一、元素偏移量 offset 系列 (一)offset 概述 1、offset 翻译过来就是偏移量,我们使用 offset 系列相关属性可以动态的得到该元素的位置(偏移)、大小等。 (1)获得元素距离带有定位父元素的位置; (2)获得元素自身的大小(宽度高度); (3)注意:返回的数值都不带单位…

使用polkadot.js在substrate frontier上安装ERC20token合约

使用polkadot.js在substrate frontier上安装ERC20token合约参考资料Substrate Frontier Node Template github.com/substrate-developer-hub/frontier-node-template frontier-node-template/examples/contract-erc20/truffle/contracts/MyToken.json安装ERC20 token合约 sourc…

SwiftUI AR教程之应用程序中使用 RealityKit 生成 3D 文本(教程含完整源码)

项目文件 基本设置 我们将从 Xcode 上的“增强现实应用程序”模板开始: 我使用 SwiftUI 作为界面,使用 Swift 作为语言,使用 RealityKit 作为内容技术: 您现在应该拥有基本的增强现实应用程序模板代码。 使用 RealityKit 生成 3D 文本网格 我们将向我们的项目添加一个函…

快速入门SSMS的使用

快速入门SSMS的使用1.Install SSMS2.Demo2.1 Export DDL2.2 XXXXX3.XXXX4.Waken1.Install SSMS 官方地址 SSMS Website: https://learn.microsoft.com/zh-tw/docs/. 也可以直接下载 Download Website: https://aka.ms/ssmsfullsetup.双击安装 要有电脑的管理员权限 快速启动…

springboot基于JAVA游戏周边商城设计与实现毕业设计源码261622

Springboot游戏周边商城的开发 摘 要 现今人们的生活方式逐渐丰富&#xff0c;电脑和网络已经融入了人们生活中的滴滴点点&#xff0c;无时不刻的影响着我们的日常生活&#xff0c;网络游戏已经进入到了大多数人的生活之中。在游戏的世界中人们会得到很多游戏商品&#xff0c;然…

死锁检测组件原理及代码实现

一、引言 所谓死锁&#xff0c;是指多个线程或进程各自持有某些资源&#xff0c;同时又等待着别的线程或进程释放它们现在所保持的资源&#xff0c;否则就不能向前推进。如下图&#xff1a;线程各自占有一把锁&#xff0c;还需要申请别的线程当前持有的锁&#xff0c;形成锁资…

Cisco简单配置(十四)—第一跳冗余协议—HSRP

为什么使用第一跳冗余 默认网关限制 如果路由器或路由器接口&#xff08;作为默认网关&#xff09;发生故障&#xff0c;配置该默认网关的主机将与外部网络隔离。在交换网络中&#xff0c;每个客户端仅收到一个默认网关。即使存在第二个路由可以从本地网段传输数据包&#xf…

微信小程序 java高校新生报到宿舍安排管理系统python php

将小程序权限按管理员和用户这两类涉及用户划分。 (a) 管理员&#xff1b;管理员使用本程序涉到的功能主要有&#xff1a;个人中心、宿舍管理、学生管理、宿舍安排管理、缴费信息管理、程序管理等功能 (b)用户进入程序前台可以实现首页、互助沟通、我的等功能 uni-app框架&…