利用阿里云容器服务实现高可用抢红包应用

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 红包是春节习俗,原本是讨个吉利的意图。在互联网技术高度发展的今天,用手机抢红包已经成为一种文化、一种生活方式;据支付宝统计的数据显示,2016年2月7日除夕夜,支付宝共四轮“咻一咻”互动平台的总参与次数达到了3245亿次;在21点09分,用户的参与热情达到了顶峰,“咻一咻”峰值一度达到210亿次/.

红包是春节习俗,原本是讨个吉利的意图。在互联网技术高度发展的今天,用手机抢红包已经成为一种文化、一种生活方式;据支付宝统计的数据显示,2016年2月7日除夕夜,支付宝共四轮“咻一咻”互动平台的总参与次数达到了3245亿次;在21点09分,用户的参与热情达到了顶峰,“咻一咻”峰值一度达到210亿次/分钟。

业务需求催生技术升级,随着红包业务的大众化、普遍化,我们对高可用、可扩展、按需提供服务的技术架构要求越来越高。下面介绍一种基于阿里云容器服务及相关云产品组成的高可用抢红包系统框架;

系统架构:

下图给出了基于阿里云相关产品实现的抢红包系统架构,所涉及的产品包括阿里云容器服务,MNS,RDS,SLB,SLS等。

框架图

用户端:模拟用户抢红包软件(如支付宝),能发送用户的的抢红包请求,并携带身份ID等信息;根据服务端的响应,把中奖信息反馈给用户;

请求处理逻辑:用户发送抢红包信息到“请求处理逻辑集群”,这部分有SLB、ECS集群,ECS集群通过阿里云容器服务实现容器化。可以接收用户请红包请求,并调用接口进行身份验证、MNS获取消息(抢红包)等;通过MNS反馈消息判断是否中奖,并反馈给用户;

身份验证模块:用户验证抢红包用户的身份,可以根据业务实现不同的限制;例如约定同一个用户ID在一定时间内只能抢一次、或者随机放弃1/2的用户请求;

红包管理监控:显示当前MNS中有效红包数;进行红包发放操作,可以设定总红包数,多批次发放,以及发放时间间隔等;可以基于SLS日志服务进行红包数据统计;

MNS服务:模拟红包队列,请求处理模块通过从MNS抢消息来模拟抢红包,抢到消息的请求即为抢到红包;同时通过往MNS中发送消息模拟赛红包;

SLS服务:日志存储服务,会把抢红包过程中产生的状态日志(中奖、未中奖、验证错误等)进行统计、并持久化;

RDS服务:存储用户相关信息,验证抢红包用户的身份;持久化红包发放信息,包含抽中红包用户的ID,时间,红包ID等;

SLB服务:对用户请求进行负载均衡;

其中MNS、SLS、RDS、SLB都通过阿里云提供的云服务实现,其余组件均通过简单的代码实现,并通过容器服务进行微服务化;

下图以容器服务为中心描述了系统之间的调用:

框架图

实现细节:

系统通过4个微服务相互配合,并引用RDS、MNS、SLS等提供的服务能力;下面是通过容器服务部署的编排文件内容:

webpage:
  image: registry.cn-hangzhou.aliyuncs.com/junbao/redpacket_webpage:v5
  restart: always
  labels:
    aliyun.routing.port_80: http://test/webpage
    aliyun.logs: /var/log
    aliyun.probe.url: http://container/index.jsp
    aliyun.scale: '3'
    aliyun.auto_scaling.max_cpu: '70'
    aliyun.auto_scaling.min_cpu: '40'
    aliyun.auto_scaling.step: '1'
redpacket:
  image: registry.cn-hangzhou.aliyuncs.com/junbao/redpacket_redpacket:v12
  restart: always
  environment:
    DB_HOST: "rm-bp1y1o7ga6hsm257o.mysql.rds.aliyuncs.com"
    DB_PORT: "3306"
    DB_NAME: "redpacket_account_check"
    DB_USER: "docker"
    DB_PASSWD: "***"
    ACCOUNT_CHECK_IP: "account.local"
    MNS_URL: "http://1171330362041663.mns.cn-hangzhou.aliyuncs.com"
    ACCESS_KEY_ID: "hDfTgHQ5xKn45q8a"
    ACCESS_KEY_SECRET: "*******"
  external_links:
    - "account.local"
  labels:
    aliyun.routing.port_80: http://test/redpacket
    aliyun.logs: /var/log
    aliyun.probe.url: http://container/redpacket/test
    aliyun.scale: '2'
    aliyun.log_store_redpacket: /var/log/redpacket_access.log
    aliyun.log.timestamp: "false"
    aliyun.auto_scaling.max_cpu: '70'
    aliyun.auto_scaling.min_cpu: '40'
    aliyun.auto_scaling.step: '1'
