当前位置:网站首页>Design e-commerce seckill system
Design e-commerce seckill system
2022-07-03 20:39:00 【InfoQ】
One 、 background
technology
- Technical team Java Technology oriented
- Microservices have been launched
- At present, single room
- Yes APP Follow wechat applet , Requires only APP Users can participate in the second kill
Business
- Selling goods <=10 Categories *20 A commodity
- This second kill 2 A commodity (1000 A power bank 、10 platform iphone12)
- The normal daily life is about 100w user
- At present, there are only single rooms
- The boss needs to be foolproof
Two 、 Business analysis
3、 ... and 、 Design ideas
- Do a good job of isolation : Including seckill service isolation 、 Isolation of middleware . Deploy the service cluster separately , Prevent the collapse of other services .
- Multi layer current limiting : Make sure you arrive DB Layer can be in controllable flow .
- Try to cache : Preheat the goods to the cache in advance , Including inventory data .
- High availability design : Including current limiting 、 line up 、 Downgrade 、 Fuse .
data:image/s3,"s3://crabby-images/48fc8/48fc8d707b8d1a228d2b4ef095e493d00b545848" alt="null"
Storage architecture design
data:image/s3,"s3://crabby-images/bd333/bd333d2ba77009c3491e7ca6163be1cd6495bf6d" alt="null"
data:image/s3,"s3://crabby-images/54de2/54de28bddc77c9926f284e8ee59a75b757719bb8" alt="null"
6、 ... and 、 Computing architecture design
6.1、 Load balancing design
data:image/s3,"s3://crabby-images/a3fd9/a3fd905fcc9a557da214bbba76e9cba7c526b3f2" alt="null"
6.2、 Cache design
data:image/s3,"s3://crabby-images/9b384/9b3844a91a9765c6b865841fdb566ff1f6997f3c" alt="null"
7、 ... and 、 High availability design
7.1、 Current limiting design
data:image/s3,"s3://crabby-images/1e988/1e9888f33de1d7e87ed055df723275d73bbede42" alt="null"
- 1、 Current limit at the requester : Limit the current when making a request , Requests that are throttled are not actually sent to the back-end server
- 2、 Current limiting at the access end : Conduct current limiting when receiving a service request , Avoid requests going into the actual business process
- 3、 A single service protects itself , If there are too many requests , New requests can be discarded
7.2、 Queuing design
data:image/s3,"s3://crabby-images/41dd2/41dd2bb0ed9ddccd73f6ba49064f5425185c2879" alt="null"
- 1、 Queuing module . Use Kafka Message queue , Save the request first in first out , The size of the queue can be more than that of the second kill commodity .
- 2、 Scheduling module . Test according to the processing capacity of seckill service , Ability to handle , Put the messages in the queue under the seckill service .
- 3、 Other services . Real business processing module , If you place an order 、 Close the deal .
7.3、 Degraded design
data:image/s3,"s3://crabby-images/6bcb6/6bcb6a0ce289a00436d2b8ecb8e19e4dae1c8176" alt="null"
7.4、 Fuse design
data:image/s3,"s3://crabby-images/f38ec/f38ec2e6072d8c276f06795ad79d5f9d8242ca2e" alt="null"
边栏推荐
- 1.4 learn more about functions
- Haven't expressed the artifact yet? Valentine's Day is coming. Please send her a special gift~
- 阻塞非阻塞和同步异步的区分 参考一些书籍
- Global and Chinese market of micro positioning technology 2022-2028: Research Report on technology, participants, trends, market size and share
- 2.4 conversion of different data types
- SQL injection - Fundamentals of SQL database operation
- Implementation of stack
- 强化学习-学习笔记1 | 基础概念
- Qtablewidget control of QT
- Derivation of decision tree theory
猜你喜欢
Sparse matrix (triple) creation, transpose, traversal, addition, subtraction, multiplication. C implementation
Test changes in Devops mode -- learning and thinking
2.4 conversion of different data types
Viewing Chinese science and technology from the Winter Olympics (II): when snowmaking breakthrough is in progress
LabVIEW training
强基计划 数学相关书籍 推荐
In 2021, the global revenue of syphilis rapid detection kits was about US $608.1 million, and it is expected to reach US $712.9 million in 2028
From the behind the scenes arena of the ice and snow event, see how digital builders can ensure large-scale events
强化学习-学习笔记1 | 基础概念
How can the outside world get values when using nodejs to link MySQL
随机推荐
【leetcode】1027. Longest arithmetic sequence (dynamic programming)
Gauss elimination solves linear equations (floating-point Gauss elimination template)
[postgresql]postgresql custom function returns an instance of table type
Task of gradle learning
Shortest path problem of graph theory (acwing template)
Cesiumjs 2022 ^ source code interpretation [7] - Analysis of the request and loading process of 3dfiles
Set, weakset, map, weakmap in ES6
Qt6 QML Book/Qt Quick 3D/基础知识
Global and Chinese markets of polyimide tubes for electronics 2022-2028: Research Report on technology, participants, trends, market size and share
4. Data splitting of Flink real-time project
Commands related to files and directories
Sparse matrix (triple) creation, transpose, traversal, addition, subtraction, multiplication. C implementation
Do you really know how old you are?
Global and Chinese market of speed limiter 2022-2028: Research Report on technology, participants, trends, market size and share
Golang type assertion and conversion (and strconv package)
1.5 learn to find mistakes first
Based on laravel 5.5\5.6\5 X solution to the failure of installing laravel ide helper
Rhcsa third day notes
Camera calibration (I): robot hand eye calibration
Qtablewidget control of QT