面试:SpringBoot&SpringCloud 高频面试题及答案

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/xxyybs/article/details/102766650

SpringBoot&SpringCloud 面试题。

其他面试题:
dubbo&zookeeper55道高频面试题(附加答案)

1.什么是 Spring Boot?

答: 多年来,随着新功能的增加,spring 变得越来越复杂。
只需访问https://spring.io/projects 页面,我们就会看到可以在我们的应用程序中使用的所有 Spring 项目的不同功能。如果必 须启动一个新的 Spring 项目,我们必须添加构建路径或添加 Maven 依赖关系,配置应用程 序服务器,添加 spring 配置。因此,开始一个新的 spring 项目需要很多努力,因为我们现在必须从头开始做所有事情。

Spring Boot 是解决这个问题的方法。Spring Boot 已经建立在现有 spring 框架之上。使用 spring 启动,我们避免了之前我们必须做的所有样板代码和配置。因此,Spring Boot 可以 帮助我们以最少的工作量,更加健壮地使用现有的 Spring 功能。

2.Spring Boot 有哪些优点?

答: 独立运行、简化配置、自动配置、无代码生成和XML配置、 应用监控、上手容易

3.什么是 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,不需要任何强制转换或 基于字符串的查找。

4.如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?

答: 这可以使用 DEV 工具来实现。通过这种依赖关系,您可以**节省任何更改,嵌入式 tomcat 将重新启动。**Spring Boot 有一个开发工具(DevTools)模块,它有助于提高开发人员的生 产力。Java 开发人员面临的一个主要挑战是将文件更改自动部署到服务器并自动重启服务 器。开发人员可以重新加载 Spring Boot 上的更改,而无需重新启动服务器。这将消除每次 手动部署更改的需要。Spring Boot 在发布它的第一个版本时没有这个功能。这是开发人员 最需要的功能。DevTools 模块完全满足开发人员的需求。该模块将在生产环境中被禁用。 它还提供 H2 数据库控制台以更好地测试应用程序。

5.Spring Boot 中的监视器是什么?

答: Spring boot actuator 是 spring 启动框架中的重要功能之一。Spring boot 监视器可帮助您访问生产环境中正在运行的应用程序的当前状态。有几个指标必须在生产环境中进行检查和 监控。即使一些外部应用程序可能正在使用这些服务来向相关人员触发警报消息。监视器 模块公开了一组可直接作为 HTTP URL 访问的 REST 端点来检查状态。

6.如何在 Spring Boot 中禁用 Actuator 端点安全性?

答: 默认情况下,所有敏感的 HTTP 端点都是安全的,只有具有 ACTUATOR 角色的用户才能访 问它们。安全性是使用标准的 HttpServletRequest.isUserInRole 方法实施的。 我们可以使用 management.security.enabled = false 来禁用安全性。只有在执行机构端点在防火墙后访问时,才建议禁用安全性。

7.如何在自定义端口上运行 Spring Boot 应用程序?

答: 为了在自定义端口上运行 Spring Boot 应用程序,您可以在 application.properties 中指定端口。 server.port = 8090

8.什么是 YAML?

答: YAML 是一种人类可读的数据序列化语言。它通常用于配置文件。 与属性文件相比,如果我们想要在配置文件中添加复杂的属性,YAML 文件就更加结构 化,而且更少混淆。可以看出 YAML 具有分层配置数据

9.如何实现 Spring Boot 应用程序的安全性?

答: 为了实现 Spring Boot 的安全性,我们使用 spring-boot-starter-security 依赖项,并且必须添 加安全配置。它只需要很少的代码。配置类将必须扩展 WebSecurityConfigurerAdapter 并覆 盖其方法。

10.如何集成 Spring Boot 和 ActiveMQ?

答: 对于集成 Spring Boot 和 ActiveMQ,我们使用 spring-boot-starter-activemq 依赖关系。 它只需要很少的配置,并且不需要样板代码。

11.如何使用 Spring Boot 实现分页和排序?

答: 使用 Spring Boot 实现分页非常简单。使用 Spring Data-JPA 可以实现将可分页的
org.springframework.data.domain.Pageable 传递给存储库方法。

12.什么是 Swagger?你用 Spring Boot 实现了它吗?

答: Swagger 广泛用于可视化 API,使用 Swagger UI 为前端开发人员提供在线沙箱。 Swagger 是用于生成 RESTful Web 服务的可视化表示的工具,规范和完整框架实现。它使文档能够以 与服务器相同的速度更新。当通过 Swagger 正确定义时,消费者可以使用最少量的实现逻 辑来理解远程服务并与其进行交互。因此,Swagger 消除了调用服务时的猜测。

