怎么把报表模块从应用里拆出来单独维护?

 

关键词: 报表解耦 报表应用解耦 报表模板单独维护 报表单独部署 报表应用独立部署

如果报表通过报表工具开发,且报表中只涉及 SQL/ 存储过程,拆分相对容易些,只需要整理好报表模块需要的数据库资源即可,比如:会涉及到哪些数据源、数据库连接数需要分配多少等,然后将报表模块单独作为报表应用部署维护即可。

如果报表中涉及 JAVA 编写的内容(通常是为报表准备数据)会比较麻烦。首先因为 JAVA 代码要跟主程序一起打包部署,所以报表模块和主应用是紧耦合在一起的,要解耦报表模块需要另一种方式实现报表中 JAVA 实现的部分。

报表中使用 JAVA 编码主要基于以下几种原因:

1、数据计算涉及复杂过程和逻辑控制
为报表准备数据时涉及的计算过于复杂,或者需要做比较复杂的逻辑控制,通过 SQL 不易实现,只能通过 JAVA 硬编码

2、涉及多样性数据源
报表的数据来源多种多样,当涉及 NoSQL、文本、XML、Hadoop、时序数据库、Webservice 等数据源时,报表工具无法实现混合计算,需要用 JAVA 实现报表数据准备

3、方便应用扩展
未来业务增长需要对应用进行水平扩展(拆分),使用 SQL 不利于未来分库,只能用 JAVA 实现报表数据计算

4、用于管理
为了管理需要,有时需要记录报表访问人、报表查询次数、每次查询了哪些数据等信息,通过 JAVA 编写监听类实现

可以直接使用具备这些能力的报表工具完成解耦:
1. 很强的复杂计算能力,能完成较复杂的运算,还容易实现逻辑控制;
2. 多样性数据源支持,最好还能混合计算,如 CSV 和 DB 做 join;
3. 计算不依赖数据库,方便扩展
4. 支持热切换,修改报表不用重启应用

可以看一下 如何降低报表应用的耦合度 ,介绍了如何使用报表工具解耦报表和主应用,画个图感受一下:

imagepng
原来 JAVA 程序把报表和主应用紧紧绑在一起,现在可以把报表模块单独拆分维护,解释执行可以热切换,修改报表可以不必重启整个应用了。甚至还可以将报表模板单独部署,在物理上实现分离,实现单独维护。

工具对复杂计算的支持可以参考 如何应对报表开发中的复杂逻辑
对多样性数据源的支持参考 在报表中直接使用多样性数据源