从0到1,趣店集团的云上架构设计

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 本次阿里云云栖社区行业圆桌论坛上,趣店集团总架构师徐章健与阿里云数据库产品经理王义成共同探讨了趣店集团上云实践之路,并且分享了趣店集团对于数据库层面的思考的实践和在基础架构设计上的经验,以及趣店对于消费金融风控的思索和探索。对话行业大咖,引领云端科技,畅谈云上话题,尽在阿里云云栖社区行业圆桌论坛。
摘要:本次阿里云云栖社区行业圆桌论坛上,趣店集团总架构师徐章健与阿里云数据库产品经理王义成共同探讨了趣店集团上云实践之路,并且分享了趣店集团对于数据库层面的思考的实践和在基础架构设计上的经验,以及趣店对于消费金融风控的思索和探索。对话行业大咖,引领云端科技,畅谈云上话题,尽在阿里云云栖社区行业圆桌论坛。

以下内容根据阿里云行业圆桌论坛视频整理而成。视频传送门,请点击这里

本期嘉宾介绍:
徐章健,趣店集团总架构师;
王义成,阿里云数据库产品经理。

首先,徐章健简单介绍了趣店集团的基本业务情况,趣店集团是2014年3月份成立的,前身是趣分期,在2016年趣分期正式升级为趣店集团。趣店集团目前整体业务分为两大部分:来分期和趣店,提供现金和实物分期这两种服务。总体而言,趣店集团属于消费金融行业。

上云之路

对于像趣店这样消费金融类的平台而言,在上云的过程中以及在选择云计算服务提供商的时候,在基础架构的设计层面,考虑到的出发点有哪些呢?

徐章健谈到趣店集团的产品从一开始就是构建在云上的,其实在刚开始上云的时候,趣店的确调研了很多的云服务提供商,最终选择阿里云是基于如下几个方面的考虑:
  1. 服务的能力、可靠性以及稳定性,对于任何一个企业或者是创业团队而言,这都是被看重的方面。
  2. 基础组件或者说是基础的服务能力,这里面包括核心的RDS数据库支持,Redis以及MQ等等这些服务。这些服务可能有的云厂商能够提供,但是很多厂商却不能。而阿里云拥有这一系列非常丰富的产品,其基础组件的产品线也非常完善。对于像趣店这样的创业团队而言,初期最需要关注的是业务的发展,可能没有太多的人力、物力和财力去做基础架构,这时如果云服务提供商能够为创业团队提供更多的基础服务的保障,当然会被优先选择。
  3. 市场评价或者说是口碑,趣店也非常看重阿里云的口碑,这一点也是值得创业团队关注的。
所以趣店最终选择阿里云其实是对于服务能力、基础组件以及市场评价这样的几个指标进行综合性评定之后做出的选择。

趣店作为消费金融类的平台,在上云过程中,有没有政策方面的特殊限制呢?

徐章健谈到从这一点来讲,趣店的确和其他互联网公司不完全一样,因为趣店属于消费金融行业。在数据层面,首先消费金融行业对于数据的安全性要求是非常高的;其次,金融监管上存在着两地三中心容灾这样的要求,这一部分与其他互联网公司是不同的。

趣店集团的上云之路,其实是从2014年3月份开始创业时就开始的。在刚开始的时候,团队也没有太多的考虑,因为自建IDC肯定是不现实的,因为对于任何创业团队而言,购买硬件以及各种运维的成本都将是一笔不小的开销,所以趣店在开始时的技术方向就是基于云的。

这时候问题就出现了,就是应该选择哪家云计算服务提供商以及应该选用云上的哪些服务。正如之前所提到的,无论从趣店调研的结果来说,还是对于云计算服务提供商进行的对比来说也好,在进行综合的评定之后,在初期就选择了阿里云的ECS作为最基础的服务。趣店的产品是基于LAMP架构设计的,使用PHP进行开发,后端所使用的Redis和RDS也是非常核心的部分,所以一些核心的数据在最开始也就是在使用阿里云的RDS进行存储。

