阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

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

评论 1 条评论

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

菜单栏图标管理 Bartender 5 for mac最新

mac大玩家j

Mac软件 菜单栏软件 菜单栏管理软件

Office下载 办公软件Office 2019 mac永久激活版

mac

办公软件 苹果mac Windows软件 office 2019

脱颖而出!云起无垠荣获第二届“陇剑杯”优胜奖

云起无垠

软件测试/测试开发丨ChatGPT在测试计划中的应用策略

测试人

人工智能 软件测试 测试开发 ChatGPT

哪款国产堡垒机好用便宜实惠?大家推荐一下!

行云管家

网络安全 数据安全 堡垒机 国产

直销系统开发|直销系统开发详解

V\TG【ch3nguang】

深度学习之“切图”

矩视智能

深度学习

以创新抵御经济环境压力:自动化测试ReadyAPI帮助企业平衡软件质量与成本控制

龙智—DevSecOps解决方案

自动化测试

2023 届的字节跳动技术新人,个个都是宝藏同学

字节跳动技术范儿

字节跳动 offer 校招

一篇聊聊Mybatis插件开发

互联网工科生

sql 数据 mybatis

鲸鸿动能加入气候行动,与野生救援(WildAid)探索公益新玩法

最新动态

ByConity 技术详解之 ELT

字节跳动开源

大数据 开源 实时数仓 Clickhouse 数仓

数字货币交易平台,专业数字货币交易系统开发

V\TG【ch3nguang】

PPT | 智能工厂生产制造执行系统(MES)建设方案

工赋开发者社区

文档信息抽取技术:从非结构化文本到结构化信息的旅程

合合技术团队

人工智能 技术 文档 文档抽取

广东汕头等保测评机构有哪些?位于哪里?

行云管家

等保 等级保护 等保测评 汕头

干货丨中国移动5G数字工厂引领工业数字化未来(附PPT)

工赋开发者社区

【效率提升】maven 转 gradle 实战 | 京东云技术团队

京东科技开发者

maven 编译 Gradle 打包工具 企业号9月PK榜

从 Hackathon 战队到创业公司,和开发者们聊聊真实世界 AI Apps 的基础设施丨活动预告

PingCAP

数据库 开发 hackathon TiDB pingCAP

软件测试/测试开发丨利用人工智能ChatGPT自动生成架构图

测试人

人工智能 软件测试 ChatGPT

企业微信 API 接口调用教程:从入门到精通

Liam

后端 后端开发 API 开放 API 企业微信开发

Mac苹果电脑无线鼠标连不上怎么办

柠檬与橘子

聊聊wireshark的进阶使用功能 | 京东云技术团队

京东科技开发者

网络协议 Wireshark 抓包 企业号9月PK榜

亚马逊云科技面向 macOS 的 Amazon 云服务器 EC2 M1 Mac 实例

亚马逊云科技 (Amazon Web Services)

存储 VPC EC2

苹果Mac电脑3D家居设计 Live Home 3D Pro 激活中文版

胖墩儿不胖y

3D Mac软件 家居设计软件 三维家居设计

Go语言高级特性解析与实践

这我可不懂

Go 语言 并发模型

如何正确地计算经过时间(elapsed time)

redcoder54

Java 时钟同步

Golang 的 GMP:并发编程的艺术

树上有只程序猿

golang GMP

这个时代,由消费主导的敏态数据更值钱

ToB行业头条

基于Kubernetes的Serverless PaaS稳定性建设万字总结

Serverless Devs

云计算 Serverless 运维 托管

CRM系统开发要多少钱_CRM管理系统开发报价

V\TG【ch3nguang】

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