北京云栖大会Tech Insight Workshop:《使用微服务框架快速构建一个分布式交易系统》篇

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: 本篇是北京云栖大会Tech Insight Workshop金融云主体《使用SOFA来快速构建金融级分布式交易系统》中的一个组成部分,用来介绍如何通过SOFA Boot来快速构建一个分布式微服务系统,以及如果通过金融云下中间件微服务产品来进行查看与管理。

背景介绍

本篇是北京云栖大会Tech Insight Workshop金融云主体《使用SOFA来快速构建金融级分布式交易系统》中的一个组成部分,用来介绍如何通过SOFA Boot来快速构建一个分布式微服务系统,以及如何通过金融云下中间件微服务产品来进行查看与管理。

DEMO整体架构与说明

image
在本篇中,会逐步引导学员借助SOFA Boot来创建【支付】服务(Core工程)和【交易】平台(Web工程),并且【支付】对外提供RPC服务,供【交易】平台进行调用,以及如何借助金融云进行应用的发布部署。

实验涉及SOFA产品

详细教程

创建支付服务和交易平台Web工程

看到下图则表示构建成功:
image

  • 通过IntelliJ IDEA导入已创建的工程
    image

注意:在导入向导中选择JDK1.8作为运行时环境。此外一直点击Next即可

  • 工程使用facade范式,在com.alipay.sofa.pay.facade下创建model,并创建PayOrder.java,并复制DEMO源码中对应路径下的文件内容
    core_create_facade_mo_del
  • 创建PayService接口
    core_create_facade_payservice_interface
  • 在com.alipay.sofa.pay.service下创建接口的实现类,目前尚未引入持久化层,所以这里接口的实现先返回mock数据core_create_service_impl
  • 截至目前,支付服务的程序实现部分已经初步完成,需要将刚设计的接口通过bean方式进行对外暴露,修改pay-demo-service的pay-emo-service.xml
    core_create_service_publish_bean
  • 由于该服务会通过金融云进行发布,所以需要增加如下配置core_create_service_app_properties

注意:
run.mode=NORMAL表示需要在金融云上发布/访问RPC调用
com.alipay.env=shared表示使用共享型中间件
com.alipay.instanceid在【金融云首页】-【产品与服务】-【中间件】-【中间件控制台】中的“实例标识”获得。

  • 删除test目录,该目录对本DEMO无用,并有可能会导致运行失败(core范例工程版本更新维护等原因)
    core_delete_test
  • 在保证本机maven环境设置好的前提下,开始编译支付服务
    core_compile_need_setmvnreadyfirst

构建成功,生成 【fat jar】
core_compile_done

  • 开始构建【交易】平台Web服务,参见SOFA Boot创建Web工程
    web_create_1
  • 通过IntelliJ IDEA导入已创建的【交易】平台工程
    web_import_1
  • 引用刚刚创建的【支付】服务RPC,帮助信息可以参照该文档

web_refer_bean

  • 删除工程中自动生成的index.html
    web_delete_indexhtml
  • 将DEMO范例中的静态文件和模板通过IDE移动进当前工程
    web_move_static_subfolder

web_move_template

  • 删除工程中自动生成的主类,并通过IDE移动DEMO范例代码中对应的主类至对应目录
    web_delete_applicationmain

web_copy_applicationmain

  • 通过IDE将DEMO范例代码中对应的com.alipay.demo下所有文件移动至项目对应路径
    web_copy_application_subfolders
  • 保证下列依赖包在工程中被正确引入
    image
  • 设置金融云上环境(参数含义参照支付服务创建过程)
    web_app_properties
  • 请确认当前工程下test目录已被删除
  • 编译并生成【fat jar】

注意:由于之前修改了主类,所以在编译后的运行时可能会由于IDE原因出现主类无法找到的情况,这时需要重启IDE并重新进行编译,一般即可解决问题

web_compile_done

  • 接下来就是需要在金融云上构建应用,并上传已编译好的jar包

金融云上发布已创建的SOFA Boot应用

  • 登录金融云,选择合适的环境
    core_upload_login_antcloud_workspace
  • 新增支付服务的应用:进入【产品与服务】-【应用管理】,【新建应用】并输入对应的应用信息
    webcore_antcloud_create_app_1

webcore_antcloud_create_app_2

  • 点击【确定】完成新应用的添加
    webcore_antcloud_create_app_done
  • 同样的方式添加支付平台的新应用,【应用名称】设置为“DEMO-web-console”,其他设置与支付服务应用相同(技术栈:sofa-lite2 1.0.1)。
  • 在【产品与服务】-【环境资源管理】中添加2台ECS,分别分配给【DEMO-pay-core】和【DEMO-web-service】
    webcore_antcloud_createecs_bindingapp1

webcore_antcloud_createecs_bindingapp2

webcore_antcloud_createecs