13.什么是 Spring Profiles?

答: Spring Profiles 允许用户根据配置文件(dev,test,prod 等)来注册 bean。因此,当应用 程序在开发中运行时,只有某些 bean 可以加载,而在 PRODUCTION 中,某些其他 bean 可 以加载。假设我们的要求是 Swagger 文档仅适用于 QA 环境,并且禁用所有其他文档。这 可以使用配置文件来完成。Spring Boot 使得使用配置文件非常简单。

14.什么是 Spring Batch?

答: Spring Boot Batch 提供可重用的函数,这些函数在处理大量记录时非常重要,**包括日志/跟 踪,事务管理,作业处理统计信息,作业重新启动,跳过和资源管理。**它还提供了更先进 的技术服务和功能,通过优化和分区技术,可以实现极高批量和高性能批处理作业。简单 以及复杂的大批量批处理作业可以高度可扩展的方式利用框架处理重要大量的信息。

15.如何使用 Spring Boot 实现异常处理?

答: Spring 提供了一种使用 ControllerAdvice 处理异常的非常有用的方法。 我们通过实现一个 ControlerAdvice 类,来处理控制器类抛出的所有异常。

16.我们如何监视所有 Spring Boot 微服务?

答: Spring Boot 提供监视器端点以监控各个微服务的度量。这些端点对于获取有关应用程序的 **信息(如它们是否已启动)以及它们的组件(如数据库等)**是否正常运行很有帮助。但 是,使用监视器的一个主要缺点或困难是,我们必须单独打开应用程序的知识点以了解其 状态或健康状况。想象一下涉及 50 个应用程序的微服务,管理员将不得不击中所有 50 个 应用程序的执行终端。

17.Spring Boot 的核心配置文件有哪几个?它们的区别是什么?

答: Spring Boot 的核心配置文件是 application 和 bootstrap 配置文件。application 配置文件主要用于 Spring Boot 项目的自动化配置。
bootstrap 配置文件有以下几个应用场景。

  1. 使用 Spring Cloud Config 配置中心时,这时需要在 bootstrap 配置文件中添加连接到配置中心的配置属性来加载外部配置中心的配置信息。
  2. 一些固定的不能被覆盖的属性。
  3. 一些加密/解密的场景。
18.Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?

答: @SpringBootApplication。 @Configuration、@EnableAutoConfiguration、@ComponentScan组成。

19.开启 Spring Boot 特性有哪几种方式?
  1. 继承spring-boot-starter-parent项目
  2. 导入spring-boot-dependencies项目依赖
20.Spring Boot 需要独立的容器运行吗?

答: 内置了 Tomcat/ Jetty 等容器,不需要独立容器。

21.如何理解 Spring Boot 中的 Starters?

答: Starters可以理解为启动器,它包含了一系列可以集成到应用里面的依赖包,你可以一站式集成Spring及其他技术,而不需要到处找示例代码和依赖包。如你想使用Spring JPA访问数据库,只要加入spring-boot-starter-data-jpa启动器依赖就能使用了。
Starters包含了许多项目中需要用到的依赖,它们能快速持续的运行,都是一系列得到支持的管理传递性依赖。

22.如何将Spring Boot应用程序作为war包部署?

答:pom.xml文件中将 packaging 修改为war如下代码:

<groupId>com.javainuse</groupId>
	<artifactId>temp-page</artifactId>
	<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>

接下来,修改Spring BootStrap类,该类扩展了SpringBootServletInitializer类,以初始化Tomcat所需的Servlet上下文。

@SpringBootApplication
public class SpringBootHelloWorldApplication  extends SpringBootServletInitializer {
	
	@Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(SpringBootHelloWorldApplication.class);
    }
 
	public static void main(String[] args) {
		SpringApplication.run(SpringBootHelloWorldApplication.class, args);
	}
}

运行maven命令-clean install,然后在目标文件夹中创建一个war文件。

23.SpringBoot 中怎么禁用某些自动配置特性?

答: @EnableAutoConfiguration 或 @SpringBootApplication 注解的 exclude 属性来指明。

24.什么是Spring Cloud?

答: Spring cloud流应用程序启动器是基于Spring Boot的Spring集成应用程序,提供与外部系统的集成。 Spring cloud Task,一个生命周期短暂的微服务框架,用于快速构建执行有限数据处理的应用程序。

25.使用Spring Cloud有什么优势?

