图解支付-金融级密钥管理系统:构建支付系统的安全基石

经常在网上看到某某公司几千万的个人敏感信息被泄露,这要是放在持牌的支付公司,可能就是一个非常大的麻烦,不但会失去用户的信任,而且可能会被吊销牌照。而现实情况是很多公司的技术研发人员并没有足够深的安全架构经验来设计一套高度安全的密钥管理系统。

今天我们解构金融级别的密钥管理系统设计与实现,讲清楚如何设计密钥分级体系,密钥轮换机制,如何兼顾存储安全与运算速度,跨机房容灾方案等技术细节。

安全行业有句俗话:“密钥的价值等于数据的价值”,如果你对数据安全感兴趣,或想加固自己公司的数据安全级别,或好奇金融级别的安全体系相关知识,欢迎和墨哥一起探索如何设计一个金融级的密钥管理系统。

1. 前言

在当今数字化经济的浪潮中,支付系统扮演着极其关键的角色,支付系统面临的安全挑战也日益增加,尤其是数据泄露事件频发,对信任机制和整个支付生态系统构成了严重威胁。在这样的背景下,高度安全的金融级密钥管理系统(KMS)的作用变得尤为重要,它是确保支付系统安全的关键技术之一。

密钥管理系统涵盖了密钥的生命周期管理,包括密钥的生成、分发、使用、存储、轮换和销毁等环节,旨在通过严格的安全措施保护密钥不被未授权访问,从而确保交易数据的安全。当然,有效的密钥管理不仅仅是技术问题,它还涉及到政策、流程、人员等多个方面,需要系统性的设计和实施。

本文旨在通过图解的方式,深入浅出地介绍金融级密钥管理系统的设计和实现,帮助读者理解其在构建安全支付系统中的关键作用。我们将从密钥管理的基本概念出发,逐步深入到产品架构、系统架构、部署架构以及设计细节等多个层面,全面展示如何在支付系统中实施有效的密钥管理策略及应用。

希望通过本文的介绍,能够为在线支付系统的工程师、架构师们提供实用的参考指南。

2. 术语

在深入探讨密钥管理系统(KMS)之前,理解以下核心术语对于把握整个系统的设计和功能至关重要,它们构成了加密和密钥管理领域的基本词汇,是进一步讨论的基础。

  1. 密钥(Key)
    密钥是一串用于加密和解密数据的信息,是保护数据不被未授权访问的基础。根据用途和级别,密钥可分为主密钥、工作密钥等。
  2. 主密钥/本地主密钥(Master Key / Local Master Key)
    作为密钥管理体系中最高级别的密钥,主密钥用于加密和保护其他密钥(如工作密钥)。由于其重要性,通常由硬件加密机(也称为:硬件安全模块(HSM))生成和存储,确保其安全性,所以也经常称为本地主密钥。
  3. 区别主密钥(Zone Master Key)
    区别主密钥,用于密钥传输前的加密。比如要把工作密钥传输到各安全服务中心,就需要使用ZMK先加密工作密钥。一般使用公私钥来做,后面有详细说明。
  4. 工作密钥(Working Key)
    直接用于业务数据的加解密操作。工作密钥由主密钥加密保护,以保障其安全。
  5. 数据加密密钥(Data Encryption Key,DEK)
    专门用于加密和解密业务数据的密钥。在某些文献中,工作密钥和数据加密密钥可以是同一概念。
  6. 密钥加密密钥(Key Encryption Key,KEK)
    专门用于加密和解密工作密钥的密钥。在分布式环境下,我们需要把一些工作密钥缓存在各机房的安全服务中心,就使用KEK加密后缓存,而不是缓存明文。
  7. 硬件安全模块(Hardware Security Module,HSM)
    一种物理设备,专门用于生成、存储和管理数字密钥。就是我们俗称的硬件加密机。HSM提供了物理隔离和高级安全功能,确保密钥的安全。 一般只能由特定授权的公司才能生产。在银行业,执牌金融机构基本都需要使用硬件加密机。
  8. 密钥生命周期(Key Lifecycle)
    描述了密钥从生成到销毁整个过程中的各个阶段,包括生成、分发、激活、使用、轮换、废弃和销毁等。
  9. 密钥轮换(Key Rotation)
    定期更换密钥的过程。通过轮换密钥,可以减少密钥被破解的风险,增强系统的安全性。
  10. 双因素认证(Two-Factor Authentication,2FA)
    一种安全措施,要求用户提供两种不同形式的身份验证,通常是密码和物理令牌或手机接收到的一次性密码(OTP),用于增强安全性。 比如在硬件加密机维护时,需要用户插入管理卡,并输入密码。
  11. 数字签名(Digital Signature)
    使用私钥签名,公钥验签。用于验证消息或文档的完整性和来源的真实性。
  12. 加密(Encryption)
    数据保护手段,将明文数据通过特定的算法和密钥转换成密文数据,需要解密后才能再次读取明文数据。常见的加密算法包括AES、RSA等。

