服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - 三种优化思路,教你轻松实现Redis秒杀功能

三种优化思路,教你轻松实现Redis秒杀功能

2020-06-15 23:09今日头条This野指针 Redis

秒杀这样的短时大并发的系统,在性能负载上面有一个很明显的波峰和长期波谷。是为了应对相当短时间内的大并发而准备大量服务器来应对,在经济上是非常不划算的。

三种优化思路,教你轻松实现Redis秒杀功能

秒杀系统的架构设计。

那么,何为秒杀系统呢?就是典型的、短时间的、大量的、突发访问,我们对于这类问题呢,总结有以下三种优化性能的思路:

异步处理,而不是同步处理 。

写入内存,而不是写入硬盘 。

分布式处理。

——那么,这三种优化秒杀系统性能的思路,不论秒杀时负载多大,都能够轻松的应对。redis能够满足以上三种优化性能,用redis能轻松实现秒杀系统。

为什么以上三种性能优化思路,能够轻松的解决秒杀系统的性能问题呢?下面我们一一的介绍。

异步处理,而不是同步处理。

秒杀这样的短时大并发的系统,在性能负载上面有一个很明显的波峰和长期波谷。是为了应对相当短时间内的大并发而准备大量服务器来应对,在经济上是非常不划算的。

因此呢,对付秒杀类的需求,我们就应该化同步为异步,用户请求写入内存后立刻返回。后台启动多个线程从内存池中异步读取数据,对其进行处理。

如果用户请求可能是1秒钟内进入的,系统实际处理完成可能花三十分钟。那么一台服务器在异步情况下其处理能力大于同步情况下1800多倍之多。

——异步处理,通常用MQ(消息队列)来实现。redis可以看作是一个高性能的MQ。因为它的数据读写都发生在内存之中。

写入内存,而不是写入硬盘。

对于传统的硬盘读写性能是相当差的,SSD硬盘比传统硬盘快100倍,而内存又比SSD硬盘快10倍以上。因此,写入内存,而不是写入硬盘,就能使系统的能力提升上千倍。也就是说,原来你的秒杀系统可能需要900台服务器支撑,现在一台服务器就可以扛得住了。

有些开发者就会有疑问了?写入内存,而不是持久化,如果此时计算机突然宕机了呢,写入的数据不就全部丢失了吗??如果你运气不好,倒霉呢?碰到服务器宕机,那你就没秒到了,有什么大不了呀!

——后面真正处理秒杀订单时,我们会把信息持久化到硬盘中。因此不会丢失关键的数据。redis是一个缓存系统,数据写入内存后就返回给客户端,能够支持这个特性。

分布式处理

要是你的客户很多,秒杀系统即使用了以上两种方案,还是捉襟见肘撑不住?不要紧的,还有下面这个大招[分布式处理]。如果一台服务器撑不住秒杀系统,那么就多用几台服务器。五台不行,就上一百台嘛。

——分布式处理,就是把海量用户的请求分散到多个服务器上,一般使用hash实现均匀分布。

这类系统在大数据云计算时代的今天已经有很多了。无非是用Paxos算法和Hash Ring实现的,redis Cluster正是这样一个分布式的产品。

使用Redis实现描述系统

redis和redis cluster(分布式版本),是一个分布式缓存系统。其支持多种数据结构,也支持MQ。redis在性能上做了大量优化。因此使用Redis或者redis cluster就可以轻松实现一个强大的秒杀系统。

基本上,你用redis的这些命令就可以了。

RPUSH key value,插入秒杀请求。

——当插入的秒杀请求数达到上限时,停止所有后续插入。

LPOP key,后台启动多个工作线程。

读取秒杀成功者的用户id,进行后续处理,或者使用LRANGE key start end命令读取秒杀成功者的用户id,进行后续处理。

——每完成一条秒杀记录的处理,就执行INCR key_num。一旦所有库存处理完毕,就结束该商品的本次秒杀,关闭工作线程,也不再接收秒杀请求。

延伸 · 阅读

精彩推荐
  • Redis关于Redis数据库入门详细介绍

    关于Redis数据库入门详细介绍

    大家好,本篇文章主要讲的是关于Redis数据库入门详细介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览...

    沃尔码6982022-01-24
  • Redis详解三分钟快速搭建分布式高可用的Redis集群

    详解三分钟快速搭建分布式高可用的Redis集群

    这篇文章主要介绍了详解三分钟快速搭建分布式高可用的Redis集群,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    万猫学社4502021-07-25
  • Redis《面试八股文》之 Redis十六卷

    《面试八股文》之 Redis十六卷

    redis 作为我们最常用的内存数据库,很多地方你都能够发现它的身影,比如说登录信息的存储,分布式锁的使用,其经常被我们当做缓存去使用。...

    moon聊技术8182021-07-26
  • RedisRedis 6.X Cluster 集群搭建

    Redis 6.X Cluster 集群搭建

    码哥带大家完成在 CentOS 7 中安装 Redis 6.x 教程。在学习 Redis Cluster 集群之前,我们需要先搭建一套集群环境。机器有限,实现目标是一台机器上搭建 6 个节...

    码哥字节15752021-04-07
  • Redisredis缓存存储Session原理机制

    redis缓存存储Session原理机制

    这篇文章主要为大家介绍了redis缓存存储Session原理机制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪...

    程序媛张小妍9252021-11-25
  • RedisRedis集群的5种使用方式,各自优缺点分析

    Redis集群的5种使用方式,各自优缺点分析

    Redis 多副本,采用主从(replication)部署结构,相较于单副本而言最大的特点就是主从实例间数据实时同步,并且提供数据持久化和备份策略。...

    优知学院4082021-08-10
  • RedisRedis Template实现分布式锁的实例代码

    Redis Template实现分布式锁的实例代码

    这篇文章主要介绍了Redis Template实现分布式锁,需要的朋友可以参考下 ...

    晴天小哥哥2592019-11-18
  • Redis如何使用Redis锁处理并发问题详解

    如何使用Redis锁处理并发问题详解

    这篇文章主要给大家介绍了关于如何使用Redis锁处理并发问题的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习...

    haofly4522019-11-26