多语言展示
当前在线:1945今日阅读:19今日分享:20

经典Java面试题:微服务技术栈有哪些?

维度(springcloud)服务开发:springboot spring springmvc服务配置与管理:Netfix公司的Archaiusm ,阿里的Diamond服务注册与发现:Eureka,Zookeeper服务调用:Rest RPC gRpc服务熔断器:Hystrix服务负载均衡:Ribbon Nginx服务接口调用:Fegin消息队列:Kafka Rabbitmq activemq服务配置中心管理:SpringCloudConfig服务路由(API网关)Zuul事件消息总线:SpringCloud Bus
工具/原料
1

springboot

2

spring springmvc

3

Kafka

4

Rabbitmq

5

activemq

6

Zuul

7

SpringCloud Bus

8

RPC

9

Zookeeper

方法/步骤
1

单体架构,是指将开发好的项目打成war包,然后发布到tomcat等容器中的应用。

2

应用核心是业务逻辑,由定义服务、领域对象和事件的模块完成。围绕着核心的是与外界打交道的适配器。适配器包括数据库访问组件、生产和处理消息的消息组件,以及提供API或者UI访问支持的web模块等。

3

尽管也是模块化逻辑,但是最终它还是会打包并部署为单体式应用。具体的格式依赖于应用语言和框架。例如,许多Java应用会被打包为WAR格式,部署在Tomcat或者Jetty上,而另外一些Java应用会被打包成自包含的JAR格式,类似的,Rails和Node.js会被打包成层级目录。

4

这种应用开发风格很常见,因为IDE和其它工具都擅长开发一个简单应用,这类应用也很易于调试,只需要简单运行此应用,用Selenium链接UI就可以完成端到端测试。单体式应用也易于部署,只需要把打包应用拷贝到服务器端,通过在负载均衡器后端运行多个拷贝就可以轻松实现应用扩展。在早期这类应用运行的很好。

5

Netflix开发的一套分布式服务框架的封装,包括服务的发现和注册,负载均衡、断路器、REST客户端、请求路由等。

6

Spring Cloud Eureka 是 Spring Cloud Netflix 微服务套件中的一部分,它基于Netflix Eureka 做了二次封装,主要负责完成微服务架构中的服务治理功能。

7

Spring Cloud提供了多种注册中心的支持,如:Eureka、consul、ZooKeeper等。Eureka已经闭源了。本教程第二篇也会介绍使用其它两种方式作为注册中心。

8

Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。

9

Eureka Client是一个java客户端,用于简化与Eureka Server的交互,客户端同时也就别一个内置的、使用轮询(round-robin)负载算法的负载均衡器。

10

在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。

11

Eureka Server之间通过复制的方式完成数据的同步,Eureka还提供了客户端缓存机制,即使所有的Eureka Server都挂掉,客户端依然可以利用缓存中的信息消费其他服务的API。综上,Eureka通过心跳检查、客户端缓存等机制,确保了系统的高可用性、灵活性和可伸缩性。

12

服务注册到Eureka集群时,可以指定多个,也可以指定一个Eureka服务(因为Eureka服务集群间彼此互联)。

13

Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用。

14

在微服务架构中,后端服务往往不直接开放给调用端,而是通过一个API网关根据请求的url,路由到相应的服务。当添加API网关后,在第三方调用端和服务提供方之间就创建了一面墙,这面墙直接与调用方通信进行权限控制,后将请求均衡分发给后台服务端。

15

SpringCloud Config提供服务器端和客户端。服务器存储后端的默认实现使用git,因此它轻松支持标签版本的配置环境,以及可以访问用于管理内容的各种工具。

注意事项
1

事件消息总线:SpringCloud Bus

2

服务开发:springboot spring springmvc

3

服务路由(API网关)Zuul

4

服务调用:Rest RPC gRpc

5

服务熔断器:Hystrix

6

服务负载均衡:Ribbon Nginx

7

服务接口调用:Fegin

8

消息队列:Kafka Rabbitmq activemq

9

服务配置中心管理:SpringCloudConfig

10

服务注册与发现:Eureka,Zookeeper

11

服务配置与管理:Netfix公司的Archaiusm ,阿里的Diamond

推荐信息