这些术语部分不好理解,补充几个图如下:

主密钥生成与保存:硬件运算生成,保存到安全芯片。

主密钥作用:加密工作密钥,用于保存DB.

工作密钥:用于加密业务明文数据。

区域主密钥:加密工作密钥用于传输。

密钥加密密钥:加密工作密钥用于缓存,加速本地运算。

3. 建设目标

在设计和实施密钥管理系统(KMS)时,需要达成以下主要目标:

  1. 确保数据安全:最核心的目标是保护支付系统中敏感数据的安全,防止数据泄露、篡改或未授权访问。密钥管理系统应确保所有需要加密的业务数据在存储和传输过程中均经过加密保护。
  2. 支持密钥全生命周期管理:系统应提供密钥的生成、分发、使用、存储、轮换、废弃和销毁等全生命周期管理功能,确保密钥的安全性和有效性。
  3. 满足合规性要求:遵守相关的行业安全标准和法律法规,确保支付系统的合规性。
  4. 提高系统可用性和灵活性:通过支持密钥的快速轮换和备份恢复功能,提高系统对密钥泄露等安全事件的响应能力,保障业务连续性。
  5. 简化管理工作和降低运营成本:通过自动化的密钥管理流程和直观的管理界面,简化管理员的操作,降低管理成本和运营成本。
  6. 支持多种密钥类型和算法:适应不同加密需求,支持多种密钥类型和加密算法,提供灵活的密钥解决方案。
  7. 实现高性能和可扩展性:保证在高并发场景下的性能需求,支持业务的快速增长和系统的横向扩展。
  8. 提供强大的访问控制和审计功能:实现基于角色的访问控制(RBAC),记录详细的操作日志,支持安全审计和事后分析。
  9. 用户友好的操作界面:提供直观易用的管理界面,降低操作复杂度,提高用户体验。
  10. 支持灾难恢复和数据备份:构建高可用的密钥管理架构,实现密钥的及时备份和灾难恢复,确保关键业务数据的持久安全。

上面写得有虚,但确实是指导思路,一个完备、安全的密钥管理系统需要达到上述要求。

4. 系统架构

简化版本系统架构:

在密钥管理系统中,因为考虑分布式与安全网络隔离的问题,所以需要分开设置三个子系统:

  1. 安全服务中心:提供加密、解密、签名、验签、访问控制等基础能力。可水平扩展。
  2. 密钥存储中心:负责密钥的存储、轮换等基础能力。独立网络隔离区。
  3. 管理中心:提供后台管理能力,比如配置密钥、授权密钥给应用,对接硬件加密机(HSM)等。
  4. 硬件加密机(HSM):负责保存主密钥,并对工作密钥进行加密。

在下面的部署架构中,我们回看这个图,就明白为什么要切成三个。

另外,里面的子功能设计,可以参考后面的“设计细节”章节。

详细功能的系统架构:

5. 部署架构

在构建密钥管理系统(KMS)时,部署架构的设计直接影响到系统的可用性、扩展性和安全性。对于支付系统而言,必须考虑到业务的高可用性和灵活性需求,采用分布式部署架构是一种必然的选择。

