I’m sure you’re familiar with open platforms. When it is necessary to open up some functions of a product, third-party developers can access and use it. This is what open platforms do.
The reason why we can use wechat to log in to many other apps is because these apps are authorized to log in by accessing the capabilities provided by wechat’s open platform.
Flow control demand analysis of open platform
One feature that is a must for open platforms is API flow control.
For every app that connects to the open platform, you are assigned an Appkey, which is associated with which API you have applied. Then some of the apis are unlimited and can be called all the time. Some need to request call packages, such as 100,000 calls a day.
In addition to the amount limit, there is also a limit on frequency. For example, limit per API call per second, limit per Appkey call per second.
To implement these flow control functions, the best way is to have a traffic management platform, which provides the function of traffic limiting. Such as open platform is not ordinary system traffic limiting, a bit partial business traffic limiting, because there are specific quantitative indicators.
Technology selection
This is the previous article to tell you when to research, when you can directly use open source. When the demand can not be met, only research.
Self-development can be developed on the basis of open source, add service traffic limiting functions, support tenant functions, and allow multi-tenant access. Supports traffic limiting by Appkey volume and API volume.
If there is no existing governance platform to tap into, then businesses need to develop it themselves. Their development will generally use MySQL+Redis to achieve.
Realize the principle of
MySQL is used to store basic configuration information, such as flow control information corresponding to Appkey and API.
Redis is used for quantitative deductions to improve performance. Using this scheme inevitably brings up a data consistency problem, that is, how to keep the data in MySQL consistent with Redis.
Why Redis?
Assuming you don’t use Redis means you need to update the number of MySQL calls after each call. In the case of high concurrency, performance is definitely a priority.
Redis is still used for high concurrency, and the business scenario is not complex, just a count, Redis itself supports atomic operations.
Redis is for ancillary use only, not as a storage system for business data. So here comes the question of data consistency.
How to be consistent?
Now let’s think about, do we need strong consistency?
No, and this scene is not easy to do. So you just have to make sure that you’re consistent.
Count information can be synchronized to Redis in advance or loaded lazily. For example, to count an API under an Appkey, the key can be designed as Appkey:API, the expiration time is the period that you want to limit, such as by day.
There needs to be a periodic task to synchronize the count information from Redis to MySQL. The interval can be set by yourself. If Redis is not persistent and data is lost after restart, the count information will be retrieved from MySQL to initialize. If you synchronize data every 10 minutes, then only the 10 minutes of calls will be lost.
I don’t think it’s a big deal for a general open platform to lose some count information, just to get three parties to call more interfaces. But depending on the business, if your API is pay-per-view, then this scheme may not be suitable, and it has to be consistent when it comes to money.
Single or cluster?
On this topic, the previous article “Traffic governance artifact -Sentinel traffic limiting Mode: Single machine or Cluster?” We talked about it in there.
So in this business scenario of open platform, there is no doubt that cluster limiting should be chosen. Traffic limiting in a service scenario has specific traffic limiting indicators. Traffic limiting in a single node does not have global storage and cannot feed back its own results to other services. As a result, service results are incorrect.
Hello everyone, I am a handsome man from ancient times: structure ferryman. I will put my martial arts secret all impart with you, feel useful please share to the friends around. Let’s do a triple. Thank you! In addition, I also recorded the “real order business, 100 million level data with your actual combat sub-database sub-table” ** actual combat course, remember to learn oh!