答: 使用Spring Boot开发分布式微服务时,我们面临以下问题。

  1. 与分布式系统相关的复杂性-这种开销包括网络问题,延迟开销,带宽问题,安全问题。
  2. 服务发现-服务发现工具管理群集中的流程和服务如何查找和互相交谈。它涉及一个服务目录,在该 目录中注册服务,然后能够查找并连接到该目录中的服务。
  3. 冗余-分布式系统中的冗余问题。
  4. 负载平衡 --负载平衡改善跨多个计算资源的工作负荷,诸如计算机,计算机集群,网络链路,中央 处理单元,或磁盘驱动器的分布。
  5. 性能-问题 由于各种运营开销导致的性能问题。
  6. 部署复杂性-Devops技能的要求。
26.服务注册和发现是什么意思?Spring Cloud如何实现?

答: 当我们开始一个项目时,我们通常在属性文件中进行所有的配置。随着越来越多的服务开发和部署,添加 和修改这些属性变得更加复杂。有些服务可能会下降,而某些位置可能会发生变化。手动更改属性可能会 产生问题。 Eureka服务注册和发现可以在这种情况下提供帮助。由于所有服务都在Eureka服务器上注 册并通过调用Eureka服务器完成查找,因此无需处理服务地点的任何更改和处理。

27.负载平衡的意义什么?

答: 在计算中,负载平衡可以改善跨计算机,计算机集群,网络链接,中央处理单元或磁盘驱动器等多种计算 资源的工作负载分布。负载平衡旨在优化资源使用,最大化吞吐量,最小化响应时间并避免任何单一资源 的过载。使用多个组件进行负载平衡而不是单个组件可能会通过冗余来提高可靠性和可用性。负载平衡通 常涉及专用软件或硬件,例如多层交换机或域名系统服务器进程。

28.ribbon和feign区别

答:

  1. 启动类使用的注解不同,Ribbon用的是@RibbonClient,Feign用的@EnableFeignClients。
  2. 服务的指定位置不同,Ribbon是在@RibbonClient注解上声明,Feign则是在定义抽象方法的接口中使用@FeignClient声明。
  3. 调用方式不同:Ribbon需要自己构建http请求,模拟http请求然后使用RestTemplate发送给其他服务,步骤相当繁琐。Feign则是在Ribbon的基础上进行了一次改进,采用接口的方式,将需要调用的其他服务的方法定义成抽象方法即可, 不需要自己构建http请求。不过要注意的是抽象方法的注解、方法签名要和提供服务的方法完全一致。
29.什么是Hystrix?它如何实现容错?

答: Hystrix是一个延迟和容错库,旨在隔离远程系统,服务和第三方库的访问点,当出现故障是不可避免的 故障时,停止级联故障并在复杂的分布式系统中实现弹性。

30.什么是Hystrix断路器?我们需要它吗?

答: 当一个服务调用另一个服务由于网络原因或者自身原因出现问题时 调用者就会等待被调用者的响应 当更多的服务请求到这些资源时导致更多的请求等待,这样就会发生连锁效应(雪崩效应),断路器就是解决这一问题。
由于某些原因,公开服务会引发异常。在这种情况下使用Hystrix我们定义了一个 回退方法。如果在公开服务中发生异常,则回退方法返回一些默认值。
如果firstPage method() 中的异常继续发生,则Hystrix电路将中断,并且员工使用者将一起跳过 firtsPage方法,并直接调用回退方法。 断路器的目的是给第一页方法或第一页方法可能调用的其他方法 留出时间,并导致异常恢复。可能发生的情况是,在负载较小的情况下,导致异常的问题有更好的恢复机会 。

31.什么是Netflix Feign?它的优点是什么?

答: Feign是受到Retrofit,JAXRS-2.0和WebSocket启发的java客户端联编程序。Feign的第一个目标 是将约束分母的复杂性统一到http apis,而不考虑其稳定性。

32.spring cloud 与dubbo的区别是什么

答: 最大的区别:Dubbo底层是使用Netty这样的NIO框架,是基于TCP协议传输的,配合以Hession序列化完成RPC通信。
而SpringCloud是基于Http协议+Rest接口调用远程过程的通信,相对来说,Http请求会有更大的报文,占的带宽也会更多。但是REST相比RPC更为灵活,服务提供方和调用方的依赖只依靠一纸契约,不存在代码级别的强依赖。
dubbo与springcloud区别

猜你喜欢

转载自blog.csdn.net/xxyybs/article/details/102766650