核心设计原则

  1. 高可用性:通过在多个数据中心分布式部署密钥管理系统的实例,即使某个数据中心发生故障,其他实例仍然可以提供服务,从而保证系统的高可用性。
  2. 灵活扩展性:随着业务量的增长,系统可以通过增加节点的方式横向扩展,灵活应对业务需求的变化。
  3. 数据一致性:采用先进的数据同步技术,确保各节点间密钥信息的一致性,避免数据不一致导致的安全问题。
  4. 安全隔离:在不同的物理位置部署密钥管理服务,可实现安全隔离,降低单点攻击的风险。
  5. 灾难恢复:通过地理上分散的部署,结合有效的备份和恢复策略,确保在发生灾难时可以快速恢复服务。

分布式部署架构

  1. 中心管理节点:负责整个密钥管理系统的中心控制,包括策略制定、访问控制、审计日志等核心管理功能。
  2. 区域管理节点:在各个地理区域部署,负责处理该区域内的密钥请求,实现数据处理的地理近邻性,优化响应时间。
  3. 数据同步机制:确保所有区域管理节点间的数据一致性和实时性,采用可靠的数据同步技术,如同步复制或异步复制。
  4. 安全网络:所有节点通过安全的网络连接,确保数据传输的安全性和加密,防止数据在传输过程中被截获或篡改。

下面是一个部署简图:

一时没有找到防火墙常用图标,先将就着看。

核心要点:

  1. 密钥存储中心和硬件加密机部署在隔离区。
  2. 管理中心部署在管理区或者隔离机房,建议参考安全团队的建议。
  3. 安全服务中心部署在各应该APP所在机房,就近提供加解密、签验签等运算服务。可水平扩展。
  4. 安全服务中心有本地缓存,在隔离机房短时间内无法连接时,仍然可以正常提供服务。

6. 设计细节

6.1. 数据流图

核心有4个步骤:

  1. 初始化主密钥。
  2. 配置工作密钥。
  3. 同步工作密钥到各节点的安全服务中心。
  4. 实际执行加密解密、签名验签服务。

6.2. 密钥分级设计

在构建支付系统的密钥管理系统(KMS)时,密钥分级设计是确保密钥安全性的基础。通过将密钥分为不同的级别并应用不同的管理和保护策略,可以有效地降低密钥泄露的风险,提升系统的安全性。以下是密钥分级设计的核心要素:

  1. 主密钥/本地主密钥(Master Key / Local Master Key)
    • 级别:最高级别,作为其他密钥的根密钥。
    • 保护:存储于硬件安全模块(HSM)中,采用物理和逻辑双重保护机制,确保其安全性。
    • 用途:用于加密和解密工作密钥,不直接参与业务数据的加解密。
    • 管理:由最高权限的安全管理员进行管理,严格控制访问和操作。维护时一般需要3名管理员+1名操作员同时在场,管理员和操作员都有自己的物理管理卡和独立操作密码,全部验证通过后才能操作。
  1. 工作密钥(Working Key)
    • 级别:次级别,用于实际的业务数据加解密操作。
    • 保护:由主密钥加密保护,存储在加密数据库或安全配置文件中。
    • 用途:直接用于加密和解密业务数据,例如用户信息、交易数据等。
    • 管理:支持自动轮换和更新,减少手动干预,提高管理效率和安全性。

需要说明的是,严格意义上说,区域主密钥也是保存在硬件加密机中的。但在实现时,如果在区域节点不想部署硬件加密机,就可以生成公私钥对,把私钥放在区域节点,公钥放在密钥存储中心。

密钥分级设计的优势:

  • 分层保护:通过对密钥进行分级管理,构建了多层防御体系,即便低级别密钥被泄露,也不会直接威胁到系统的根本安全。
  • 灵活管理:主密钥和工作密钥的分离,使得密钥轮换和更新更加灵活高效,同时减少了主密钥的使用频率,降低了安全风险。
  • 性能与安全的平衡:通过在不同层级应用不同的密钥,可以在保证安全的前提下,优化系统性能,特别是对于高频率的业务数据加解密操作。因为硬件加密机的运算效率有限,且采购及运维成本高昂,不便于水平扩展。

密钥分级设计是构建高安全性支付系统不可或缺的一环,它为密钥的安全管理提供了一套完整的框架。

6.3. 访问控制

