1.springboot哪个版本稳定?
2.美团动态线程池思路框架(DynamicTp)之动态调整Tomcat、源码Jetty、分析Undertow线程池参数篇
3.Spring Boot å
åµå®¹å¨Undertowå代tomcat
springboot哪个版本稳定?
springboot2.0.0.m2是源码什么版本
Release表示是正式的版本.
RCstandsforReleaseCandidate表示后选版本
Mstandsformilestone表示里程碑版本.
一般而言,稳定性由上而下,依次降低.
,
springboot快速入门及@SpringBootApplication注解分析
简单demo
使用maven构建项目,官方现在稳定版本是分析1.5.4,第一个入门demo不是源码web项目,pom依赖如下:
实体User类:
配置类:
入口类Application:
项目结构目录
启动程序,分析awk源码分析以main方法启动:
打印出正确的源码结果。
来分析一下流程,分析为何Runnable类,源码User,分析Map会纳入spring容器。源码
首先我们分析的分析就是入口类Application的启动注解@SpringBootApplication,进入源码:
发现@SpringBootApplication是源码一个复合注解,包括@ComponentScan,分析和@SpringBootConfiguration,源码@EnableAutoConfiguration。
根据上面的理解,上面的Everything 源码C入口类Application,我们可以使用:
使用@ComponentScan注解代替@SpringBootApplication注解,也可以正常运行程序。原因是@SpringBootApplication中包含@ComponentScan,并且springboot会将入口类看作是一个@SpringBootConfiguration标记的配置类,所以定义在入口类Application中的Runnable也可以纳入到容器管理。
看一个demo学会使用这些参数配置
在包下com.zhihao.miao.springboot定义一个启动应用类(加上@SpringBootApplication注解)
在com.zhihao.miao.beans包下定义一个实体类,并且想将其纳入到spring容器中,
启动启动类,打印结果如下:
说明Cat类并没有纳入到spring容器中,这个结果也如我们所想,因为@SpringBootApplication只会扫描@SpringBootApplication注解标记类包下及其子包的类(特定注解标记,比如说@Controller,@Service,@Component,@Configuration和@Bean注解等等)纳入到spring容器,很显然MyConfig不在@SpringBootApplication注解标记类相同包下及其子包的类,所以需要我们去配置一下扫包路径。
修改启动类,ble gatt源码@SpringBootApplication(scanBasePackages="com.zhihao.miao"),指定扫描路径:
启动并打印:
当然使用@SpringBootApplication(scanBasePackageClasses=MyConfig.class),指定scanBasePackageClasses参数的value值是你需要扫描的类也可以,结果一样,不过如果多个配置类不在当前包及其子包下,则需要指定多个。
再看一个列子,
在上面的列子的相同包下(com.zhihao.miao.springboot)配置了People,并将其纳入到spring容器中(@Component),我们知道@SpringBootApplication注解会扫描当前包及其子包,所以People类会纳入到spring容器中去,我们需要将其排除在spring容器中,如何操作?
可以使用@SpringBootApplication的另外二个参数(exclude或excludeName)
启动类,
启动并打印结果:
然后修改@SpringBootApplication配置,
很明显启动报错。使用@excludeName注解也可以。如下,workman源码下载
@SpringBootApplication(excludeName={ "com.zhihao.miao.springboot.People"})
参考文档:
Springboot1.5.4官方文档
springboot1.5,2.1+jdk8,jdk的内存占用对比对新的技术学习探索是一件快乐而有趣的事情。
最近关注了springboot最新版本2.1.1,jdk。然后准备把手头的学习项目升级一下。
那么为什么不用jdk而使用jdk?我的判断很简单,因为jdk是LTS版本啊。
那么升级总得有个差异,所以简单的通过项目版本变更对比下内存耗用情况。
首先介绍下我的项目:
springboot1.5.+swagger+undertow+spring-orm4.3.3+jdk1.8
当前版本内存耗费截图如下:
启动时间:StartedJdyXcxApiin4.seconds(JVMrunningfor5.)
内存情况:堆内存中的初试内存堆大小M,使用M,超过的时候回收了一下
开始升级springboot:
springboot2.1.1+swagger+undertow+spring-orm5.1.4+jdk1.8
启动时间:StartedJdyXcxApiin3.seconds(JVMrunningfor4.)
内存情况:堆内存中的初试内存堆大小M,使用M,超过M的时候回收了一下
开始升级jdk:
springboot?2.1.1?+swagger+undertow+spring-orm5.1.4?+jdk
启动时间:StartedJdyXcxApiin3.seconds(JVMrunningfor4.)
内存情况:堆内存中的初试内存堆大小M,使用M,超过M的时候回收了一下
综合统计:
如何选择SpringBoot最稳定的版本,以及相应的SpringCloud版本1、登录Spring的calcite源码解析官网,查看当前最稳定的版本。
当然了,想使用SpringCloud,还需要许多的jar包,如何选择兼容的jar包呢?在这里,我们可以考虑使maven的dependencyManagement功能。
dependencyManagement其实就相当于一个对jar版本进行管理的依赖管理器,如果在dependencies的dependency里没有找到version属性,Maven就会去dependencyManagement里寻找相应的版本信息。
如果既使用了dependencyManagement功能,又在dependencies的dependency里指定了version属性,dependency是以version属性为准的,所以,不用担心使用dependencyManagement功能之后无法自行指定jar包的版本信息。
在这里,我们选择的是alibaba的版本管理配置。
首先,进入阿里巴巴的GitHub地址,进入WiKi页面,点击版本说明。
或者直接点击版本说明
我们可以看到,2.4.2版本的SpringBoot,对应的alibaba版本是.0.RC1,对应的SpringCloud版本是.0,我们选择.0.2,最终配置如下。
我这里是为了学习,所以选择的都是最新版本,在生产环境,还是要根据实际情况来详细评估选择哪些版本,以免给自己挖坑。
jdk1.7选什么版本springboot1.。由于springboot2.0以后不支持jdk1.7,所以只能自降springboot的版本由2.0降为1.。当选用jdk1.7构建springboot项目时会提示,选用jdk1.8。
请问年最稳定的jdk版本or哪个最好用,最流行!Java8是继Java5之后改动最大的一个版本,很经典,目前企业用的最多的还是Java8,即使有人用Java,但特性可能还是只用了Java8的,所以还是java8吧
美团动态线程池思路框架(DynamicTp)之动态调整Tomcat、Jetty、Undertow线程池参数篇
动态线程池框架(DynamicTp)的adapter模块,作为第三方组件线程池管理的适配器,旨在使如Tomcat、Jetty和Undertow等Web服务器内置的线程池具备动态参数调整、监控告警等增强功能。通过该模块,用户可利用Spring的事件机制监听并管理这些第三方组件的线程池,实现与核心模块的解耦。
adapter模块已成功接入SpringBoot内置的三大WebServer,包括Tomcat、Jetty和Undertow的线程池管理。通过监听机制,动态Tp框架能够及时响应这些组件的线程池变化,提供实时监控和灵活调整策略。
具体实现上,针对Tomcat、Jetty和Undertow的线程池管理,需要深入理解其内部处理流程。这些组件并未直接使用Java Util Concurrency(JUC)提供的线程池实现,而是自定义了线程池或扩展了JUC的实现,如Tomcat就采用了自定义的ThreadPoolExecutor类,通过继承或扩展JUC的抽象类来定制线程池行为。
以Tomcat为例,其内部线程池的实现中,继承自JUC原生ThreadPoolExecutor或其抽象类AbstractExecutorService。在执行任务时,Tomcat首先调用父类方法处理,然后根据任务队列类型(如TaskQueue)和线程池当前状态(如线程数、提交任务数、队列状态)进行一系列复杂判断,以决定是否创建新线程、添加任务至队列或执行拒绝策略。这种设计使得Tomcat能够高效管理请求,同时优化资源利用,避免过度创建线程导致的性能下降。
Jetty和Undertow的内部线程池实现原理与Tomcat类似,均基于JUC框架进行定制,以满足其特定的性能优化和扩展需求。通过分析这些组件的源码,可以深入了解其线程池管理策略,为后续性能调优提供宝贵信息。
动态线程池框架(DynamicTp)的引入,为Web服务器性能调优提供了强大的工具,允许用户动态调整线程池参数,提升系统响应速度和资源利用率。使用DynamicTp框架,用户可以更灵活地管理第三方组件的线程池,实现业务与开源贡献的双赢。
欢迎使用DynamicTp框架,探索更多性能优化的可能性。下期将分享在使用过程中遇到的Tomcat版本不一致导致的监控线程停滞问题,通过这一案例深入理解ScheduledExecutorService的运行机制。敬请期待。
如需交流或合作,请联系我,期待与您一起成长:
微信:yanhom
公众号:CodeFox
Spring Boot å åµå®¹å¨Undertowå代tomcat
æ§è½æ¯è¾ï¼
Undertow,TomcatåJettyæå¡å¨é 置详解ä¸æ§è½æµè¯
Undertow认为å®çè¿ç¨åºæ¯æ¯å¨IOå¯éåçç³»ç»åºç¨ä¸ï¼å¹¶ä¸è®¤ä¸ºå¤æ ¸æºå¨æ¯ä¸ä¸ªæ¯è¾å®¹æ满足çç¹ï¼Undertowåå§ååæ³åºç¨çé»å¡ç³»æ°å¨0.8~0.9ä¹é´ï¼æ以é»å¡çº¿ç¨æ°ç´æ¥ä¹äºä¸ª8ï¼å½ç¶ï¼å¦æ对åºç¨è¾ç²¾ç¡®çä¼°æµé»å¡ç³»æ°ï¼å¯ä»¥é ç½®ä¸å»ï¼
å¦æ项ç®è¿è¡ä¸æ®µæ¶é´ååç°httpåå¨è¶ æ¶æè è·åhttpè¿æ¥æ¯è¾èæ¶çæ åµï¼å¯ä»¥éå½çå 大 workerThreads 线ç¨é ç½®ã
åç»ä¹ãSpringBootæå¡å¨åæµå¯¹æ¯ï¼jettyãtomcatãundertowï¼ã
undertowå¨githubçæºç
Spring Boot å åµå®¹å¨Undertowåæ°è®¾ç½®
Spring boot ä¸ Undertow é 置线ç¨æ°
线ç¨æ°è®¾å¤å°åéï¼ï¼
Dockerç¯å¢Spring Bootåºç¨undertow大éhttp请æ±è¶ æ¶