这10道springboot常见面试题你须要了解下

图片描述

一、什么是Spring Boot?
多年来,随着新功能的增长,spring变得愈来愈复杂。只需访问https://spring.io/projects页面,咱们就会看到能够在咱们的应用程序中使用的全部Spring项目的不一样功能。web

若是必须启动一个新的Spring项目,咱们必须添加构建路径或添加Maven依赖关系,配置应用程序服务器,添加spring配置。spring

所以,开始一个新的spring项目须要不少努力,由于咱们如今必须从头开始作全部事情。数据库

Spring Boot是解决这个问题的方法。Spring Boot已经创建在现有spring框架之上。使用spring启动,咱们避免了以前咱们必须作的全部样板代码和配置。tomcat

所以,Spring Boot能够帮助咱们以最少的工做量,更加健壮地使用现有的Spring功能。安全

二、Spring Boot有哪些优势?
减小开发,测试时间和努力。服务器

使用JavaConfig有助于避免使用XML。并发

避免大量的Maven导入和各类版本冲突。app

提供意见发展方法。框架

经过提供默认值快速开始开发。dom

没有单独的Web服务器须要。这意味着你再也不须要启动Tomcat,Glassfish或其余任何东西。

须要更少的配置 由于没有web.xml文件。只需添加用@ Configuration注释的类,而后添加用@Bean注释的方法,Spring将自动加载对象并像之前同样对其进行管理。您甚至能够将@Autowired添加到bean方法中,以使Spring自动装入须要的依赖关系中。

基于环境的配置 使用这些属性,您能够将您正在使用的环境传递到应用程序:-Dspring.profiles.active = {enviornment}。在加载主应用程序属性文件后,Spring将在(application{environment} .properties)中加载后续的应用程序属性文件。

三、什么是JavaConfig?
Spring JavaConfig是Spring社区的产品,它提供了配置Spring IoC容器的纯Java方法。所以它有助于避免使用XML配置。使用JavaConfig的优势在于:

面向对象的配置。因为配置被定义为JavaConfig中的类,所以用户能够充分利用Java中的面向对象功能。一个配置类能够继承另外一个,重写它的@Bean方法等。

减小或消除XML配置。基于依赖注入原则的外化配置的好处已被证实。可是,许多开发人员不但愿在XML和Java之间来回切换。

JavaConfig为开发人员提供了一种纯Java方法来配置与XML配置概念类似的Spring容器。

从技术角度来说,只使用JavaConfig配置类来配置容器是可行的,但实际上不少人认为将JavaConfig与XML混合匹配是理想的。

类型安全和重构友好。JavaConfig提供了一种类型安全的方法来配置Spring容器。因为Java 5.0对泛型的支持,如今能够按类型而不是按名称检索bean,不须要任何强制转换或基于字符串的查找。

四、如何从新加载Spring Boot上的更改,而无需从新启动服务器?
这可使用DEV工具来实现。经过这种依赖关系,您能够节省任何更改,嵌入式tomcat将从新启动。

Spring Boot有一个开发工具(DevTools)模块,它有助于提升开发人员的生产力。Java开发人员面临的一个主要挑战是将文件更改自动部署到服务器并自动重启服务器。

开发人员能够从新加载Spring Boot上的更改,而无需从新启动服务器。这将消除每次手动部署更改的须要。Spring Boot在发布它的第一个版本时没有这个功能。

这是开发人员最须要的功能。DevTools模块彻底知足开发人员的需求。该模块将在生产环境中被禁用。它还提供H2数据库控制台以更好地测试应用程序。

clipboard.png

五、Spring Boot中的监视器是什么?
Spring boot actuator是spring启动框架中的重要功能之一。Spring boot监视器可帮助您访问生产环境中正在运行的应用程序的当前状态。

有几个指标必须在生产环境中进行检查和监控。即便一些外部应用程序可能正在使用这些服务来向相关人员触发警报消息。监视器模块公开了一组可直接做为HTTP URL访问的REST端点来检查状态。

六、如何在Spring Boot中禁用Actuator端点安全性?
默认状况下,全部敏感的HTTP端点都是安全的,只有具备ACTUATOR角色的用户才能访问它们。

安全性是使用标准的HttpServletRequest.isUserInRole方法实施的。 咱们可使用management.security.enabled = false 来禁用安全性。只有在执行机构端点在防火墙后访问时,才建议禁用安全性。

如何在自定义端口上运行Spring Boot应用程序? 为了在自定义端口上运行Spring Boot应用程序,您能够在application.properties中指定端口。 server.port = 8090

七、什么是YAML?
YAML是一种人类可读的数据序列化语言。它一般用于配置文件。 与属性文件相比,若是咱们想要在配置文件中添加复杂的属性,YAML文件就更加结构化,并且更少混淆。能够看出YAML具备分层配置数据。

八、如何实现Spring Boot应用程序的安全性?
为了实现Spring Boot的安全性,咱们使用 spring-boot-starter-security依赖项,而且必须添加安全配置。它只须要不多的代码。配置类将必须扩展WebSecurityConfigurerAdapter并覆盖其方法。

九、如何集成Spring Boot和ActiveMQ?
对于集成Spring Boot和ActiveMQ,咱们使用spring-boot-starter-activemq 依赖关系。 它只须要不多的配置,而且不须要样板代码。

十、如何使用Spring Boot实现分页和排序?
使用Spring Boot实现分页很是简单。使用Spring Data-JPA能够实现将可分页的org.springframework.data.domain.Pageable传递给存储库方法。

免费Java资料领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring
Cloud、Dubbo/Kafka、Hadoop、Hbase、Flink等高并发分布式、大数据、机器学习等技术。
传送门: https://mp.weixin.qq.com/s/Jz...
相关文章
相关标签/搜索