在构建支付系统的密钥管理系统(KMS)中,实现严格的访问控制机制是保障系统安全的关键。访问控制的主要目的是确保只有授权用户或应用才能访问和操作密钥,同时保护密钥不被非法导出或滥用。以下是访问控制的三个核心部分:

  1. 用户分级管理
  • 用户角色和权限:系统应定义不同的用户角色,每种角色具有不同的权限级别。例如,系统管理员拥有最高权限,可以管理用户和密钥策略;安全管理员负责主密钥的管理,包括生成、备份和恢复等操作;普通用户只能使用工作密钥进行日常的加解密操作。
  • 主密钥操作的物理安全:主密钥的操作,如生成、备份和恢复,只能由特定的安全管理员在物理安全的环境下通过硬件安全模块(HSM)直接操作。这样的操作需记录详细的审计日志,并且在执行关键操作时需要多人同时在场。
  • 工作密钥的审批流程:导出工作密钥或进行敏感操作时,需要通过多层审批流程。审批流程中涉及的每一步都应有清晰的操作记录和日志,以便于事后审计和追踪。

2. 密钥与应用的绑定

  • 应用级访问控制:每个密钥应指定可访问的应用列表。只有列表中的应用才能使用对应的密钥进行加解密或签名验签操作。这样可以有效防止密钥被非授权应用使用,增强密钥的安全性。
  • 密钥使用策略:对于每个密钥,可以定义详细的使用策略,包括使用的时间窗口、IP地址范围、访问频率等。这些策略可以在KMS中配置,并由系统强制执行。 但因为主要提供内网应用使用,一般很少这么限制。

3. 加密解密和签名验签的集中处理

  • 密钥的集中处理:所有的加密解密和签名验签操作都应通过密钥管理系统集中完成。通过API调用或服务接口的形式提供给外部应用,避免直接暴露密钥
  • 工作密钥的保护:工作密钥应始终存储在加密形式,且不能被导出或直接读取。所有密钥操作都在KMS内部完成,确保密钥的安全。

通过这种分层的访问控制机制,结合用户分级管理、密钥与应用的绑定以及加密解密和签名验签的集中管理,可以有效地保护密钥不被未授权访问和使用,从而为支付系统提供坚实的安全保障。

6.4. 工作密钥版本管理

在密钥管理系统(KMS)中,工作密钥版本管理是一个关键的安全措施,主要通过定时轮换机制来增强系统的安全性。此机制确保即使旧密钥被泄露,攻击者也无法利用它来破解过去或未来的加密数据。以下是工作密钥版本管理的主要方面:

定义密钥版本

  • 版本命名:为每个工作密钥定义唯一的版本标识符,通常包括密钥ID和版本号。
  • 版本属性:记录每个版本的关键属性,如创建时间、启用时间、过期时间和状态(激活、过期、废弃)。

定时轮换机制

  • 自动轮换:通过预设的策略自动轮换工作密钥。例如,根据最佳实践或合规要求,可以设置每三个月自动生成新的工作密钥版本并切换至新版本。
  • 轮换通知:在轮换发生前,系统应发送通知给相关的系统管理员和应用,确保它们准备好迁移到新的密钥版本。
  • 平滑过渡:在新旧版本切换期间,保持旧版本的可用性一段时间,以便完成未处理的加密操作,然后逐步淘汰旧版本。

版本回滚

  • 应急回滚:在发现新版本密钥存在问题时,系统应支持快速回滚至前一个稳定版本,以保障业务连续性。

密钥版本跟踪与审计

  • 版本历史记录:维护每个工作密钥的版本历史记录,包括每个版本的使用情况和更换原因。
  • 审计日志:记录所有密钥版本操作的详细审计日志,包括版本创建、启用、废弃和删除等,以支持安全审计和合规性检查。

一个简单的实现方案

对于内部数据,直接在密文的前面加上5位数的版本号。这样数据和密钥版本就形成一个绑定关系。

通过实施工作密钥版本管理和定时轮换机制,KMS能够有效降低密钥泄露的风险,提升支付系统的整体安全性。此外,该机制还有助于满足行业安全标准和合规要求,如PCI-DSS等,进一步保护敏感数据的安全。

6.5. 隔离部署

隔离部署是加强支付系统密钥管理系统(KMS)安全性的一个重要策略,它通过物理或逻辑手段,将敏感组件和操作环境与其他系统部分分离,从而减少潜在的安全威胁和风险。以下是实施隔离部署的关键考虑因素:

