SprintBoot总体来说,搭建还是比较容易的,特别是SpringCloud全家桶,简称亲民微服务,但在发展趋势中,容器化技术已经成熟,面对巨耗内存的SprintBoot,小公司表示用不起。如今,很多刚诞生的JAVA微服务框架大多主打“轻量级”,主要还是因为SprintBoot太重。
有Spring大靠山在,更新、稳定性、成熟度的问题根本不需要考虑。在JAVA系混的技术人员大约都听说过Spring的大名吧,所以不缺程序员……,而且这入手的难度十分低,完全可以省去一个架构师。 但是,你必然在服务器上付出:
如图,内存占用304M。
如图,内存占用1520M(1.5G),CPU上升到321%
一个SprintBoot的简单应用,最少1G内存,一个业务点比较少的微服务编译后的JAR会大约50M;而SprintCloud引入的组件会相对多一些,消耗的资源也会相对更多一些。 启动时间大约10秒左右: `Started Application in 10.153 seconds (JVM running for 10.915)` 复制代码
背靠Eclipse的[Eclipse Vert.x](https://vertx.io/)是一个用于在JVM上构建响应式应用程序的工具包。定位上与SprintBoot不冲突,甚至可以将Vert.x结合SprintBoot使用。众多Vert.x模块提供了大量微服务的组件,在很多人眼里是一种微服务架构的选择。华为微服务框架[Apache ServiceComb](http://servicecomb.apache.org/cn/)就是以Vert.x为底层框架实现的,在"基准测试网站TechEmpower"中,Vert.x的表现也十分亮眼。 复制代码
如图,内存占用65M。
如图,内存占139M,CPU占2.1%,给人的感觉似乎并没有进行压测。
Vert.x单个服务打包完成后大约7M左右的JAR,不依赖Tomcat、Jetty之类的容器,直接在JVM上跑。 Vert.x消耗的资源很低,感觉一个1核2G的服务器已经能够部署许多个Vert.x服务。除去编码方面的问题,真心符合小项目和小模块。git市场上已经出现了基于Vert.x实现的开源网关- [VX-API-Gateway帮助文档](https://duhua.gitee.io/vx-api-gateway-doc/) 对多语言支持,很适合小型项目快速上线。 启动时间不到1秒:`Started Vert.x in 0.274 seconds (JVM running for 0.274)` 复制代码