nodejs之简单的秒杀系统实现(mysql、redis、kafka、zookeeper、postman或docker)

nodejs之简单的秒杀系统实现(mysql、redis、kafka、zookeeper或docker)

一:环境

1.一台阿里云服务器
2.云服务器需要安装redis、kafka、mysql、zookeeper环境
3.一台本地电脑需要安装postman
注:kafka与zookeeper的安装和配置请参考:https://blog.csdn.net/wushichao0325/article/details/84993081 或者使用docker直接拉去镜像安装。

二:工具说明

1.postman:用于使用其中的(Run)实现并发测试
2.redis:用于存放商品信息,这里只创建一个counter字段,使用redis的命令set设置个初始值。100,即商品总量。模拟数据为:counter=100
3.kafka:结合zookeeper使用,将秒杀成功的结果生成一个producer,待consumer去消费及同步数据到mysql。模拟数据为:创建一个topic名为PRODUCT_NUMBER。
4.mysql:存放最终的秒杀结果。模拟数据为:创建一个seckill数据库,再创建一个seckill表,表字段为id自增和date存放秒杀时间和uid存放用户id。

三:代码实现

1.代码目录
在这里插入图片描述
2.node依赖包
在这里插入图片描述
3.seckillService.js
接收秒杀请求,并将秒杀结果及用户信息发送个kafka的producer。

var express=require("express"),
    redis=require("redis"),
    kafka=require('kafka-node'),
    Producer=kafka.Producer,
    kafkaClient=new kafka.Client(),
    producer=new Producer(kafkaClient);
    count=0;
    app=express();
    config=require("./config/redis.json");
var bodyParser=require('body-parser');
app.use(express.json());
app.use(bodyParser.json({
   limit: '1mb'}));  //body-parser 解析json格式数据
app.use(bodyParser.urlencoded({
               //此项必须在 bodyParser.json 下面,为参数编码
    extended: true
}));
app.all("*", function (req, res, next
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Docker是一种容器化解决方案,Docker Compose可以简化多个容器的管理和部署流程。Nacos是一个用于服务发现、配置管理和动态DNS服务的开源平台。Node.js是一个基于JavaScript的开源、跨平台的运行时环境,用于构建可扩展的网络应用程序。MongoDB是一个高性能、文档型NoSQL数据库,适用于处理大量的结构化和非结构化数据。MySQL是一个开源的关系型数据库管理系统,用于存储和管理结构化数据。Redis是一个基于内存的高性能键值存储系统,用于缓存和数据持久化。Seata是一个开源的分布式事务解决方案,用于保证分布式系统中的数据一致性。 通过Docker Compose,我们可以轻松地将这些不同的组件和服务以容器化的方式部署在一台或多台服务器上。我们可以使用Docker Compose的配置文件定义每个服务的镜像、端口映射、环境变量等设置。在这个场景中,我们可以将Nacos、Node.js、MongoDB、MySQLRedis和Seata分别作为独立的服务进行定义。 使用Docker Compose可以简化部署过程,只需运行一个命令即可启动整个应用程序的容器群组。Docker会自动拉取和部署所需的镜像,启动容器,并通过网络连接各个服务。Nacos可以作为服务发现和配置中心,用于管理和注册各个服务的地址和配置信息。Node.js可以作为应用程序的后端逻辑进行开发,通过Nacos来发现和调用各个后端服务。MongoDB作为主要的数据存储,MySQLRedis可以作为辅助数据存储和缓存。Seata可以用于管理和控制分布式事务,确保数据一致性。 总之,使用Docker Compose可以方便地将Nacos、Node.js、MongoDB、MySQLRedis和Seata等组件集成在一起,并通过容器化的方式进行部署。这样做可以极大地简化应用程序的开发和部署过程,并提供高度可扩展的架构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值