随着趣店业务的发展,就不断地会有一些更大的挑战和新的需求出现。因为架构设计已经在云上了,此时就需要开始思考如何通过阿里云帮助企业将业务推动得更快,所以在这个过程中趣店就使用了阿里云很多其他的服务,比如使用Cache进行加速,使用MQ服务进行解耦以及进行异步化等等,在这个过程中,阿里云的各个产品线和服务是逐步地被趣店的产品使用起来的。

从整个过程来看,可以说趣店对于阿里云存在着一个比较深的合作关系。只要有需求一来,技术团队首先会去思考阿里云有没有这样的服务,有的话就会去采用。徐章健谈到对于创业团队而言,创业项目从0到1的这个过程一定要以最快的方式实现,所以在发展初期时,可能没有太多的精力去维护趣店的基础架构,所以就需要依赖于阿里云强大的支持。徐章健表示选择借助阿里云实现上云是趣店创业将近三年以来选择的比较正确的一条路,这条路帮助趣店基于阿里云实现了对于产品的快速迭代。

那么作为消费金融领域内的企业,趣店存不存在类似于双11这样的秒杀场景呢?在面临大流量、高并发这样的场景的冲击时,趣店是如何应对挑战的呢?

徐章健谈到双11对于趣店而言,其实也和双11对于阿里一样是一个非常大的考验。接下来,徐章健简单地分享了趣店为了应对双11所做的准备,也就是从消费金融行业的角度分享了如何应对双11的大流量、高并发场景的考验。

首先徐章健谈到趣店也会有全链路压测机制,每年会进行三轮的全链路压测,大约会在3月份、8月份和10月份,全程为双11做准备。其次,因为流量会存在脉冲,有时会出现流量的波峰。那么为了应对这样的大流量,趣店会对于一些原本长链路的服务进行扁平化处理,在架构层面进行一些调整,比如加入MQ进行解耦和削峰,当流量过来时,先在MQ中进行缓存,后端基于不同的处理能力加上不同的Worker,将MQ中的消息向后端的RDS和Redis进行分发,这样做的核心目的就是为了保障后端服务的稳定性,保证后端不被这波流量击垮。最后一部分,就是在RDS或者说DB层面,也需要进行专项的优化。

d4e5b0e251b950c9fbb1b2dc523105382675394a

趣店平台架构体系图

趣店数据库选型的思考

其实最近几年数据库技术发展还是比较迅速的,从最初的关系型数据库发展到NoSQL数据库再到分析型数据库。那么对于趣店而言,在对数据库类型进行选型时是基于什么样的思考呢?


徐章健谈到对于关系型数据库而言,趣店核心部分采用的是阿里云的RDS,除此之外还会使用到一些PG,也就是目前用到了MySQL和PG这两个开源的数据库。另外就是对于NoSQL而言,趣店目前主要使用了Redis,以及阿里云能够提供集群支持的MongoDB数据库。


其实,趣店最初做Redis时还是自己创建并维护的,但是后来发现运维以及故障解决方面存在问题,或者说技术处理问题的能力水平还是不够的,所以最后进行了转型,将自建Redis这部分转移到阿里云提供的Redis集群上去,其实阿里云的Redis服务在公测时还是不稳定的,但是经过了一年多的磨合,目前来看,阿里云的Redis服务已经上了一个大的台阶,有了很大改善和提升,而且相信在未来阿里云的Redis服务也会有更大的发展空间。

正如上面谈到的,趣店的数据库其实分为了两大类,也就是像MySQL这样的传统的关系型数据库以及像Redis和MongoDB这样的NoSQL数据库,但是新型的数据库与传统关系型数据库在业务需求上往往是不一致的,那么对于像趣店这样的偏向于金融类的业务而言,对于传统型数据库的诉求和需求是什么呢?

徐章健谈到对于传统数据库而言,首先会对于其服务的稳定性非常看重,对于像RDS这样集群性质的数据库而言,其可靠性、可扩展性以及安全性都是互联网金融行业的企业比较关注的。而对于NoSQL这部分来说,趣店更看重的是稳定性和性能,特别是对于在像双十一这种场景下,大流量过来的时候,需要去考虑性能问题应该如何解决,这时NoSQL就派上用场了。