物理隔离

  • 硬件安全模块(HSM)部署:将存储和管理主密钥的硬件安全模块(HSM)物理隔离在受控的安全环境中,例如专用的安全机房。这样做不仅提高了主密钥的安全性,而且防止了未经授权的物理访问。
  • 独立的密钥管理网络:建立一个独立的网络环境专门用于密钥管理操作,与生产网络和办公网络隔离,避免潜在的跨网络攻击。

网络隔离

  • 防火墙和网络分段:使用防火墙和网络分段技术,将密钥管理系统与外部网络及其他内部系统分离,防止潜在的网络攻击和数据泄露。
  • 加密通信:确保所有进出密钥管理系统的网络通信都采用加密协议,如TLS,保护数据传输的安全性。

数据隔离

  • 敏感数据加密:确保存储和传输的所有敏感数据(包括密钥和加密的业务数据)都经过加密,即使数据被非法访问,也无法被解读。
  • 备份与恢复策略:对密钥和关键配置数据实施定期备份,并将备份数据存储在与生产环境隔离的安全位置,同时确保快速恢复能力以应对可能的灾难事件。

通过实施隔离部署策略,KMS能够有效地降低安全威胁,提高支付系统的整体安全性和稳定性。隔离部署不仅有助于防御外部攻击,也能减轻内部错误或滥用所带来的风险。

6.6. 性能设计

在密钥管理系统(KMS)的设计中,性能是一个不可忽视的关键要素。一个高性能的KMS能够保证在密钥生成、存取、更新以及加密服务的过程中,响应迅速,满足支付系统等高并发环境下的需求。以下是构成KMS性能设计的主要策略:

缓存机制

  • 密钥缓存:对频繁访问的工作密钥和会话密钥实施缓存,减少对密钥存储库的直接访问,也减少对硬件加密机的访问,提高响应速度。使用合适的缓存策略(如LRU算法)来管理缓存密钥的生命周期,确保密钥的即时更新和过期密钥的清除。同时

负载均衡与水平扩展

  • 请求分发:采用负载均衡技术在多个KMS节点之间分发请求,平衡系统负载,提高处理能力。一般的分布式部署架构都支持。
  • 水平扩展:因为工作密钥被缓存在本地运算节点,所以安全服务中心可以水平扩展,而不受限于硬件加密机。

并行处理

  • 多线程操作:加解密等这些操作是运算优先型业务,应减少线程数,以减少CPU的切换损耗。

通过上述性能设计策略,KMS能够满足高并发、低延迟的性能要求。以前实测下来,单机AES加解密能到2万左右的QPS。

6.7. 容灾设计

在构建密钥管理系统(KMS)时,容灾设计是确保系统在面对硬件故障、软件错误、人为操作失误或自然灾害等情况下仍能保持业务连续性和数据完整性的关键。以下是容灾设计的核心要素:

数据复制与同步

  • 跨地域复制:为了保证数据的高可用性和持久性,重要数据(包括密钥材料、配置信息等)应跨多个地域进行复制。使用实时数据复制技术确保各地域数据的一致性。
  • 异地备份:定期将关键数据异地备份,以防单点故障导致的数据丢失。备份数据应加密存储,以保护其安全性。

自动故障转移

  • 故障检测与自动转移:实现系统的自动故障检测机制,一旦检测到服务异常或系统故障,能够自动将请求转移到备用系统或节点,确保服务不间断。
  • 负载均衡:通过负载均衡技术分配请求到健康的服务节点,提高系统整体的稳定性和可用性。

系统冗余设计

  • 冗余硬件:在关键组件上采用冗余设计,比如同一机房需要部署多台硬件加密机(HSM),以减少单点故障的风险。
  • 服务冗余:部署冗余的服务实例,包括数据库、应用服务器等,确保任何单一实例的故障都不会影响到整个系统的运行。 这也是在线服务部署的常规动作。

容灾演练

  • 定期演练:定期进行容灾演练,验证和改进容灾计划的有效性,确保在真正的灾难发生时能够快速、有效地恢复服务。
  • 演练反馈:对容灾演练的结果进行分析,并根据反馈优化容灾计划和技术方案。

