收单结算是支付系统最重要的子域之一,行业内经常把有牌照的支付平台称为“收单机构”就可见一斑。有些监管严格的国家地区,没有收单牌照就不能碰收单和结算,商户必须入驻到有收单牌照的支付机构。本文主要讲清楚支付系统中收单涉及的基本概念,产品架构、系统架构,以及一些核心的流程和相关领域模型、状态机设计。
支付系统无论需求文档还是技术方案文档,都充斥着专业词汇和行业通用词语,这些术语有的直观易懂,有的则晦涩难解。在这篇文章中,我将揭开支付系统中常用术语的神秘面纱,用最通俗的语言解释这些专业词汇。需要说明的是:这些术语是我个人从业10来年经验的总结,多用于聊需求或设计时使用,严谨性可能不及一些权威书籍,但是足够实用,起码在中国绝大部分的支付大厂是通用的。此外,一些术语在不同的领域有不同含义,下面的定义只适用在线支付系统场景下。
下面描述的概念大部分做了极致简化,只是用于入门,对于理解概念应该是够用的。真实的实现会复杂非常多,后面的系列文章会展开做详细说明。后面的描述中,经常混着用“支付系统”、“支付平台”,本质是一个东西。在内部来说,就是一个支付系统,但从和外部机构交互来说,就是一个支付平台。
支付安全是支付系统最重要的根基之一,没有支付安全,在线支付系统就无从谈起。但是安全又是一门很大的学科,涉及密码学,网络设备,法律法规,流程制度等方方面面。这里只谈一些和软件研发比较紧密的一部分内容,不涉及网络防火墙等网络设备安全。主要包括以下几点内容:支付安全体系概要;常见加解密、加验签等密码学知识。统一密钥存储及加解密系统设计概要。
使用Shell脚本,可以编写一个任务,然后让计算机去做,而你可以去忙其他的事情;可以编写一个任务,让计算机重复执行,而不需要你每次在命令行手动输入;可以更灵活地处理任务,比如管理用户,管理程序等。就这样,Shell脚本赋予你控制计算机的能力,一切尽在掌握。
在大多数的Linux和Unix系统、及其他类Unix系统中,Shell是用户与操作系统内核交互的主要方式。作为一种强大的命令行解释器,它也支持编程功能,用户可以写脚本来处理各种任务。大多数人学习Shell脚本的最大动力是提高效率。使用Shell脚本,可以编写一个任务,然后让计算机去做,而你可以去忙其他的事情;可以编写一个任务,让计算机重复执行,而不需要你每次在命令行手动输入;可以更灵活地处理任务,比如管理用户,管理程序等。就这样,Shell脚本赋予你控制计算机的能力,一切尽在掌握。
在堡垒机中,过滤危险命令是确保系统安全的重要措施之一。要过滤的危险命令可能会因具体环境、系统配置和业务需求的不同而有所差异。需要注意的是,过滤这些命令时,应该仔细考虑它们可能带来的风险和实际业务需求。在某些情况下,某些命令可能是合法且必要的,因此在实施过滤策略时应该灵活调整。
Shell脚本的作用是监控系统的CPU、内存以及磁盘使用情况,并在超过特定阈值时记录详细的进程信息。它将这些信息写入到一个日志文件中。由于当前的系统环境中没有部署专门的监控组件,我们需要一种临时方案来监控系统资源。此方案通过Shell脚本实时测量CPU、内存和磁盘使用率,并在超过设定阈值时保存告警信息。该脚本能够帮助管理员快速发现和解决系统性能问题,确保系统稳定运行。
很多文章都在介绍设计模式怎么用,讲解设计模式的原理等等,设计模式的思想是编程中的精髓,用好了可以让代码结构利于维护和扩展,同时代码风格也更加优雅,V 哥也写过这样一篇文章,但很少有人从反模式的角度来讲一讲,过度滥用设计模式将给项目带来灾难。设计模式反模式(Anti-Pattern)是指那些表面上看起来像是设计模式,但实际上会导致软件设计问题的做法。这些做法可能会导致代码难以维护、扩展或测试。
整个软件的发展历程是一部软件复杂性对抗史,软件的复杂性分为技术复杂性和业务复杂性,业务复杂性主要是建模和抽象设计,技术复杂性主要是三高(高性能,高并发,高可用)的应对,C端的业务一般以技术复杂性为主,业务复杂性为辅,而B端或者M端的业务通常以业务复杂性为主,技术复杂性为辅。本篇文章主要是从后端研发的视角结合自己多年的B C端系统建设实践谈下三高系统的建设方法论和实践,希望和大家相互交流,共同进步,同时这是我参与创作者计划的第1篇文章。