account:
  image: registry.cn-hangzhou.aliyuncs.com/junbao/redpacket_account:v12
  restart: always
  environment:
    DB_HOST: "rm-bp1y1o7ga6hsm257o.mysql.rds.aliyuncs.com"
    DB_PORT: "3306"
    DB_NAME: "redpacket_account_check"
    DB_USER: "docker"
    DB_PASSWD: "***"
  labels:
    aliyun.routing.port_80: account.local
    aliyun.logs: /var/log
    aliyun.probe.url: http://container/test
    aliyun.scale: '2'
    aliyun.auto_scaling.max_cpu: '70'
    aliyun.auto_scaling.min_cpu: '40'
    aliyun.auto_scaling.step: '1'
monitor:
  image: registry.cn-hangzhou.aliyuncs.com/junbao/redpacket_monitor:v18
  restart: always
  environment:
    DB_HOST: "rm-bp1y1o7ga6hsm257o.mysql.rds.aliyuncs.com"
    DB_PORT: "3306"
    DB_NAME: "redpacket_account_check"
    DB_USER: "docker"
    DB_PASSWD: "***"
    MNS_URL: "http://1171330362041663.mns.cn-hangzhou.aliyuncs.com"
    ACCESS_KEY_ID: "hDfTgHQ5xKn45q8a"
    ACCESS_KEY_SECRET: "****"
  labels:
    aliyun.routing.port_80: http://test/monitor
    aliyun.logs: /var/log
    aliyun.scale: '1'

根据上面编排模板内容介绍阿里云容器服务特点:

可伸缩性:

可通过对CPU、内存的使用限制定义容器服务的伸缩功能;

aliyun.auto_scaling.max_cpu: '70'
aliyun.auto_scaling.min_cpu: '40'
aliyun.auto_scaling.step: '1'

上面配置表示容器内CPU使用率超过70%时会自动扩展一个容器,且容器内CPU使用率低于40%时会自动缩减一个容器;详见:

https://help.aliyun.com/document_detail/26017.html?spm=5176.doc26018.6.601.fo3Esr

简单路由服务:

在编排模板中添加 routing 标签,定义相应的域名或者域名前缀。可以实现简单的 7 层协议负载均衡;

aliyun.routing.port_80: http://test/monitor

上面配置表示可以通过以下域名访问服务,其中test为域名的前缀,monitor为URL的path部分;

http://test.c61d9ad24beea4d93a4f574202f443a44.cn-beijing.alicontainer.com/monitor

集群内服务发现与负载均衡:

具体的系统中,有一些服务是不愿对外开放的,例如本系统的账号验证服务;阿里云容器服务引入了集群内负载均衡功能,您只需要使用以 .local 结尾的域名,并在依赖的服务的 external_links 中增加这个域名,依赖的服务便可以通过 .local 的域名访问到依赖的服务,并且能够配合健康检查做到自动的服务发现。

aliyun.routing.port_80: account.local
external_links:
  - "account.local"

详见:

https://help.aliyun.com/document_detail/35358.html?spm=5176.doc25984.6.654.cqipVM

日志服务:

阿里云日志服务(Log Service,简称SLS)是针对日志场景的平台化服务。适用于日志中转、监控、性能诊断、日志分析、审计等场景。容器服务提供了集成日志服务的能力,可以方便地将应用日志发送到日志服务里。

aliyun.log_store_redpacket: /var/log/redpacket_access.log

上述定义会将容器内/var/log/redpacket_access.log文件内的内容输入到相应的日志服务中;详见:

https://help.aliyun.com/document_detail/26036.html?spm=5176.doc35358.6.633.Gy4q50

系统示例

1 抢红包系统第一步首先要把红包塞进“口袋”,可以通过管理模块进行相关操作;

访问管理监控服务页面提示的访问端点,然后点击发放红包页面;

