请给SpringBoot多一些内存

点击上方“后端技术精选”,选择“置顶公众号”

技术文章第一时间送达!


作者:襄垣

juejin.im/post/5c89f266f265da2d8763b5f9

概述

SprintBoot总体来说,搭建还是比较容易的,特别是SpringCloud全家桶,简称亲民微服务,但在发展趋势中,容器化技术已经成熟,面对巨耗内存的SprintBoot,小公司表示用不起。如今,很多刚诞生的JAVA微服务框架大多主打“轻量级”,主要还是因为SprintBoot太重。

JAVA系微服务框架No1-Spring Cloud

介绍

有Spring大靠山在,更新、稳定性、成熟度的问题根本不需要考虑。在JAVA系混的技术人员大约都听说过Spring的大名吧,所以不缺程序员……,而且这入手的难度十分低,完全可以省去一个架构师。

但是,你必然在服务器上付出:

  • 至少一台“服务发现 ”的服务器;

  • 可能有一个统一的网关Gateway;

  • 可能需要一个用于“分布式配置管理”的配置中心;

  • 可能进行“服务追踪”,知道我的请求从哪里来,到哪里去;

  • 可能需要“集群监控”;

  • 项目上线后发现,我们需要好多服务器,每次在集群中增加服务器时,都感觉心疼;

压测30秒

压测前的内存占用

640?wx_fmt=png

如图,内存占用304M。

压测时的内存占用

640?wx_fmt=png

如图,内存占用1520M(1.5G),CPU上升到321%

概览

640?wx_fmt=png

总结

一个SprintBoot的简单应用,最少1G内存,一个业务点比较少的微服务编译后的JAR会大约50M;而SprintCloud引入的组件会相对多一些,消耗的资源也会相对更多一些。

启动时间大约10秒左右: Started Application in 10.153 seconds (JVM running for 10.915)

JAVA系响应式编程的工具包Vert.x

介绍

背靠Eclipse的Eclipse Vert.x是一个用于在JVM上构建响应式应用程序的工具包。定位上与SprintBoot不冲突,甚至可以将Vert.x结合SprintBoot使用。众多Vert.x模块提供了大量微服务的组件,在很多人眼里是一种微服务架构的选择。

华为微服务框架Apache ServiceComb就是以Vert.x为底层框架实现的,在"基准测试网站TechEmpower"中,Vert.x的表现也十分亮眼。

压测30秒

压测前的内存占用

640?wx_fmt=png

如图,内存占用65M。

压测时的内存占用

640?wx_fmt=png

如图,内存占139M,CPU占2.1%,给人的感觉似乎并没有进行压测。

概览

640?wx_fmt=png

总结

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)

JAVA系其他微服务框架

SparkJava

  • jar比较小,大约10M

  • 占内存小,大约30~60MB;

  • 性能还可以,与SprintBoot相仿;

Micronaut

  • Grails团队新宠;

  • 可以用 Java、Groovy 和 Kotlin 编写的基于微服务的应用程序;

  • 相比SprintBoot已经比较全面;

  • 性能较优,编码方式与SprintBoot比较类似;

  • 启动时间和内存消耗方面比其他框架更高效;

  • 多语言;

  • 依赖注入;

  • 内置多种云本地功能;

  • 很新,刚发布1.0.0

Javalin

  • 上手极为容易;

  • 灵活,可以兼容同步和异步两种编程思路;

  • JAR小,4~5M;

  • 多语言;

  • 有KOA的影子;

  • 只有大约2000行源代码,源代码足够简单,可以理解和修复;

  • 符合当今趋势;

  • 多语言;

  • 嵌入式服务器Jetty;

Quarkus

  • 启动快;

  • JAR小,大约10M;

  • 文档很少;

SpringBoot相关文章


SpringBoot+Mybatis多模块(module)项目搭建教程

Springboot使用RedisTemplate优雅地操作redis

Springboot线程池的使用和扩展

SpringBoot 并发登录人数控制

Springboot如何优雅的解决ajax+自定义headers的跨域请求

优化你的springboot

Springboot总结,核心功能,优缺点

基于SpringBoot开发一个Restful服务,实现增删改查功能

深入SpringBoot核心注解原理

企业级SpringBoot与Dubbo的并用

Spring全家桶系列--[SpringBoot入门到跑路]

Spring全家桶系列--SpringBoot渐入佳境

Spring全家桶系列--SpringBoot之AOP详解

Spring全家桶--SpringBoot Rest API

Spring全家桶系列--SpringBoot与Mybatis结合

Spring全家桶系列--SpringBoot入门Redis

教你 Shiro 整合 SpringBoot,避开各种坑

教你 Shiro + SpringBoot 整合 JWT

SpringBoot 使用 Redis 缓存

SpringBoot启动流程解析

SpringBoot+MyBatis+MySQL读写分离(实例)

Springboot-Redis分布式锁

Springboot实战:集成Swagger2

SpringBoot整合RabbitMQ(一)快速入门

SpringBoot整合RabbitMQ(二)单机抢票系统

springboot整合websocket实现一对一消息推送和广播消息推送

SpringBoot常用注解大全

 
 

640?wx_fmt=png


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值