热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用SpringBoot和Groovy实现灵活的动态计算引擎

本文介绍了如何利用SpringBoot和Groovy构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。

背景与需求:

在上半年,我们在钱包应用程序中实现了类似于余额宝的功能。下半年,我们计划通过邀请新用户注册来推广此功能。例如,余额宝的年化收益率为1.7%,每成功邀请一名新用户,年化收益率将增加1%,最多可达某个上限。假设用户的初始余额为10元,并在一天内成功邀请了5名新用户,那么第二天的余额计算公式如下:

本金:10元

昨天利息:A = 10 * 1.7% / 365

昨天奖金:B = 10 * 5% / 365

昨天总收入:A + B


需求分析:

我们需要根据邀请人数动态计算用户每天获得的推广奖金,并确保系统能够支持未来其他项目的计算需求,如借呗等。


方案一:集中式编码

可以在现有的 A 服务中添加新的接口,根据类型参数判断具体场景并实现相应逻辑。然而,这种方法存在诸多问题:

1. A 服务开发人员可能对其他服务(如借呗)不够熟悉,导致编码困难;

2. 接入方(如借呗团队)直接在 A 服务中编码会降低效率;

3. 所有业务逻辑集中于 A 服务,每次修改计算规则都需要重新部署,增加了维护成本。

因此,方案一并不理想。


方案二:抽象计算接口

为了实现更灵活和可扩展的设计,我们可以创建一个独立的 CalculateService 接口,该接口不依赖任何特定业务,仅负责执行计算任务。具体实现步骤如下:

1. 对外提供 calculate 方法,输入输出均为 Map 类型;

2. 接入方需自行实现 calculateParse 接口,编写具体的业务逻辑,并将其存入数据库中的 calculate_rule 表;

3. A 服务启动时读取 calculate_rule 表内容,构造对应的 Groovy 脚本并交由 Spring 容器管理;

4. 当计算规则发生变化时,无需重启服务,只需更新数据库并通过开关刷新内存中的规则。

这种设计具有以下优势:

1. A 服务专注于提供计算功能,与具体业务解耦;

2. 各业务团队可以独立完成编码并提交给 A 服务;

3. 规则变更通过 SQL 文件处理,减少代码修改带来的风险;

4. 提高迭代效率,减少重复工作。


技术选型

经过调研,我们选择了 Groovy 作为动态计算引擎,因为它不仅支持完整的业务逻辑编写,还能无缝集成现有 Java 系统。相比之下,Spring Expression Language 和 Velocity 更适合用于简单的规则配置。


Groovy 特性简介

Groovy 是一种基于 Java 虚拟机的敏捷动态语言,具备与 Java 的无缝集成能力,可以直接编译成字节码并在任何 Java 环境下运行。它显著减少了框架性代码,提升了开发效率,特别适用于 Web、GUI、数据库和控制台程序的开发。


推荐阅读
author-avatar
苏小丫123_877
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有