Java Dubbo 面试及答案 Java Dubbo 是一个分布式、高性能、透明化的 RPC 服务框架,提供服务自动注册、自动发现等高效服务治理方案,可以和 Spring 框架无缝集成。下面是 Dubbo 面试中常见的知识点: 一、Dubbo 支持哪些协议,每种协议的应用场景,优缺点? 1. Dubbo 协议:单一长连接和 NIO 异步通讯,适合大并发小数据量的服务调用,消费者远大于提供者。传输协议 TCP,异步,Hessian 序列化。 2. RMI 协议:采用 JDK 标准的 RMI 协议实现,传输参数和返回参数对象需要实现 Serializable 接口,使用 Java 标准序列化机制,使用阻塞式短连接,传输数据包大小混合,消费者和提供者个数差不多,可传文件,传输协议 TCP。 3. WebService 协议:基于 WebService 的远程调用协议,集成 CXF 实现,提供和原生 WebService 的互操作。多个短连接,基于 HTTP 传输,同步传输,适用系统集成和跨语言调用。 4. HTTP 协议:基于 Http 表单提交的远程调用协议,使用 Spring 的 HttpInvoke 实现。多个短连接,传输协议 HTTP,传入参数大小混合,提供者个数多于消费者,需要给应用程序和浏览器 JS 调用。 5. Hessian 协议:集成 Hessian 服务,基于 HTTP 通讯,采用 Servlet 暴露服务,Dubbo 内嵌 Jetty 作为服务器时默认实现,提供与 Hession 服务互操作。多个短连接,同步 HTTP 传输,Hessian 序列化,传入参数较大,提供者大于消费者,提供者压力较大,可传文件。 6. Memcache 协议:基于 Memcached 实现的 RPC 协议。 7. Redis 协议:基于 Redis 实现的 RPC 协议。 二、Dubbo 超时时间怎样设置? Dubbo 超时时间设置有两种方式: 1. 服务提供者端设置超时时间,在 Dubbo 的用户文档中,推荐如果能在服务端多配置就尽量多配置,因为服务提供者比消费者更清楚自己提供的服务特性。 2. 服务消费者端设置超时时间,如果在消费者端设置了超时时间,以消费者端为主,即优先级更高。因为服务调用方设置超时时间控制性更灵活。如果消费方超时,服务端线程不会定制,会产生警告。 三、Dubbo 有些哪些注册中心? 1. Multicast 注册中心:Multicast 注册中心不需要任何中心节点,只要广播地址,就能进行服务注册和发现。基于网络中组播传输实现。 2. Zookeeper 注册中心:基于分布式协调系统 Zookeeper 实现,采用 Zookeeper 的 watch 机制实现数据变更。 3. Redis 注册中心:基于 Redis 实现,采用 key/Map 存储,住 key 存储服务名和类型,Map 中 key 存储服务 URL,value 服务过期时间。基于 Redis 的发布/订阅模式通知数据变更。 4. Simple 注册中心 四、Dubbo 集群的负载均衡有哪些策略 Dubbo 提供了常见的集群策略实现,并预扩展点予以自行实现。 1. Random LoadBalance:随机选取提供者策略,有利于动态调整提供者权重。截面碰撞率高,调用次数越多,分布越均匀。 2. RoundRobin LoadBalance:轮循选取提供者策略,平均分布,但是存在请求累积的问题。 3. LeastActive LoadBalance:最少活跃调用策略,解决慢提供者接收更少的请求。 4. ConstantHash LoadBalance:一致性 Hash 策略,使相同参数请求总是发到同一提供者,一台机器宕机,可以基于虚拟节点,分摊至其他提供者,避免引起提供者的剧烈变动。 五、Dubbo 是什么? Dubbo 是一个分布式、高性能、透明化的 RPC 服务框架,提供服务自动注册、自动发现等高效服务治理方案,可以和 Spring 框架无缝集成。 六、Dubbo 的主要应用场景? 1. 透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何 API 侵入。 2. 软负载均衡及容错机制,可在内网替代 F5 等硬件负载均衡器,降低成本,减少单点。 3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的 IP 地址,并且能够平滑添加或删除服务提供者。 七、Dubbo 的核心功能? 主要就是如下 3 个核心功能: 1. Remoting:网络通信框架,提供对多种 NIO 框架抽象封装,包括“同步转异步”和“请求-响应”模式。 2. Registry:服务注册和发现机制,提供服务自动注册、自动发现等高效服务治理方案。 3. Cluster:集群容错机制,提供软负载均衡、失败重试、路由策略等功能。
剩余14页未读,继续阅读
- 粉丝: 1089
- 资源: 419
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助