JavaFX开发桌面应用技术选型参考

在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 项目下的一个独立的开源项目。

官网:https://openjfx.io/

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以文件形式存储数据库,提供了一个简单的、零配置的数据库解决方案。

image.png

https://www.sqlite.org/2、一种是收集的设备指标测量值数据,存储半年就丢掉了,这个可以使用时序数据库influxdb,设置半年的过期时间。

InfluxDB 是一种专为处理高容量时间序列数据而设计的数据库。它针对存储、查询和分析时间序列数据进行了优化,该类型数据包含随时间发生的测量或事件。InfluxDB 是 TICK(Telegraf、InfluxDB、Chronograf 和 Kapacitor)堆栈的一部分,提供了一个全面的平台来处理时间序列数据。

image.png

https://www.influxdata.com/

第三,避开技术壁垒。

既然打包成安装包一时搞不懂,可以避开安装这个环节,解压即用。

把项目打包成exe文件,和数据库放在一个压缩包里,进行压缩。

用户拿到压缩包,把压缩包解压后,先运行时序数据库,然后点击exe文件,即可运行桌面应用,正常使用桌面应用。也帮用户省了安装一步。

最后总结一次本次的技术选型:

image.png

不考虑业务场景的架构,都是耍流氓。这个架构到底合不合适呢?一起分析一下,客户端的用户数据,是单用户数据,只存储当前用户的数据,和别的用户没有交互,需要永久性存储的设备数据初步估算500条以内。500个设备的实时数据,一天存储10万条数据,半年存储90亿数据,这还是往多了算,只要电脑的容量不是太小,运行半年是没有问题的。当然这也是初步分析,至于现实是什么样子,还需等待客户反馈。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容