对于RDS的稳定性而言,趣店使用了RDS已经经过了三年的时间,徐章健认为阿里云的RDS总体上而言是比较稳定的,但同时对于趣店而言,在稳定性上则会有更高的要求,主要表现在以下的两个方面:
  1. 数据安全,趣店所有的用户信息以及交易记录都是存储在RDS中的,那么如何保证这部分数据不丢失,这是一个重要的需求。
  2. 弹性扩展,业务的交易量是不断扩增的,那么如何保证数据不会成为存储的瓶颈,以及如何使存储能够更好地扩展而不会影响业务的快速发展,这也是目前比较关心的。
对于RDS的基于逻辑业务的拆分,也就是大家说的分库分表的功能来讲,目前来看,通过阿里云提供的服务以及趣店自身的策略已经可以非常好地满足需求了。而在另外一个层面上,趣店还会有更高的要求,就是需要构建两地三中心,所以在RDS层面会有一些灾备的需求。所以趣店后来选择了阿里云的RDS的灾备功能,目前在多个机房对于核心数据库都进行了备份。基于这样的场景,再深入一点去考虑,其实趣店希望不通过业务去干预RDS层面的分库分表,而是希望在DB层面或者是组件层面去做这样的事情。所以后来趣店调研了阿里云的DRDS,后续也希望通过DRDS实现业务方不需要感知底层的存储,而是能够通过数据库层面的核心技术组件来解决问题。

而对于数据库的安全层面而言,趣店目前在做三个维度的安全:
  1. 链路层面,目前趣店使用了阿里的云盾服务来保证请求的安全。
  2. 引擎层面,阿里云数据库服务的底层会对于数据进行加密,即便被脱库,对方得到的也只是加密后的文件,需要有密匙才能进行解析,所以能够实现引擎层面的安全。
  3. 核心业务层面的字段加密,这部分与业务的关联关系会更重一些,比如金融行业的几个要素:身份证、密码以及手机号等等这些都是要进行字段加密的。
总结而言,趣店对于传统型数据库的需求一部分在于可靠性上,需要两地三中心的模式,需要主区域存在多个可用区,而在异地则需要实时的备库,而趣店借助阿里云的RDS实现了两地三中心的策略。另一部分的需求则在于数据库的可扩展性上,核心诉求集中在对于业务无限扩展以及海量并发数据的支持上,这部分可以使用阿里云的分布式数据库DDRS实现。另外最核心的问题还是安全,包括链路安全、引擎存储安全以及字段的安全,字段安全主要依靠业务方面实现,而链路和存储部分的安全则可以借助阿里云提供的服务实现。

而趣店对于新型数据库的诉求集中在稳定性和性能部分,也许阿里云的Redis服务在最初公测时期的稳定性表现并不算特别优秀,但是最近一年,阿里云的Redis数据库进行了大幅度的提升,进行了包括系统架构上的优化以及与大的中台系统进行合并等,整体上迅速提升了稳定性。

而在性能方面,比如像面对双十一的挑战时,Redis有没有能够帮助业务快速成长的点呢?

徐章健谈到对于Redis的性能而言,面对双十一的挑战是没有问题的。阿里云Redis的扩展性以及集群的模型对于性能天然上就有非常不错的支持,而Redis本身的引擎也非常强,所以性能方面的整体是比较不错的。

趣店最初使用了自建的Redis,而现在为了应对扩展性使用了阿里云的集群版Redis,那么针对于两种方式的对比,对于业内的技术朋友有什么样的建议呢?什么样的方式会更适合于初创企业的成长呢?

其实对于初创型公司,在进行基础架构设计的时候,需要关注于重点。

从趣店的角度而言,在成长初期的时候,不适宜引入中间件这样的技术组件,首先因为初创公司的技术资源是非常有限的,所以需要聚焦于自身的业务发展,对于基础架构的投入不可能会非常多。在这种情况下,如果要引入中间件或者技术组件,就需要深入地了解其内部的机制,对于出现的问题需要能够跟进,如果不能达到这种能力,那么就最好就不要引入中间件,特别是存储中间件。

徐章健在给出的建议中还谈到,如果在业务能够接受的情况下,就去云上通过像阿里云的Redis集群这样的服务去实现,这样其实就往往能够满足需求,如果还有更高的需求,比如像容灾、主备这些需求,在业务的架构层面就需要进行更多的思考,不能完全依赖于Redis,因为任何一个版本的Redis或多或少都有出现问题的概率,针对这样的问题一定要在业务层面采取一定的预防措施。