分配给【DEMO-web-service】

  • 在将应用与计算资源分配完毕后,进入【产品与服务】-【发布部署服务】-【发布包管理】,为对应【DEMO-pay-core】和【DEMO-web-service】两个应用添加发布包
    webcore_antcloud_deploymanage_core
  • 上传支付服务fat jar
    webcore_antcloud_deploymanage_core_upload
  • 上传交易平台web的 fat jar
    webcore_antcloud_deploymanage_web_upload
  • 在【产品与服务】-【环境资源管理】中创建负载均衡,并将创建好的负载均衡挂载交易平台web服务的ECS
    image

image

  • 至此,访问该台负载均衡的公网地址,以及开放端口,则可以看到发布的服务,表示【DEMO-pay-core】和【DEMO-web-service】均发布成功,且RPC调用正常
    image

通过中间件微服务产品对已发布的分布式服务进行管理

  • 点击【产品与服务】-【中间件】-【微服务】进入控制台
    image
  • 定位已发布的RPC服务
    image
  • 查看分布式服务之间的调用关系
    image
目录
相关文章
|
6天前
|
运维 供应链 安全
SD-WAN分布式组网:构建高效、灵活的企业网络架构
本文介绍了SD-WAN(软件定义广域网)在企业分布式组网中的应用,强调其智能化流量管理、简化的网络部署、弹性扩展能力和增强的安全性等核心优势,以及在跨国企业、多云环境、零售连锁和制造业中的典型应用场景。通过合理设计网络架构、选择合适的网络连接类型、优化应用流量优先级和定期评估网络性能等最佳实践,SD-WAN助力企业实现高效、稳定的业务连接,加速数字化转型。
SD-WAN分布式组网:构建高效、灵活的企业网络架构
|
1天前
|
监控 算法 网络协议
|
2月前
|
人工智能 Linux 云栖大会
看过来!2024 云栖大会操作系统技术 Workshop 怎么玩?
报名倒计时2天啦,欢迎大家来“操作系统技术Workshop”打卡。专家讲解原理、现场实战演练,AI、C++ 20专场任选。
看过来!2024 云栖大会操作系统技术 Workshop 怎么玩?
|
4月前
|
负载均衡 Java 双11
使用Java构建高可用的分布式系统
使用Java构建高可用的分布式系统
|
3月前
|
监控 Java 开发者
随着软件开发的发展,传统单体应用已难以适应现代业务需求,微服务架构因此兴起,成为构建可伸缩、分布式系统的主流
随着软件开发的发展,传统单体应用已难以适应现代业务需求,微服务架构因此兴起,成为构建可伸缩、分布式系统的主流。本文探讨Java微服务架构的设计原则与实践。核心思想是将应用拆分为独立服务单元,增强模块化与扩展性。Java开发者可利用Spring Boot等框架简化开发流程。设计时需遵循单一职责、自治性和面向接口编程的原则。以电商系统为例,将订单处理、商品管理和用户认证等拆分为独立服务,提高可维护性和容错能力。还需考虑服务间通信、数据一致性及监控等高级话题。掌握这些原则和工具,开发者能构建高效、可维护的微服务应用,更好地应对未来挑战。
82 1
|
3月前
|
机器学习/深度学习 分布式计算 PyTorch
构建可扩展的深度学习系统:PyTorch 与分布式计算
【8月更文第29天】随着数据量和模型复杂度的增加,单个GPU或CPU已无法满足大规模深度学习模型的训练需求。分布式计算提供了一种解决方案,能够有效地利用多台机器上的多个GPU进行并行训练,显著加快训练速度。本文将探讨如何使用PyTorch框架实现深度学习模型的分布式训练,并通过一个具体的示例展示整个过程。
120 0
|
3月前
|
存储 负载均衡 中间件
构建可扩展的分布式数据库:技术策略与实践
【8月更文挑战第3天】构建可扩展的分布式数据库是一个复杂而具有挑战性的任务。通过采用数据分片、复制与一致性模型、分布式事务管理和负载均衡与自动扩展等关键技术策略,并合理设计节点、架构模式和网络拓扑等关键组件,可以构建出高可用性、高性能和可扩展的分布式数据库系统。然而,在实际应用中还需要注意解决数据一致性、故障恢复与容错性以及分布式事务的复杂性等挑战。随着技术的不断发展和创新,相信分布式数据库系统将在未来发挥更加重要的作用。
|
4月前
|
分布式计算 API 对象存储
Ray是一个开源的分布式计算框架,用于构建和扩展分布式应用。它提供了简单的API,使得开发者可以轻松地编写并行和分布式代码,而无需担心底层的复杂性。
Ray是一个开源的分布式计算框架,用于构建和扩展分布式应用。它提供了简单的API,使得开发者可以轻松地编写并行和分布式代码,而无需担心底层的复杂性。
638 11
|
4月前
|
消息中间件 Java 开发者
Spring Cloud微服务框架:构建高可用、分布式系统的现代架构
Spring Cloud是一个开源的微服务框架,旨在帮助开发者快速构建在分布式系统环境中运行的服务。它提供了一系列工具,用于在分布式系统中配置、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态等领域的支持。
175 5
|
4月前
|
消息中间件 存储 负载均衡
使用Java构建高可用性的分布式系统
使用Java构建高可用性的分布式系统