DUBBO 面试灵魂18问
一、Dubbo 是什么
dubbo 是一个分布式框架,是一个远程服务调用的分布式框架,其核心部分包含:
1)集群容错: 提供基于接口方法的透明远程过程调用,包含多协议支持,以及软负债均衡、失败容错、地址路由、动态配置等集群支持
2) 远程通讯:提供对多种基于长连接的NIO框架抽象封装、包括多线程模型、序列化、以及“请求-响应”模式的信息交换方式
3)自动发现:基于注册中心目录服务、使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑的增加或者减少机器
二、Dubbo能做什么
透明化的远程方法调用,只需简单的配置,没有任何API侵入
软负载均衡以及容错机制,可以在内容替代F5等硬件负载均衡器,减少单点、降低成本
服务的自动注册和发现,不再需要写死服务提供方地址、注册中心基于接口名查询服务提供者的IP 地址,并且能够平滑添加或者删除服务提供者。
三、Dubbo默认使用的是什么通信框架,还可以选择别的框架么?
默认使用netty通信框架,还可以选择mina
四、Dubbo 服务调用时阻塞的么?
Dubbo服务调用默认是阻塞的
五、Dubbo 使用哪些注册中心?
推荐使用zookeeper注册中心,也可以使用Redis注册中心、Multicast注册中心、Simple注册中心
六、Dubbo 默认使用什么序列化框架?
默认使用Hession序列化框架、Hession是一个采用二进制格式传输的服务框架,相对于传统的Soap webService 更轻便、更快速。
其他的序列化框架还有 Dubbo、FastJson 、java自带的序列化框架等
七、服务提供者能实现失效踢出是什么原理?
服务失效踢出是基于zookeeper的临时节点原理
八、服务上线如何才能不影响旧版本?
采用多版本开发,不影响旧版本。在配置中添加version来作为版本区分。
九、如何解决服务调用链过程的问题?
可以结合zipkin 实现分布式服务跟踪
十、Dubbo的核心配置有哪一些?
1)dubbo:service
2)dubbo:reference
3)dubbo:registry
4)dubbo:protocol
5)dubbo:application
6)dubbo:provider
7)dubbo:consumer
8)dubbo:method
十一、Dubbo推荐什么协议
默认使用dubbo协议
十二、同一个服务多个注册的情况下可以直接连某一个服务么?
可以直连,修改配置即可
十三、dubbo的安全机制?
dubbo通过token令牌防止用户绕过注册中心直连,然后在注册中心管理授权,dubbo提供了黑白名单,控制服务所允许的调用方
十四、dubbo的集群容错怎么做?
读操作建议使用Failover失败自动切换,默认重试两次其他服务器;写操作建议使用Failfast快速失败,发现一次调用失败就立即报错
十五、dubbo和dubbox之间的区别?
dubbox是当当网基于dubbo上做的一些扩展,如增加了 服务科restful调用,更新了开源组件等等。
十六、dubbo支持哪一些协议?
dubbo协议:单一长连接和NIO 异步通讯,适合大并发小数据量的服务调用,以及消费者远远大衣提供者,传输协议TCP,异步Hession序列化
rmi协议:基于JDK标准,传输和返回参数对象需要实现Serializable接口,使用java标准序列化机制,使用阻塞式短连接
webservice协议
Redis:基于redis实现的Rpc协议
十七、Dubbo集群的负载均衡有哪一些策略?
十八、如何处理服务调用超时?
dubbo在服务调用不成功,默认是会重试两次的。为了避免重复请求,对于核心的服务中心,应该去除dubbo的超时重试,合理的设置超时时间
DUBBO 面试灵魂18问的更多相关文章
- 死磕面试 - Dubbo基础知识37问(必须掌握)
作为一个JAVA工程师,出去项目拿20k薪资以上,dubbo绝对是面试必问的,即使你对dubbo在项目架构上的作用不了解,但dubbo的基础知识也必须掌握. 整理分享一些面试中常会被问到的dubbo基 ...
- [灵魂拷问]MySQL面试高频100问(工程师方向)
作者:呼延十 juejin.im/post/5d351303f265da1bd30596f9 前言 本文主要受众为开发人员,所以不涉及到MySQL的服务部署等操作,且内容较多,大家准备好耐心和瓜子矿泉 ...
- 应届生/社招面试最爱问的几道Java基础问题
本文已经收录自笔者开源的 JavaGuide: https://github.com/Snailclimb ([Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识)如果觉得不错 ...
- 面试官再问你 HashMap 底层原理,就把这篇文章甩给他看
前言 HashMap 源码和底层原理在现在面试中是必问的.因此,我们非常有必要搞清楚它的底层实现和思想,才能在面试中对答如流,跟面试官大战三百回合.文章较长,介绍了很多原理性的问题,希望对你有所帮助~ ...
- 面试一次问一次,HashMap是该拿下了(一)
文章目录 前言 一.HashMap类图 二.源码剖析 1. HashMap(jdk1.7版本) - 此篇详解 2. HashMap(jdk1.8版本) 3. ConcurrentHashMap ~~ ...
- JVM工作原理和特点(一些二逼的逼神面试官会问的问题)
作为一种阅读的方式了解下jvm的工作原理 ps:(一些二逼的逼神面试官会问的问题) JVM工作原理和特点主要是指操作系统装入JVM是通过jdk中Java.exe来完毕,通过以下4步来完毕JVM环境. ...
- 面试中常问的List去重问题,你都答对了吗?
面试中经常被问到的list如何去重,用来考察你对list数据结构,以及相关方法的掌握,体现你的java基础学的是否牢固. 我们大家都知道,set集合的特点就是没有重复的元素.如果集合中的数据类型是基本 ...
- 电话面试总结(问的很细).md
String 和其他基本类型有什么区别 Tip 基本类型有几种 为什么要给String创建一个常量池而不给其他类创建常量池 常量池的定义是什么 垃圾回收机制是如何运行的 对新生代和老年代不同的处理机制 ...
- 【搞定 Java 并发面试】面试最常问的 Java 并发进阶常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star![Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识.觉得内容不错 ...
随机推荐
- .net core ioc
-------------------------------------- 2. ---------------------------- -----------aop
- 把Java代码转成c#可用的dll
1.首先你需要到 IKVM官网 下载IKVM.http://sourceforge.net/projects/ikvm/files/,需要注意的是如果你用的是.net framework2.0,那么最 ...
- PMP备考经验总结-1906
1.考试成绩 3A1T1B 2.考试背景(为什么考) 工作多年,做的项目很多,上到几百万,下到几万的项目,有自己的一套方法论,但是没有系统的对项目的知识做一次完整的梳理整合,觉得在整体把控上需要做一次 ...
- Euler characteristic
Euler characteristic Euler定理 顶点(v),棱数(edge)(e),面(J) 尽管我们有四个不同的四面体,但是如果我们将顶点数\((v)\)减去棱数\((e)\)再加上四面体 ...
- smarty应用1 之 模板进行数学运算,保留小数位数
例子1 乘法除法运算: 1格式:{$number|number_format} 保留小数点后2位小数. {$v/$total*100|string_format:"%0.2f"|c ...
- make的使用和Makefile规则和编程及其基本命令(简单)
转自:http://blog.chinaunix.net/uid-23929712-id-2650328.html 概述: make从Makefile中文件中获取模块间的依赖关系,判断哪些文件 ...
- 初级vector
标准库vector类型 #include<vector> using std::vector; vector为一个类模板. vector的初始化 vector<T> v1; v ...
- geoserver整合swagger2支持自动生成API文档
网上各种博客都有关于swagger2集成到springmvc.springboot框架的说明,但作者在整合到geoserver中确碰到了问题,调试一番最后才解决,遂总结一下. swagger2集成只需 ...
- 签章新的pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://mave ...
- Catalan数应用问题