当前位置:网站首页>Exploration and practice of transaction link under multi-service mode
Exploration and practice of transaction link under multi-service mode
2022-08-05 11:38:00 【InfoQ】
< h3> a business background, < / h3>< div> around as the head of domestic second-hand idle trading platform, since 2015, the business model by C2C expand to B2C, C2B, B2B, C2B2C, such as the new pattern of multiple modes coexist, category covers mobile phones, books, games and so on more than 30 kinds of.< / div>< br>< div> around is applied at present middle mode structure, middle office is responsible for providing general trading ability, flexible rapid response to the needs of the business;Business party is responsible for the front desk to explore innovation, to provide users with a valuable service.< / div>< h3> 2, trading problems facing China < / h3>< div> middle trading order system carries the entire company most general order flow ability of the business, but the business model of the trading link in the complex and diverse, with is different, such as below: < / div>< br>< img SRC="/ / img.inotgo.com/imagesLocal/202208/05/202208051128148139_3.png" Alt=null loading=lazy>< br>< ul>< li>< div> 1, the different business model trading link there are differences between the master node, and lock the storage, delivery, settlement, node also has difference < / div>< / li>< / ul>< ul>< li>< div> 2, need to support a variety of business models coexist at the same time, and each other < / div>< / li>< / ul>< ul>< li>< div> 3, transaction link scalable, reusable, low maintenance cost, fast response speed, meet the business daily fast iterative < / div>< / li>< / ul>< ul>< li>< div> 4, the link is stable, accurate data, process visualization, can quickly locate problems < / div>< / li>< / ul>< br>< strong>< div> obviously hard-coded traditional way have been unable to meet demand, FSM finite state machine be vividly portrayed.< / div>< / strong>< h3> three practice and exploration, trading link < / h3>< h4> 3.1, transaction link of practice the FSM finite state machine < / h4>< h5> FSM finite state machine is what?< / h5>< div> FSM Finite state machine (Finite - state The machine, & have spentFSM), & have spentIs trading around China to provide a general state of the circulation scheme, for through the event action between finite state transfer mathematical model.Commonly used to describe objects in its life cycle state experienced by sequence, and how to respond to external events, etc.< / div>< h5> FSM package can be done?< / h5>< div> FSM can quickly build any flow of the document link, link related offline tasks at the same time, the problem such as transaction message.< / div>< h5> four elements of FSM < / h5>< div> FSM will trade link state flow of abstraction and structured, mainly divides into four elements, namely, the current state (now), events, actions and target state (state).The "current state" and "events" because, "action" and "time" is a fruit, as shown in the figure below: < / div>< br>< img SRC="/ / img.inotgo.com/imagesLocal/202208/05/202208051128148139_0.png" Alt=null loading=lazy>< br>< ul>< li>< div> now state < / div>< div> : refers to the current state of the place.< / div>< / li>< / ul>< ul>< li>< div> events < / div>< div> : also known as the "conditions".When an event occurs, will trigger an action, or execute a state migration.< / div>< / li>< / ul>< ul>< li>< div> action < / div>< div> : condition is met after the execution of actions.After the action has been completed, can be migrated to a new state, can still maintain the original state.Action is not required, when the condition is met, also can not perform any action, directly to migrate to the new state.< / div>< / li>< / ul>< ul>< li>< div> time state < / div>< div> : after the condition is met will be moved to the new state.
FSM实战
在转转交易中台订单系统,抽象了符合交易场景的状态角色:
- 状态关系:初始状态、目标状态
- 角色:不同角色有不同的操作权限,比如卖家、买家、系统、客服
- 操作:对应事件Event
- handler:对应动作Action实现
FSM可视化交易链路
运营后台可查看指定交易链路FSM状态机的状态流转全景图,如下图:
FSM解决了交易主链路节点的流转问题,但是针对无状态的单节点子链路不适用,例如下单节点,包含商品、用户、地址、库存、促销、埋点等多维信息的校验与整合。So how to guarantee the expansibility, reusability and stability of the order link and high performance, please see below the concurrency model of exploration and practice.< / div>< / strong>< h4> 3.2, trading link in stages based on the future of practice concurrency model < / h4>< div> about trade order, the layman to see is to create an order, an insert; Actually otherwise, the logic complexity is far more than that, we come to place the order to do what kind of logic: < / div>< br>< ul>< li>< div> information query (goods, inventory, activities, a red envelope, user, address, business line, label, etc.) < / div>< / li>< / ul>< ul>< li>< div> check (inventory check, address calibration, red envelopes, calibration cycle check, calibration services, commodity prices, integral calibration, purchase frequency, etc.) < / div>< / li>< / ul>< ul>< li>< div> risk control intercept < / div>< / li>< / ul>< ul>< li>< div> order information to assemble < / div>< / li>< / ul>< ul>< li>< div> lock stock class (virtual inventory, physical inventories, service inventory, lock a red envelope, lock integral) < / div>< / li>< / ul>< ul>< li>< div> activity budget deductions < / div>< / li>< / ul>< ul>< li>< div> persistence (create order, to create single) < / div>< / li>< / ul>< ul>< li>< div> operation flow, log buried point and so on < / div>< / li>< / ul>< br>< div> only listed above the key node is not complete, intended to express order of the complexity of the logic.< / div>< h5> a serial model, the traditional process: < / h5>< img SRC="/ / img.inotgo.com/imagesLocal/202208/05/202208051128148139_1.png" Alt=null loading=lazy>< br>< strong>< div> obviously, the traditional process of serial model, no matter from the aspects of performance, or from the code the flexibility and expansibility of sex has been unable to meet our requirements, so here we order adopted "the concurrency model by stages based on the future" < / div>< div>.< / div>< / strong>< h5> b, based on the future of the concurrency model in stages: < / h5>< img SRC="/ / img.inotgo.com/imagesLocal/202208/05/202208051128148139_2.png" Alt=null loading=lazy>< br>< div> than traditional procedural serial model, has the following advantages: < / div>< br>< ul>< li>< div> multithreaded interface improved overall performance;< / div>< / li>< / ul>< ul>< li>< div> code more functionality to the abstract and structured, divided into the smallest unit of adjacent state when in structures, lego, the reusability significantly increased;< / div>< / li>< / ul>< ul>< li>< div> expansibility and maintainability got a qualitative leap;< / div>< / li>< / ul>< br>< div> but there are also some disadvantages: < / div>< br>< ul>< li>< div> concurrently in strict accordance with the grouped, task set is consumed by the about the longest time-consuming < / div>< / li>< / ul>< ul>< li>< div> grouped, the utilization rate of the thread pool unsaturated < / div>< / li>< / ul>< h4> 3.3, transaction link of discovery model based on event driven concurrent < / h4>< div> around company Avenger series provides a more efficient concurrent component (Avenger - Ultron), more efficient than the original concurrency model in stages.< / div>< br>< img SRC="/ / img.inotgo.com/imagesLocal/202208/05/202208051128148139_5.png" Alt=null loading=lazy>< br>< strong>< div> at present, the concurrency model has been widely used in various lines of business in the company of complex concurrent scenarios (a user request interface internal needs scores of RPC aggregation query information).< / div>< / strong>< br>< div> if, from the traditional procedural serial model, evolution to the future based concurrency model in stages, from 0 to 1 of the process;So from the concurrency model by stages based on the future, evolved to based on the event-driven concurrency model, can be viewed as the progress of from 1 to 100.Then add the topology, monitoring, fusing, degradation and other plug-ins or the improvement of the tool, can achieve 100 to up the cross dimension of ascension.< / div>< h3> 4, summary < / h3>< div> concurrency model is used to solve the complex of stateless concurrent scenarios (such as commodity list page, the details page, home page, etc.), while the FSM is mainly to solve complex business scenarios deal link-state flow problem, but the application of FSM scene beyond the trade order, can also be used for other link with state scenarios, such as OA workflow, quality inspection line, etc.< / div>< br>< div> FSM is a framework that also need to set up a complete set of business logic, based on its periphery in link-state flow in the process of trading, the business logic is our muscles.Business logic and the framework of our trading middle technical system, so that the technology to grow healthier, perhaps this is the charm of China.< / div>< br>< br>< br>< div> author introduction < / div>< div> shi-jie guo, trading around China r&d engineers < / div>< br>< strong>< div> around the research and development center and technology study and communication platform of industry friends, on a regular basis to share a line of actual combat experience and industry leading edge technology.< / div>< / strong>< br>< strong>< div> pay attention to the public, around the "technology" (comprehensive), around "FE" (focus on FE), around the "QA" (focusing on QA), more dry practice, welcomed the sharing ~ < / div>< / strong>
边栏推荐
- #yyds干货盘点#JS数组和树相互转化
- 365天挑战LeetCode1000题——Day 050 在二叉树中增加一行 二叉树
- UDP communication
- 智源社区AI周刊No.92:“计算复杂度”理论奠基人Juris Hartmanis逝世;美国AI学生九年涨2倍,大学教师短缺;2022智源大会观点报告发布[附下载]
- STM32 entry development: write XPT2046 resistive touch screen driver (analog SPI)
- 大佬们 我是新手,我根据文档用flinksql 写个简单的用户访问量的count 但是执行一次就结束
- Hands-on Deep Learning_GoogLeNet / Inceptionv1v2v3v4
- Student Information Management System (first time...)
- 2022杭电杯超级联赛(5)
- Flink Yarn Per Job - RM启动SlotManager
猜你喜欢
随机推荐
hdu2097 nyoj414 sky数 (进制转换)
一张图理解EOS是什么
四、kubeadm单master
TiDB 6.0 Placement Rules In SQL Usage Practice
el-menu箭头改为右下
Android development with Kotlin programming language II Conditional control
Android development with Kotlin programming language three loop control
Flink Yarn Per Job - RM启动SlotManager
gradle尚硅谷笔记
2022技能大赛训练题:交换机snmp配置
记2022年七夕感慨
女人是这个世界上最美丽的生命
机器学习——逻辑回归
可视化开发必看:智慧城市四大核心技术
STM32入门开发:编写XPT2046电阻触摸屏驱动(模拟SPI)
LeetCode brush questions (8)
PostgreSQL 2022 报告:流行度上涨,开源、可靠性和扩展是关键
发现C语言的乐趣
LeetCode刷题(8)
Can't get in to ask questions.I want to ask you a question about the return value (traversal of the graph), please give Xiaobai an answer.