阿里云「飞天发布时刻」2024来啦!新产品、新特性、新能力、新方案,等你来探~ 了解详情
写点什么

使用 TiDB 作为 ZaloPay 商户平台核心数据库

  • 2020-07-07
  • 本文字数:2204 字

    阅读完需:约 7 分钟

使用 TiDB 作为 ZaloPay 商户平台核心数据库

VNG 是越南领先的互联网科技公司,在 2014 年,我们被评为越南唯一一家估值 10 亿美元的创业公司。VNG 推出了许多重要产品,比如 Zalo、ZaloPay、Zing 等,吸引了数亿用户。


Zalo 是 VNG 集团的旗舰产品,发布于 2012 年,是越南使用最广泛的通讯 APP,目前活跃用户数达到 1 亿。而本文主角 ZaloPay 是一款移动支付应用,它建立在 Zalo 的基础上,继承 Zalo 生态中的诸多便利,满足用户的日常生活和商业需求。ZaloPay 发布于 2017 年,当时 Zalo 已经拥有大量用户,形成了一个生态系统。也就是说,ZaloPay 的系统必须能够处理非常大的用户量,并且有连续不断的扩展性。

ZaloPay 系统的商户解决方案

2020 年初, ZaloPay 上线了一个新功能,大约 1 亿的 Zalo 用户可以使用 ZaloPay 来转账、收款等。在越南,ZaloPay 是在线上聊天平台提供转账和支付功能的先驱。


为 ZaloPay 建立一个必须能够满足大量 Zalo 用户需求的基础架构,并不是一件容易的事,而是一个巨大的挑战。我们不能根据旧的模型来构建服务和设计架构,因为新的系统要有可扩展性、弹性、一直在线的可用性、性能监控功能,还要有严密的安全性。它必须适配尽可能多的云模式。


越南正融入世界上其他地区,迈向互联网时代的高峰,对电子钱包的需求日益增长。我们要推动各种体量的商户使用电子钱包,包括餐饮业、旅游业等的账单支付。这正是“无现金化”电商所普遍追求的目标,我们都知道,实现复杂的交易业务,需要复杂且一致的系统架构。

数据库的挑战

我们认识到业务正在迅速扩张,也清楚地意识到,在不久的将来,数据存储和数据处理会成为一个重大问题,并且这个问题需要尽早处理。随着业务的蓬勃发展,我们的系统基础架构必须能够及时响应业务的增长。


在调研数据库的解决方案时,我们发现了 TiDB,一个 NewSQL 数据库,支持 HTAP 负载,兼容流行的 MySQL 协议。在座的各位都非常了解 TiDB。我可能不需要多说 TiDB 的架构,这部分内容留给 PingCAP 的专业人士,大家当然都知道 TiDB 能做到的事情。请允许我讲一讲我对 HTAP 的理解。


HTAP 数据库的主要技术挑战在于,如何在同一个数据库里,高效处理许多高频更新的小事务和遍历多行数据的复杂查询,以及如何防止分析查询干扰业务的运行。


HTAP 的大多数应用都是通过内存技术(in-memory)实现的,内存技术可以处理大量事务,并提供预测和模拟等功能。HTAP 通过复杂的实时海量数据分析,提供即时的商业决策能力,以此改变企业的经营模式。企业决策者可以实时获知各种问题,查看结果,了解趋势,例如风险管理和欺诈检测等领域。


TiDB 是一个支持 HTAP 工作负载的 NewSQL 数据库,旨在满足数据开发、数据可伸缩性、数据分析等需求。我最喜欢 TiDB 的一点是,我可以用 TiSpark 轻松分析数据。随着业务高速发展,我们需要不断扩展数据存储容量,同时进行大量的数据挖掘,以便迅速提供业务建议,TiSpark 在这种场景下非常有用。


让我们回到 ZaloPay 和 TiDB。Zalopay 致力于移动支付领域,这是一场全新的技术革命。Zalopay 的系统需要与许多商业交易紧密结合,并迅速提供业务分析建议。TiDB 是支持混合事务处理与分析负载的新型数据库。对,这就是我们所需要的。这正是我们现在和未来都想要的数据库。

TiDB 在 ZaloPay 基础架构中的角色

我想谈谈我对数据的认识和理解。数据无所不有,无处不在。尽管人们将数据视为金矿,但由于技术和人力的限制,很少有人或机构能够挖掘这座金矿。


我从博客中读到,东南亚知名电商巨头 Shopee 将 TiDB 用于风控系统 中。他们已经从传统的分库分表 MySQL 迁移到了 TiDB。在 2019 年初,他们的 TiDB 集群已处理了大量非交易数据。他们正打算将一些交易类数据从 MySQL 迁移到 TiDB。他们还计划将 TiDB 用作 MySQL 同步方案的一部分,让 TiDB 作为 MySQL 的从库,把 MySQL 中的数据实时同步到 TiDB。


目前,ZaloPay 把 TiDB 集群运行在本地自有机器上。我刚才提到,ZaloPay 在 2020 年初推出了一项新功能,允许 1 亿多活跃用户在 Zalo 通讯 APP 中转账、支付、充值、预订酒店/旅行等。Zalo 用户可以轻松下单产品,在群聊里分享账单,在家庭群组里发红包,通过商户的 Zalo 官方账号付款,商户类型覆盖了零售业、餐饮业、服务业、电商等多个行业。商户拥有一个官方页面,就像脸书的粉丝主页一样,用户可以在 Zalo APP 中与商户网站上的产品进行交互,然后使用 ZaloPay 付款。


