50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

使用 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:292928

评论 1 条评论

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

JetBrains pycharm pro 2024最新永久激活码 pycharm2024下载安装

Rose

互动LED地砖屏的独特性

Dylan

科技 LED display LED显示屏 led显示屏厂家

mac触控板增强神器 BetterTouchTool for Mac破解及安装教程

Rose

苹果电脑几款好用的效率翻倍工具,轻松管理剪贴板!

Rose

adobe AU2024系统要求 附Audition 2024中文破解版安装包 Mac/win

Rose

抖音商品sku数据接口(Dy.item_sku)丨抖音平台API数据接口指南

tbapi

抖音商品详情数据接口 抖音API接口 抖音商品sku接口

告别音频瑕疵,迎接完美音质——iZotope RX 11,音频工程师的必备神器

Rose

支持M1的Photoshop 2021 for mac中文直装版安装包分享

Rose

GreatSQL 中为什么 Update 不会被锁等待

GreatSQL

研究揭秘生成式AI惊人耗水量!训练1个模型相当于165人1年总用水量!武汉大学首个人形机器人“天问”|AI日报

可信AI进展

基于微信小程序的竞赛答题小程序开发笔记(一)

CC同学

AI Native平台,跨越AI应用从创新到生产的鸿沟

阿里云大数据AI技术

人工智能 阿里云 云栖大会

云起无垠荣获第九届“创客中国”网络安全专题赛二等奖

云起无垠

邮储银行,奔跑在智能化软件开发的春天里

脑极体

AI

使用 fabric.js 开发移动端 H5 图片编辑器细节

秦少卫

Fabric.js 图片编辑器 开源图片编辑器 开源vue图片编辑器 vue图片编辑器

Nginx配置最全详解(万字图文总结)

江南一点雨

鸿蒙保障应用开发安全的技术措施

芯盾时代

鸿蒙 嵌入式

大模型时代下的新一代广告系统

京东零售技术

人工智能 算法 大模型

对HttpServletRequest中的Header进行增删

派大星

HttpServletRequest

快速生成应用:AI大模型与低代码平台如何无缝结合提升效率?

天津汇柏科技有限公司

低代码 AI 人工智能

无代码/低代码平台集成能力深度分析

NocoBase

低代码 无代码 集成能力

2024开放原子开源生态大会将启,深开鸿与您一起共促生态繁荣

科技热闻

一位架构师的自述:在尚未踏入的世界成为你自己

京东零售技术

架构 代码人生 技术成长

DBeaverEE:专业级数据库管理工具,让数据管理更高效

Rose

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