通过上述容灾设计措施,KMS能够在面对各种不可预测的故障和灾害时,保证密钥服务的持续可用性和数据的完整性,为支付系统等关键业务提供坚实的安全基础。

7. 常见误区

在工作和同事的交流中,发现对于密钥的保存和使用有几个常见误区:

  1. 硬编码密钥:在代码中硬编码密钥,或者将密钥以明文形式存储在配置文件中。这使得密钥容易被未授权的人访问,尤其是在源代码公开或配置文件被泄露的情况下。
  2. 密钥复用:为了简化管理,使用同一个密钥进行多种不同的加密任务。这种做法大大增加了密钥被破解的风险,一旦密钥被破解,所有使用该密钥加密的数据都会受到威胁。
  3. 硬编码密钥:在代码中硬编码密钥,或者将密钥以明文形式存储在配置文件中。这使得密钥容易被未授权的人访问,尤其是在源代码公开或配置文件被泄露的情况下。
  4. 忽视密钥的生命周期管理:一旦生成密钥,就不再更换或更新。不定期轮换密钥会增加密钥被破解的风险,且一旦密钥泄露,长期内的数据都将不再安全。
  5. 不适当的密钥存储:将密钥存储在不安全的环境中,例如普通的数据库或文件系统。未经加密保护的密钥容易被窃取,尤其是在遭受数据泄露或系统入侵时。
  6. 缺乏合适的访问控制:对密钥访问权限控制不严,未实施基于角色的访问控制(RBAC)。这可能导致未授权用户访问和使用密钥,增加内部威胁的风险。

这里面部分原因是安全的专业知识不够,或者图一时方便,或者条件不具备(比如无法采购硬件加密机,或研发资源不足),但不无论如何,密钥的保存和使用是一整套完整的策略和落地,需要公司中高层重视才有完整落地的可能性。

8. 最佳实践

8.1. 实施步骤

总体而言,文章涉及的方案设计所涉及的知识储备及研发资源都是比较高的,对于一些中小公司来,建议分步骤实施:

  1. 明确密钥管理和使用的规范。
  2. 建设一个基础的密钥管理系统,统一管理和使用密钥。
  3. 对密钥管理系统进行网络和安全加固,比如独立网段,访问控制,硬件加密机等。

8.2. 用户密码管理

用户密码在所有公司都是有的,登录密码,支付密码等归属这类。也经常在网上看到新闻说一些大公司的用户密码是明文保存在数据库中并被泄露。

密码设计需要遵守以下几个准则:

  1. 前端需要非对称加密后传给后端。
  2. 后端需要解密后,再加上盐值重新对称加密后保存到DB。

为什么使用用户盐值?因为每个用户的盐值都不一样,这样即使两个用户原始密码是一样的,加密出来的密文也是不一样的。

为什么前端需要非对称加密?因为公钥是可以公开的。

为什么后端需要对称加密用户的密码,而不是使用散列?因为可以做密钥轮换。如果不考虑密钥轮换,可以使用SHA256散列算法。

为什么使用硬件加密机?因为更安全,没有条件的情况下,那就使用SHA256散列算法更安全。

这里给一个简单的实现参考。

说明:

  1. 首先由加解密服务生成RSA公钥,给到前端。
  2. 用户输入的密码,经RSA公钥加密后转到后端,后端读取用户盐值,一起传给加解密服务进行转加密。
  3. 加解密服务先使用RAS私钥解密,然后重新把密码明文和盐值对称加密返回。
  4. 后端保存密码密文到数据库。

9. 结束语

正如开头说的“密钥的价值等于数据的价值”,如果你的数据价值无可估量,那么你的密钥价值也是无可估量的。无论对于支付系统还是非支付类系统,密钥管理是同样重要的。构建一个高效、安全且可靠的密钥管理系统(KMS)不但是支付系统设计中的核心任务,也是每家互联网公司开展业务的核心任务,只是有很多公司没有意识到这点。

通过今天这篇文章,我们深入探讨了金融级密钥管理系统的基本概念、设计原则、以及核心的架构方案,旨在为读者提供一个全面、深入的视角来理解KMS在支付系统中的关键作用及如何设计与实现。此外,我们还讨论了如何通过密钥的分级管理、访问控制、工作密钥版本管理、隔离部署、性能设计和容灾设计等细节设计,确保密钥的安全性和系统的稳定性。整个设计虽然有点复杂,尤其是对没有安全经验的研发同学来说,但是在支付的世界里,安全是最基础的要求。

