面试题:微服务是什么?springcloud,springboot是什么?

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介:

面试刷题37:微服务是什么?springcloud,springboot是什么?

面试中被问到为什么要使用微服务架构?springcloud的核心组件有哪些?

拿我们国家的兵种来说,如何把战争这个单体架构微服务化,就是根据适用的场景,拆分出不同的兵种(微服务)

然后每个兵种之间通过军区指挥部采用特有的通信协议连接起来(RPC) ;

每个兵种内部自治,有自己的业务,数据,部署单元(建制)对外提供打击服务(HTTP)。

微服务
微服务是一种架构风格:

把单体系统拆分成各种微服务(进程集群里面),服务之间通过HTTP或者RPC协议进行通信。

服务内部是围绕某一个问题领域的业务,有自己单独的业务流程,数据存储,自动化测试,和自动化独立部署机制。

解决单体系统的难题:
开发端:部分业务的修改要修改整个项目, 开发维护成本高,容易出错,不利于团队协作;
运维线:部分业务的上线影响整体服务质量,运维无法精确评估系统资源的需求量;

带来的问题:

1,运维需要维护数量庞大的进程;

2,接口的业务流程拉长,一致性比较更难以控制;

3,分布式的复杂性:网络延迟,异步消息,分布式事务等;

基于敏捷项目管理和自动化部署可以应对这些问题。

springcloud整体介绍
基于springboot实现的微服务架构开发工具。

提供了这些分布式问题的解决方案:

springboot带来了什么?
1,提供了一个开发微服务的脚手架(idea的initializer创建springcloud的微服务),减少了从0开始搭建项目的问题;

2,并非重写spring或者替代spring,主要是提供了自动化配置简化原有的样板配置

3,快速开发,提供了各种starter集成其它的组件和解决依赖管理问题

4,轻松部署,内置了web容器,轻松跟docker融合;

涵盖了项目的构建,开发,测试阶段;

springboot快速使用
idea的initializer创建springcloud的微服务

开发一个rest接口

开发接口的单元测试代码

例子代码点我获取!

工程结构

依赖处理
1, parent处理方式

2,dependencyManagemant处理方式

运行
1,java -jar x.jar 运行 正式环境

2,idea提供调试运行; 开发环境

3,maven的spring-boot:run插件运行  开发环境;

springboot配置
自动化配置是springboot最大的亮点。

配置的加载优先级如下:

1,命令行中的参数 ;

2, 系统环境变量中的SPRING_APPLICATION_JSON配置;

3,JNDI属性: java:comp/env

4,java的操作系统属性 System.getProperties();

5,  操作系统的环境变量

6,jar包外部的 application-${profile}.properties

7, jar包内部的 application-${profile}.properties

8, @Configuration注解修改过的类 @PropertySource注解定义的属性

9, SpringApplication.setDefaultProperties()

多环境配置
application.properties放通用配置,指定激活 dev环境

在其他的环境中提供差异化的配置,发布的时候通过命令行指定环境spring.profiles.active=prod;

springboot监控
微服务是的进程的数量增多,必须有一套自动化的监控运维机制来收集微服务的运行指标,进行监控和预警。

spring-boot-starter-actuator 来进行监控。

并配置开启的端点。

常见的监控端点: /health /beans /mappings

小结
首先宏观上回答了为什么微服务会出现,解决了什么问题?

然后初步介绍了spring-cloud带来了什么?

接着从spring-cloud的基础出发,即springboot分析了springboot带来了什么,简单实用,配置和监控;

springboot带来了什么?

以及快速使用springboot开发接口的过程;

简单介绍了 工程结构,依赖的处理方式 , 运行指令等细节;

然后基于配置,介绍了配置参数的加载顺序,多环境下的最佳实践。

最后介绍了微服务继续的自动监控和运维机制 actuator ,收集微服务的端点信息。

原文地址https://www.cnblogs.com/snidget/p/12691636.html

相关文章
|
2月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
59 2
|
3月前
|
Java 对象存储 开发者
解析Spring Cloud与Netflix OSS:微服务架构中的左右手如何协同作战
Spring Cloud与Netflix OSS不仅是现代微服务架构中不可或缺的一部分,它们还通过不断的技术创新和社区贡献推动了整个行业的发展。无论是对于初创企业还是大型组织来说,掌握并合理运用这两套工具,都能极大地提升软件系统的灵活性、可扩展性以及整体性能。随着云计算和容器化技术的进一步普及,Spring Cloud与Netflix OSS将继续引领微服务技术的发展潮流。
61 0
|
2月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
2月前
|
JSON Java 数据格式
【微服务】SpringCloud之Feign远程调用
本文介绍了使用Feign作为HTTP客户端替代RestTemplate进行远程调用的优势及具体使用方法。Feign通过声明式接口简化了HTTP请求的发送,提高了代码的可读性和维护性。文章详细描述了Feign的搭建步骤,包括引入依赖、添加注解、编写FeignClient接口和调用代码,并提供了自定义配置的示例,如修改日志级别等。
95 1
|
3月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
434 37
|
2月前
|
Java Docker 微服务
SpringBoot微服务打包Docker镜像
SpringBoot微服务打包Docker镜像
|
2月前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
2月前
|
架构师 Java 开发者
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
在40岁老架构师尼恩的读者交流群中,近期多位读者成功获得了知名互联网企业的面试机会,如得物、阿里、滴滴等。然而,面对“Spring Boot自动装配机制”等核心面试题,部分读者因准备不足而未能顺利通过。为此,尼恩团队将系统化梳理和总结这一主题,帮助大家全面提升技术水平,让面试官“爱到不能自已”。
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
|
2月前
|
负载均衡 算法 Java
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
40岁老架构师尼恩分享了关于SpringCloud核心组件的底层原理,特别是针对蚂蚁集团面试中常见的面试题进行了详细解析。内容涵盖了Nacos注册中心的AP/CP模式、Distro和Raft分布式协议、Sentinel的高可用组件、负载均衡组件的实现原理等。尼恩强调了系统化学习的重要性,推荐了《尼恩Java面试宝典PDF》等资料,帮助读者更好地准备面试,提高技术实力,最终实现“offer自由”。更多技术资料和指导,可关注公众号【技术自由圈】获取。
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
|
3月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
下一篇
无影云桌面