此外,这个功能还允许用户通过手机应用向其他人赠送礼物,比如代金券、电话卡、红包或任何东西。仅仅是常用支付领域,我们每天就有几十万笔交易。你们可以想象到,我们的 TiDB 集群工作量之大,集群每天要处理一百万个请求,令人难以置信。


未来我们可能会扩大 TiDB 在分析服务以及非交易业务中的使用。我们产品里还有许多数据挖掘系统、推荐系统等。我们已经知道 TiDB 是一个 HTAP 分布式数据库。我们从一开始就使用 TiDB,因此对我们来说,可以很容易地开发这些系统。

TiDB 带来的价值

我们的口号是 “ZaloPay,两秒付款”。要实现这个口号,我们必须改善许多业务流程和技术流程。为了实现服务,我们使用了匹配 TiDB 实现的 Golang。我们的工程师熟悉 Golang,因此,他们可以轻松阅读并理解 TiDB 源码,从而提升服务性能,优化应用程序与 TiDB 数据库核心间的软件性能。


有了 TiDB,我们可以更容易地实现服务和应用的云模式,也就是可伸缩性、弹性、监控等。


作者介绍:


Tan To Nguyen Duy,VNG DevOps 工程师,参与电子钱包 ZaloPay 基础架构的开发。


2020-07-07 17:292663

评论 1 条评论

发布
用户头像
核心交易已经用上了吗?
2022-02-21 09:04
回复
没有更多了
发现更多内容

奇妙JVM(一):Java程序员必须知道的神秘黑箱

xfgg

Java JVM

财务共享中心成功建立!用友帮助河南水投集团打造财务效率新高地

用友BIP

财务共享

移动应用架构与React Native、Flutter的关联

Onegun

flutter 移动应用 ReactNative 软件应用架构

阿里大佬随手甩出一份覆盖全网的微服务架构笔记,让我涨薪60%

程序知音

Java 微服务 spring-cloud 后端技术 spring-boot

火山引擎DataLeap联合DataFun发布《数据治理知识地图》

字节跳动数据平台

数据治理 数据开发 数据库开发 数据研发

软件测试 | LDAP常见操作指南

测吧(北京)科技有限公司

测试

财务共享真的有价值吗?

用友BIP

财务共享

阿里P9架构师推荐的Spring领域巅峰之作,颠覆了我对Spring的认知

程序知音

Java spring java架构 Java进阶 后端技术

缺乏集成和标准的协作框架,企业如何确保API质量?

龙智—DevSecOps解决方案

git API API 接口

MaxCompute 发布智能物化视图,CU 算力节省 14%

云布道师

开发者福利来了 | 京东云全系核心产品公开比价:我们承诺,买贵就赔!

京东科技开发者

数据库 云主机 京东云 云主机厂商 企业号 5 月 PK 榜

软件测试/测试开发丨Web自动化测试,强制等待与隐式等待

测试人

软件测试 自动化测试 测试开发

Python从0到1丨了解图像形态学运算中腐蚀和膨胀

华为云开发者联盟

Python 人工智能 华为云 华为云开发者联盟 企业号 5 月 PK 榜

大型企业建设财务共享中心需要重视的5个核心要素

用友BIP

财务共享

透明LED显示屏与常规屏的区别

Dylan

LCD1602液晶显示屏 显示器 LED显示屏

软件测试 | 角色介绍

测吧(北京)科技有限公司

测试

带你从0到1构建低代码平台

这我可不懂

低代码 应用开发 JNPF

快速易用pdf编辑器:PDF Expert 中文激活版

真大的脸盆

Mac Mac 软件 PDF编辑 编辑PDF文件

浅谈NFT盲盒游戏系统开发原理

Congge420

实力上榜!ONES 荣获深圳市「专精特新」企业认定

万事ONES

Apache Hudi 在袋鼠云数据湖平台的设计与实践

袋鼠云数栈

数据湖 Hudi Apache Hudi

浅谈电解电容在电路设计中的作用

华秋PCB

电路 元器件 PCB PCB设计 电解电容

能让中国联通青睐的财务共享智能报账平台是什么样的?

用友BIP

财务共享

我的 UI 组件库发布了!

DUFU

JavaScript Svelte 移动端 Tailwind UI组件库

分解GameFi链游游戏软件系统如何开发?

Congge420

在 Kubernetes 上实现高速应用交付

NGINX开源社区

nginx Kubernetes

NFTScan 正式发布 Bitcoin NFT 浏览器,支持 Ordinals NFT 和 BRC20 资产

NFT Research

Bitcoin NFT\

【技术】多端能力服务统一是一种关键的技术和架构

没有用户名丶

零信任之访问代理

Flomesh

Pipy

上海国家会计学院杨寅: 数据、业务、技术三大事项相互融合,促进财务发展

用友BIP

智能会计 价值财务

ChatGPT聊天系统开发基于GPT-3.5架构

Congge420

使用 TiDB 作为 ZaloPay 商户平台核心数据库_数据库_Tan To Nguyen Duy_InfoQ精选文章