最后,感谢阅读和关注,希望这篇文章能够对你的工作有用。

这是《百图解码支付系统设计与实现》专栏系列文章中的第(28)篇。和墨哥(隐墨星辰)一起深入了解支付系统的方方面面。

精选

专栏地址百图解码支付系统设计与实现
《百图解码支付系统设计与实现》专栏介绍
《百图解码支付系统设计与实现》专栏大纲及文章链接汇总(进度更新于2023.2.4)
领域相关(部分)
支付行业黑话:支付系统必知术语一网打尽
跟着图走,学支付:在线支付系统设计的图解教程
图解收单平台:打造商户收款的高效之道
图解结算平台:准确高效给商户结款
图解收银台:支付系统承上启下的关键应用
图解支付引擎:资产流动的枢纽
图解渠道网关:不只是对接渠道的接口(一)

技术专题(部分)
交易流水号的艺术:掌握支付系统的业务ID生成指南
揭密支付安全:为什么你的交易无法被篡改
金融密语:揭秘支付系统的加解密艺术
支付系统日志设计完全指南:构建高效监控和问题排查体系的关键基石
避免重复扣款:分布式支付系统的幂等性原理与实践
支付系统的心脏:简洁而精妙的状态机设计与核心代码实现
精确掌控并发:固定时间窗口算法在分布式环境下并发流量控制的设计与实现
精确掌控并发:滑动时间窗口算法在分布式环境下并发流量控制的设计与实现

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/668140.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RK3568平台 设备模型基本框架-kobject 和kset

一.什么是设备模型 字符设备驱动通常适用于相对简单的设备,对于一些更复杂的功能,比如说电源管理和热插拔事件管理,使用字符设备框架可能不够灵活和高效。为了应对更复杂的设备和功能,Linux内核提供了设备模型。设备模型允许开发…

Centos7安装图形界面并使用Win10远程桌面连接

Centos7安装图形界面并使用Win10远程桌面连接 一、关闭防火墙和selinux二、安装Server with GUI三、设置系统默认启动进入GUI界面四、安装epel库和xrdp五、启动xrdp并设置成开机自启六、win10电脑打开连接 一、关闭防火墙和selinux #临时关闭防火墙 [rootse1215 ~]# systemctl…

WordPress从入门到精通【安装部署】

初识WordPress WordPress,简称WP,其简称的由来是取英文单词“word”与“press”的首字母 WP中文官网 1WP主站(英文) 官方标称,已有43%的网站在使用WordPress WordPress亮点 WP使用PHP语言开发,兼容性极…

python推荐算法在汽车用品商城营销系统 django+flask

本论文拟采用计算机技术设计并开发的汽车营销中的设计与实践 ,主要是为用户提供服务。使得会员可以在系统上查看汽车商品、汽车快讯、还可以咨询客服,管理员对信息进行统一管理,与此同时可以筛选出符合的信息,给笔者提供更符合实际…

FFMPEG推流到B站直播

0、参考 ffmpeg安装参考小弟另外的一个博客:FFmpeg和rtsp服务器搭建视频直播流服务-CSDN博客推流参考:用ffmpeg 做24小时推流直播_哔哩哔哩_bilibili 一、获取b站直播码 点击开始直播后,会出现以下的画面 二、ffmpeg进行直播推流 ffmpeg -r…

网络规划与部署实训

一 实训目的及意义 本周实训主要是了解网络规划与部署,熟悉三大厂商华为、思科、锐捷交换机路由器以及相关协议的原理和配置,提高学生的动手能力和分析规划部署能力。 实训主要针对计算机网络系统集成的设计与实现的实际训练,着重锻炼学生熟练…

Flutter开发iOS问题记录

一、版本适配问题 warning: The iOS deployment target ‘IPHONEOS_DEPLOYMENT_TARGET’ is set to 10.0, but the range of supported deployment target versions is 12.0 to 17.2.99. (in target ‘Protobuf’ from project ‘Pods’) 可以通过在podfile中配置解决。 pos…

