在2020年4月,自告奋勇使用JavaFX做了一个桌面应用,那是离开培训机构10多年后做的第一个桌面应用。
对于一个Java Web开发者来说,做桌面应用还是非常手生的。可是由于业务需要,还必须开发一个桌面应用,而且十万火急。
一、整理问题
首先,遇到的第一个问题是技术选型问题,使用什么框架进行开发?本语言的,还是其他语言的?
其次,桌面应用,数据都存在本地电脑上,使用什么数据库来存储用户的数据。
再者,安装包问题,怎么打包成安装文件?
最后,是否要换语言,使用市面上流行的桌面应用开发语言?
经过反复思考,做了以下决定。
二、问题逐个击破
第一,Java Web开发者最擅长的是使用 SpringBoot。Java 关于桌面应用的框架也是有的,比如JavaFX。
JavaFX 是一种用于使用 Java 开发丰富的桌面和 Web 应用程序的软件平台和库。它提供了一组 API 和工具,用于创建图形用户界面 (GUI) 和多媒体丰富的应用程序。通过 JavaFX,开发人员可以创建交互式和视觉上吸引人的应用程序,这些应用程序可以在 Windows、macOS、Linux 和 Web 浏览器等各种平台上运行。它提供了场景图、布局管理、事件处理、动画、媒体播放以及支持 CSS 样式等功能。
虽然 JavaFX 在 JDK 8 之前是与 Java Development Kit (JDK) 捆绑在一起的,但自从 JDK 11 起,它已经从 JDK 中解耦,并成为 OpenJFX 项目下的一个独立的开源项目。
SpringBoot整合JavaFX也是有的,那就是它了。
<dependency>
<groupId>de.roskenet</groupId>
<artifactId>springboot-javafx-support</artifactId>
<version>2.1.6</version>
</dependency>
<!-- springboot整合javafx end -->
第二,数据存储问题
根据存储的数据类型分类解决:
1、一种是永久性数据,比如用户的登录信息等等,这个可以用嵌入式数据库sqlite,永久地保存在本地。
SQLite是一种嵌入式关系数据库管理系统(RDBMS),它是一个轻量级、独立的数据库引擎,不需要单独的服务器进程。SQLite以文件形式存储数据库,提供了一个简单的、零配置的数据库解决方案。
https://www.sqlite.org/2、一种是收集的设备指标测量值数据,存储半年就丢掉了,这个可以使用时序数据库influxdb,设置半年的过期时间。
InfluxDB 是一种专为处理高容量时间序列数据而设计的数据库。它针对存储、查询和分析时间序列数据进行了优化,该类型数据包含随时间发生的测量或事件。InfluxDB 是 TICK(Telegraf、InfluxDB、Chronograf 和 Kapacitor)堆栈的一部分,提供了一个全面的平台来处理时间序列数据。
第三,避开技术壁垒。
既然打包成安装包一时搞不懂,可以避开安装这个环节,解压即用。
把项目打包成exe文件,和数据库放在一个压缩包里,进行压缩。
用户拿到压缩包,把压缩包解压后,先运行时序数据库,然后点击exe文件,即可运行桌面应用,正常使用桌面应用。也帮用户省了安装一步。
最后总结一次本次的技术选型:
不考虑业务场景的架构,都是耍流氓。这个架构到底合不合适呢?一起分析一下,客户端的用户数据,是单用户数据,只存储当前用户的数据,和别的用户没有交互,需要永久性存储的设备数据初步估算500条以内。500个设备的实时数据,一天存储10万条数据,半年存储90亿数据,这还是往多了算,只要电脑的容量不是太小,运行半年是没有问题的。当然这也是初步分析,至于现实是什么样子,还需等待客户反馈。