


How can 20w push users be completed concurrently in seconds? This article will introduce to you three methods for redis to implement real-time subscription push: MQ, traditional scheduled tasks, and Redis' SortSet queue. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to everyone.
[Related recommendations: Redis Video Tutorial]
A while ago, we developed a project for the company’s coupon collection center. This project is based on Redis is implemented as a key technology.
Let’s talk about the coupon collection center project first. This project is similar to the coupon collection center of JD.com app. Of course, the picture is taken from JD.com, not the company’s. . .
There is a function called subscription push for receiving coupons.
What is the subscription push for coupon collection?
means that the user has subscribed to the push notification of the coupon, and the reminder information will be pushed to the user's app one minute before it can be claimed.
Originally, this subscription function was supposed to be implemented by the message center, but they said it could not be implemented in a short time. So I, the person in charge of coupons, did it -.-!. The specific plan is to reach the specific push time point. The coupon system calls the push interface of the message center to push the information out.
Let’s analyze the business scenario of this function. The company currently has 6000W registered users, so don’t ask who it is. . . For example, if there is a no-threshold discount coupon that offers an instant discount of 20 yuan when placing an order, more people will grab this coupon. We conservatively estimate it to be 10W, and it is hard to say if it is a million yuan. Our initial target is 200,000 people, so these 200,000 push messages will be pushed out in one minute! And one user can subscribe to multiple coupons. So we know that there are two outstanding difficulties with this subscription function:
Effectiveness of push: If the push is slow, users will complain that they have not been notified in time and missed the opportunity to start grabbing.
The volume of the push is large: a popular coupon that everyone wants to grab!
However, the volume of push will affect the effectiveness of push. This is really a headache!
Then let us solve the problems one by one!
Issues with the effectiveness of push: When a user subscribes to a coupon collection reminder in the coupon collection center, a user's subscription reminder record will be generated in the background, which records the time point at which it was given to the user. Send push messages. So the question becomes how the system can quickly select which records to push in real time!
Option 1:
Delayed delivery of MQ. Although MQ supports delayed delivery of messages, the scale is too large, 1s 5s 10s 30s 1m, and it cannot be used for precise time point delivery! And if the user cancels the subscription after executing the subscription, the operation of deleting the MQ message sent is a bit cumbersome and difficult to implement in a short time! And users can cancel and then subscribe, which again involves the problem of deduplication. Therefore, MQ’s plan is rejected.
Option 2:
Traditional scheduled tasks. This is relatively simple. To use a scheduled task, load the user's subscription reminder records in the db and select the records that can currently be pushed. But there is a saying that goes well: Any design that is divorced from actual business is a rogue. Let's analyze whether traditional scheduled tasks are suitable for our business!
Can it support multiple machines running at the same time? | Generally not, the same It can only be run alone at all times. |
Storage data source |
It is usually mysql or other traditional database, and it is a single table storage |
Frequency | Supports seconds, minutes, hours and days, generally not too fast |
To sum up, we know that general traditional scheduled tasks have the following shortcomings:
1. Performance bottleneck. Only one machine is processing it, which is unable to cope with the large amount of data!
2. Poor effectiveness. The frequency of scheduled tasks cannot be too high. If it is too high, it will put a lot of pressure on the business database!
3. Single point of failure.
If the running machine hangs up, then the entire business will be unavailable -. - This is a terrible thing! Therefore, traditional scheduled tasks are not suitable for this business. . . So are we at our wits’ end? Actually no! We just need to make a simple transformation of the traditional scheduled tasks! You can turn it into a scheduled task cluster that can run on multiple machines at the same time, and the effectiveness can be accurate to the second level, and reject single points of failure! This requires the help of our powerful redis.
Option 3:
Scheduled task cluster First we need to define the three problems that the scheduled task cluster needs to solve!
1. The effectiveness must be high
2. The throughput must be large
3. The service must be stable and there must be no single point of failure. The following is the architecture diagram of the entire scheduled task cluster. .
The architecture is very simple: we store the user's subscription push records in the sortedSet queue of the redis cluster, and use the reminder timestamp as the score value, and then in our personal Each business server starts a timer with a frequency of seconds. My setting is 1s. Then after load balancing, the user records to be pushed are obtained from a queue and pushed. Next we analyze the following architecture.
1. Performance: excluding bandwidth and other factors, it is basically linearly related to the number of machines. The greater the number of machines, the greater the throughput. When the number of machines is small, the relative throughput decreases.
2. Effectiveness: It has been improved to the second level, and the effect is acceptable.
3. Single point of failure? nonexistent! Unless the redis cluster or all servers are down. . . .
Here is an analysis of why redis is used?
First, redis can be used as a high-performance storage db. Its performance is much better than MySQL, and it supports persistence and has good stability.
The second redis SortedSet queue naturally supports sorting based on time as a condition, which perfectly satisfies us in selecting the records to be pushed.
ok~ Now that the plan is available, how can we implement it within one day? Yes, it only took me one day from designing this plan to completing the basic coding. . . Because time is too late.
First we use user_id as the key, and then mod the queue number hash into the redis SortedSet queue. Why is this? Because if the user subscribes to two coupons at the same time and the push time is very close, the two pushes can be merged into one~, and the hash is relatively even. The following is a screenshot of part of the code:
Then we need to determine the number of queues. Generally speaking, we define as many queues as we have for processing servers. Because too few queues may cause queue competition, too many may result in records not being processed in a timely manner. However, the best practice is that the number of queues should be dynamically configurable, because the number of online cluster machines will often change.
We will add more machines during the big promotion, right? And as the business volume increases, the number of machines will also increase, right? So I borrowed Taobao's diamond to dynamically configure the number of queues.
How many records we take from the queue each time can also be dynamically configured
This way, we can configure it at any time The actual production situation adjusts the throughput of the entire cluster~. So our scheduled task cluster still has a feature that supports dynamic adjustment~. The last key component is load balancing. This is very important!
Because if this is not done well, it may cause multiple machines to compete to process a queue at the same time, affecting the efficiency of the entire cluster! When time was very tight, I used a simple and practical algorithm that uses redis to auto-increment the key and then mod the number of queues. This will largely ensure that no two machines will compete for a queue at the same time~.
For more programming-related knowledge, please visit: programmingvideo! !
The above is the detailed content of A brief discussion on three methods of redis to implement real-time subscription push. For more information, please follow other related articles on the PHP Chinese website!

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于实现秒杀的相关内容,包括了秒杀逻辑、存在的链接超时、超卖和库存遗留的问题,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software