docker数据管理

docker数据管理 1.数据卷2.启动一个挂载数据卷的容器3.查看数据卷的具体信息/删除数据卷4.挂载主机目录 1.数据卷 数据卷 是一个可供一个或多个容器使用的特殊目录,它绕过 UnionFS,可以提供很多有用的特性: 数据卷 可以在容器之间共享和重用…

音频二维码怎么制作出来的?支持多种格式音频生码的方法

怎么把一个音频的文件做成二维码图片呢?在日常工作和生活中,有很多的场景会需要使用音频类型的文件来展示内容,比如常见的英语听力、课程、听书等类型的内容,现在都可以用二维码展示。而且现在生成音频二维码的方法也很简单&#…

【下一代分布式追踪】将Trace扩展到网络设备

下一代分布式追踪—将Trace扩展到网络设备 一、技术背景二、研究动机三、方法数据采集:数据整合:路径重建:可视化与分析: Foxhound,Foxhound四、典型案例五、结论 一、技术背景 随着云计算和微服务的普及,…

【刷题题解】编辑距离

给你两个单词 word1 和 word2, 请返回将 word1 转换成 word2 所使用的最少操作数 。 你可以对一个单词进行如下三种操作: 插入一个字符删除一个字符替换一个字符 这道题也是,一眼动态规划,乍一看感觉很复杂,仔细思考…

挑战杯 python 机器视觉 车牌识别 - opencv 深度学习 机器学习

1 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 基于python 机器视觉 的车牌识别系统 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分工作量:3分创新点:3分 🧿 更多资…

基于ESP8266 开发板(MCU)遥控小车

遥控小车 ​ 遥控界面 ​ 【项目源码】 第一版ESP8266 https://github.com/liyinchigithub/esp8266_car_webServerhttps://github.com/liyinchigithub/esp8266_car_webServer 第二版ESP32 GitHub - liyinchigithub/esp32-wroom-car: 嵌入式单片机 ESP32 Arduino 遥控小车&a…

前端学习第4天

一、复合选择器 1.后代选择器 2.子代选择器 3.并集选择器 4.交集选择器 5.伪类选择器 1.伪类-超链接(拓展) 二、CSS特性 1.继承性 body放在style中 2.层叠性 3.优先级 属性 !important;(最高优先级) 1.优先级-叠加计算规则 2.em…

Linux 驱动开发基础知识——设备树的语法驱动开发基础知识(九)

个人名片: 🦁作者简介:学生 🐯个人主页:妄北y 🐧个人QQ:2061314755 🐻个人邮箱:2061314755qq.com 🦉个人WeChat:Vir2021GKBS 🐼本文由…

YoloV8改进策略:HAM混合注意力机制改进YoloV8|多种改进,多种姿势涨点|代码注释详解

摘要 HAM通过快速一维卷积来缓解通道注意机制的负担,并引入通道分离技术自适应强调重要特征。HAM作为通用模块,在CIFAR-10、CIFAR-100和STL-10数据集上实现了SOTA级别的分类性能。 论文链接:https://www.sciencedirect.com/science/article/abs/pii/S0031320322002667?vi…

python接口自动化之接口测试用例(详解)

简介 接口测试是软件测试中非常重要的一种测试类型,它主要针对系统的接口进行测试,检查接口之间的交互是否符合预期。在进行接口测试时需要注意以下几个方面: 接口测试用例设计 接口测试用例设计需要考虑到接口的输入、输出、边界条件、异常…

基于Springboot的兼职网(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的兼职网(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构&#xff0…

《动手学深度学习(PyTorch版)》笔记7.2

注:书中对代码的讲解并不详细,本文对很多细节做了详细注释。另外,书上的源代码是在Jupyter Notebook上运行的,较为分散,本文将代码集中起来,并加以完善,全部用vscode在python 3.9.18下测试通过&…

DevOps落地笔记-14|部署流水线:打造一站式部署的关键平台

上一课时我主要介绍了实现自动化测试的范围、流程和结构图,自动化测试是持续集成实践不可或缺的一部分,从而使得软件向高效率和高质量迈进了一大步。持续集成主要关注的是代码是否可以编译成功、是否可以通过单元测试和验收测试等。但持续集成并不能实现…