趣店基础架构设计实践经验

趣店在架构设计方面有什么样的经验可以进行分享?

徐章健谈到对于初创型公司的基础架构层面的把握来说,以趣店为例,首先为了快速地推进业务发展,趣店在技术上采用了LAMP架构。这样的基础架构从整个业务层面来看,核心就在于后端的存储。因为对于LAMP架构的应用而言,PHP开发起来会非常快速,无论是性能还是开发成本而言都是比较不错的,所以对于正在创业路上的朋友们,一定要更多地关注DB层面,首先就应该建立DB的规范。

4707326c9b483cdaf93f146537660e38cb0ea32b

趣店创业初期架构图


45bf8c7c34b12810eb2682454085f3c6097da75a

业务快速发展期架构图


趣店之前出现过一个很痛苦的事情,由于原来没有DB的规范,所以在MySQL里面的一些数据库的列无限多,有的达到上百列,并且还存在各种大的字段。这样的不规范就为后续的工作埋下了巨大的坑,之后为了填上这个坑,技术团队花费了非常大的代价。如果能够在初期花更多的时间在DB层面设计评审上,后期维护以及扩展就会非常方便。

而对于另外一部分,就是服务稳定性以及性能提升而言,可能大家都知道使用缓存机制,其实在任何一层都可以使用缓存。但是在业务构建初期的时候,不可能层层都加上缓存,建议在DB层面之前一定要加入缓存,无论使用Redis还是MemCache,都是为了防止DB被打垮。所以DB其实是最值得关注的核心点,如果DB保不住,整个系统也就会处于瘫痪的状态。总而言之,在进行架构设计时需要对DB层面进行规范,另外还需要适当地使用缓存机制。

其实很多时候,在最初设计架构时并不能预测未来的发展,但是随着业务的发展,架构也需要进行不断优化,所以对于架构的优化而言,没有一个开始点也没有一个结束点,处于始终在路上的状态,需要不断去适应业务发展并调整自己的架构。

消费金融风控的思索和探索

趣店集团作为消费金融类的企业,并且一个主打业务是分期类购物,口号是“零首付分期,一秒钟体验”,那么在为用户服务的过程中,如何防止坏账的出现呢?在办理借贷、分期业务时如何保证有借有还呢?在信用评价部分,趣店是怎样做的呢?

其实如何将风控做的更好,这部分就是趣店的核心竞争力。风控的核心就是为了降低逾期率,防止坏账的出现。其实趣店去年从美国引入了CRO,她就是资深的风控专家。从趣店来看,构建风控体系大概涉及到几个维度:
  1. 趣店合理地使用了芝麻信用,而且对于芝麻信用分的使用上会进行进一步的细分。
  2. 趣店具有自建的风控模型,趣店经过三年的发展沉淀下来了很多的交易记录以及借还记录,可以基于这些大数据构建风控模型。这样当用户登录之后,基本上就可以对于用户的信用程度进行判断。
  3. 趣店会和业界主流的信用机构进行合作,通过合作获取像央行的征信记录这样的数据信息,并使用这些数据对用户进行信用评级来实现风险控制。
总之而言,就是在不同的维度做不同事情,整体上保护趣店的交易,降低逾期率,提高风控层级。

趣店的安全运维经验

其实在2016年发生了很多的安全事件,比如像MongoDB黑客赎金事件、GitLab事件等,那么趣店是如何看待这样的事件呢?在技术运维部分又有哪些经验可以分享呢?

安全问题一直是困扰着互联网企业的大问题。首先当GitLab事件发生之后,趣店集团的CTO就提出要迅速地Review自身的安全机制和数据备份机制以及容灾机制。所以当时技术团队就开始做了以下几个事情:
  1. 对于代码安全或以及备份机制进行审查,判定是否合理。之前趣店代码备份是每一个小时进行一次的,但是目前已经变为每15分钟就进行异地机房备份。
  2. 在DB安全层面进行预案演练,刚才已经提到阿里云的两地三中心分布式架构在很大程度上已经能够保证安全了,而趣店在此基础上进行了预案演练,如果真的出现某一个IDC的数据被删掉了,需要保证另一个IDC能够立刻运行起来。所以,针对于趣店的运维而言,每个月都会进行预案演练,甚至在双十一之前还会进行多轮的演练,所以也积累了多种多样的输出方法。