链接1

链接2

可以在页面中输入红包相关信息,红包总数、发放次数、时间间隔等;

上图中表示:分3次发放10个红包,每次的发放间隔是2秒;点击“发放红包”效果如下:

链接3

2 第二步:塞完红包后,即可进行抢红包活动;

通过Webpage页面提示的访问端点,可以登录抢红包主页面;

链接4

链接5

抢红包页面可以配置一些用户相关的信息用于红包发放时的证据;本示例中仅使用一个识别码,凭识别码信息领奖;点击抢红包即可完成操作;

链接6

3 作为抢红包的组织者除了把红包分发给用户,仍然期望对当前红包状态,以及所有红包的分布有所了解;

可以访问监控模块的数据分析页面查看相关数据,监控模块通过SLS提供的数据接口获取日志信息,并进行数据统计;这里的监控模块只是简单的demo,实际应用中日质量会非常大,可以通过实时日志分析工具进行统计;

链接7

本示例只是一个抢红包应用的简单demo,离真正线上应用尚有距离;但其中所用到的相关技术:如容器服务的弹性伸缩、负载均衡,日志服务的数据分析,消息服务高并发处理等都是抢红包应用所需的;

参考:
阿里云容器服务:
https://help.aliyun.com/product/25972.html?spm=5176.product26090.6.4.AzxFaW
SLS:
https://help.aliyun.com/product/28958.html?spm=5176.doc25974.6.15.VMW9if
SLB:
https://help.aliyun.com/product/27537.html?spm=5176.product28958.6.56.bN5R4b
MNS:
https://help.aliyun.com/product/27412.html?spm=5176.product27537.6.42.iWBZCZ
RDS:
https://help.aliyun.com/product/26090.html?spm=5176.product27412.6.47.sRItSf

相关实践学习
巧用云服务器ECS制作节日贺卡
本场景带您体验如何在一台CentOS 7操作系统的ECS实例上,通过搭建web服务器,上传源码到web容器,制作节日贺卡网页。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
2天前
|
供应链 安全 Cloud Native
阿里云飞天企业版获【可信云·容器平台安全能力】先进级认证
阿里云飞天企业版容器系列产品获中国信息通信研究院【可信云·容器平台安全能力】先进级认证,这是飞天企业版容器产品获得《等保四级PaaS平台》和《 云原生安全配置基线规范V2.0》之后,本年度再一次获得行业权威认可,证明飞天企业版的容器解决方案具备符合行业标准的最高等级容器安全能力。
阿里云飞天企业版获【可信云·容器平台安全能力】先进级认证
|
6天前
|
人工智能 运维 Kubernetes
阿里云容器服务AI助手2.0 - 新一代容器智能运维能力
2024年11月,阿里云容器服务团队进一步深度融合现有运维可观测体系,在场景上覆盖了K8s用户的全生命周期,正式推出升级版AI助手2.0,旨在更好地为用户使用和运维K8S保驾护航。
|
25天前
|
人工智能 运维 监控
阿里云ACK容器服务生产级可观测体系建设实践
本文整理自2024云栖大会冯诗淳(花名:行疾)的演讲,介绍了阿里云容器服务团队在生产级可观测体系建设方面的实践。冯诗淳详细阐述了容器化架构带来的挑战及解决方案,强调了可观测性对于构建稳健运维体系的重要性。文中提到,阿里云作为亚洲唯一蝉联全球领导者的容器管理平台,其可观测能力在多项关键评测中表现优异,支持AI、容器网络、存储等多个场景的高级容器可观测能力。此外,还介绍了阿里云容器服务在多云管理、成本优化等方面的最新进展,以及即将推出的ACK AI助手2.0,旨在通过智能引擎和专家诊断经验,简化异常数据查找,缩短故障响应时间。
阿里云ACK容器服务生产级可观测体系建设实践
|
11天前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。
|
3天前
|
监控 安全 Cloud Native
阿里云容器服务&云安全中心团队荣获信通院“云原生安全标杆案例”奖
2024年12月24日,阿里云容器服务团队与云安全中心团队获得中国信息通信研究院「云原生安全标杆案例」奖。
|
26天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
189 77
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
7天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
13天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
77 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
19天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
43 3
实战~如何组织一个多容器项目docker-compose

相关产品

  • 容器计算服务