而针对于MongoDB事件,趣店在这一点上可以说借助了阿里云的安全能力对于一些安全事故进行了屏蔽,包括之前的几起Redis事件,也没有能够对于趣店造成太大的影响,因为趣店是处于阿里云的专有网络VPC上,基本上对于一些安全问题都是可控的。

王义成也介绍了阿里云的数据库能够帮助用户在哪些层面进行防护。其实对于数据安全防护而言,可以大致分为几个阶段:事前防护、事中防护以及事后的补救。

在事前防护阶段,阿里云提供了VPC网络,在VPC网络之下强制用户设置白名单,前端的DDoS防攻击策略以及密码的强认证等,这些都是帮助用户在事前进行防护的策略。对于像Redis或者MongoDB,在业内很多用户都是直接将其暴露于公网之上的,并且密码设置的往往会比较简单,经常会出现类似黑客赎金事件这样比较恶劣的攻击。而在云上则对于这一部分进行了保护,包括禁止公网内的访问,并且强制用户输入安全等级非常高的密码来进行事前的防护。

而对于事中防护而言,则是通过对一些数据的判断来分析出哪些SQL语句或者操作可能发生脱库或者误删除的情况,这一部分后续将通过阿里云强大引擎分析加入到事中防护部分。

而在事后进行补救的策略方面,阿里云的数据库还是做了比较多的一些事情的。比如阿里云全线的数据库产品,包括RDS、Redis以及Mongo都拥有日志审计的功能。虽然两地三中心是防护系统故障层面的比较好的策略,但是防不了内鬼或者脱库行为,所以阿里云可以提供日志审计的功能,使用户可以访问近期的详细时间点、IP地址以及相应操作的日志,以此来找出究竟是谁进行了操作。另外一部分就是数据库回滚,比方在进行大的发布时漏了一些事情时,可以直接基于7天内的任何一个时间点将数据回滚出来,这也是事后的防护工作。所以使用阿里云的数据防护能够帮助用户免去很多工作,减少在自建数据库中需要面对的痛苦。
相关文章
|
8月前
|
安全 网络虚拟化 云计算
阿里云转发路由器Transit Router:构建云上高效、灵活且安全的网络架构之利器
本评测报告围绕阿里云转发路由器Transit Router(TR)在跨地域跨VPC网络互通、企业云上网络架构规划和第三方SD-WAN设备对接三个场景的表现进行了详细评估。评测结果显示,TR凭借强大的路由控制能力和灵活的互通策略,在云上构建高效、灵活且安全的网络架构方面表现出色。同时,TR与第三方SD-WAN设备的良好兼容性也为企业提供了更多组网选择。本报告旨在为企业在云上网络架构规划和部署过程中提供参考和指导。
|
2天前
|
容灾 网络协议 数据库
云卓越架构:云上网络稳定性建设和应用稳定性治理最佳实践
本文介绍了云上网络稳定性体系建设的关键内容,包括面向失败的架构设计、可观测性与应急恢复、客户案例及阿里巴巴的核心电商架构演进。首先强调了网络稳定性的挑战及其应对策略,如责任共担模型和冗余设计。接着详细探讨了多可用区部署、弹性架构规划及跨地域容灾设计的最佳实践,特别是阿里云的产品和技术如何助力实现高可用性和快速故障恢复。最后通过具体案例展示了秒级故障转移的效果,以及同城多活架构下的实际应用。这些措施共同确保了业务在面对网络故障时的持续稳定运行。
|
3天前
|
负载均衡 Serverless 持续交付
云端问道9期实践教学-省心省钱的云上Serverless高可用架构
详细介绍了云上Serverless高可用架构的一键部署流程
26 10
|
5天前
|
运维 监控 安全
天财商龙:云上卓越架构治理实践
天财商龙成立于1998年,专注于为餐饮企业提供信息化解决方案,涵盖点餐、收银、供应链和会员系统等。自2013年起逐步实现业务上云,与阿里云合作至今已十年。通过采用阿里云的WA体系,公司在账号管理、安全保障、监控体系和成本管控等方面进行了全面优化,提升了业务稳定性与安全性,并实现了显著的成本节约。未来,公司将持续探索智能化和全球化发展,进一步提升餐饮行业的数字化水平。
|
3月前
|
分布式计算 大数据 Serverless
云栖实录 | 开源大数据全面升级:Native 核心引擎、Serverless 化、湖仓架构引领云上大数据发展
在2024云栖大会开源大数据专场上,阿里云宣布推出实时计算Flink产品的新一代向量化流计算引擎Flash,该引擎100%兼容Apache Flink标准,性能提升5-10倍,助力企业降本增效。此外,EMR Serverless Spark产品启动商业化,提供全托管Serverless服务,性能提升300%,并支持弹性伸缩与按量付费。七猫免费小说也分享了其在云上数据仓库治理的成功实践。其次 Flink Forward Asia 2024 将于11月在上海举行,欢迎报名参加。
261 6
云栖实录 | 开源大数据全面升级:Native 核心引擎、Serverless 化、湖仓架构引领云上大数据发展
|
5月前
|
弹性计算 运维 关系型数据库
云上Serverless高可用架构一键部署体验与测评
在数字化转型背景下,Serverless架构因其实现业务敏捷、降低成本及提升服务可靠性而备受青睐。本文以阿里云Serverless应用引擎(SAE)为核心,展示了一种高可用、低成本且易于扩展的解决方案。通过单地域双可用区部署,构建了具备自动伸缩与故障恢复能力的架构。借助阿里云的一键部署功能,大幅简化了搭建流程,实现了快速部署,并通过性能与成本分析验证了其优势。对比传统ECS,SAE在资源利用与运维效率上表现更佳,特别适合平均负载较低的应用场景。
|
6月前
|
弹性计算 Serverless
省心省钱的云上Serverless高可用架构陪跑班开课啦!
云端问道第9期陪跑班开课啦!本课程将向您介绍,如何快速搭建云上的Serverless架构,支持服务托管、弹性伸缩和按量付费,减少企业手动资源管理和性能成本优化的工作,同时通过高可用的配置,避免可能遇到的单点故障风险。阿里云技术专家将手把手带您实操,还将针对实操中的问题进行一对一答疑!机会难得,快来参加吧!
203 9
|
6月前
|
运维 监控 Serverless
探索Serverless高可用架构:云上极简运维的新篇章
随着云计算的快速发展,Serverless 架构因其无需管理服务器、按需自动扩展等优势,逐渐成为企业应用构建的重要选择。阿里云提供的 Serverless 高可用架构解决方案,通过结合多种云服务,提供了强大的高可用性和自动化运维能力。本文将评测阿里云 Serverless 高可用架构的核心功能、优势及其应用场景,帮助读者更好地理解和使用这一解决方案。
|
6月前
|
负载均衡 安全 Cloud Native
云上负载均衡:构建高可用、高性能的网络应用架构
与云原生技术深度融合:随着云原生技术的普及和发展未来的云上负载均衡将更加紧密地与云原生技术相结合。例如与Kubernetes等容器编排平台集成实现自动化的服务发现和路由管理;与Serverless架构结合提供无缝的流量接入和请求处理能力。 安全性能提升:面对日益严峻的网络安全威胁云上负载均衡将更加注重安全性能的提升。通过引入加密传输、访问控制、DDoS防护等安全措施确保网络流量的安全性和隐私性;同时还将建立完善的安全监控和应急响应机制以应对各种安全事件和突发事件。 支持多协议和多场景:未来的云上负载均衡将支持更多种类的网络协议和应用场景以满足不同用户和业务的需求。例如支持HTTP/2、
294 0
|
6月前
|
运维 Prometheus 监控
「架构」云上自动化运维及其应用
企业在云上采用自动化运维,通过Prometheus+Grafana实现监控,Ansible进行配置管理,Jenkins+GitLab+SonarQube支持CI/CD,提升效率,降低成本。关键指标包括系统可用性、故障恢复时间等。通过自动化监控、配置管理和持续集成/部署,保证服务稳定性,促进快速迭代,确保市场竞争力。持续改进与培训是维持领先的关键。
180 0

热门文章

最新文章