前言
Dubbo用起来就和EJB、WebService差不多,调用一个远程的服务(或者JavaBean)的时候在本地有一个接口,就像调用本地的方法一样去调用,它底层帮你实现好你的方法参数传输和远程服务运行结果传回之后的返回,就是RPC的一种封装
当然,这个只是Dubbo的最基本的功能,它的特点是:
- 它主要是使用高效的网络框架和序列化框架,让分布式服务之间调用效率更高。
- 采用注册中心管理众多的服务接口地址,当你想调用服务的时候只需要跟注册中心询问即可,不用像使用WebService一样每个服务都得记录好接口调用方式。
- 监控中心:实现对服务方和调用方之间运行状态的监控,还能控制服务的优先级、权限、权重、上下线等,让整个庞大的分布式服务系统的维护和治理比较方便。
- 高可用:有个服务宕机了?注册中心就会从服务列表去掉该节点。还是调用到了?客户端会向注册中心请求另一台可用的服务节点重新调用。注册中心宕机?注册中心也能实现高可用(ZooKeeper)。
- 负载均衡:采用软负载均衡算法实现对多个相同服务的节点的请求负载均衡。
相信不少去面试阿里的朋友都有被面试官问到了Dubbo的相关问题,小编在这里将阿里面试官问的最频繁的那些Dubbo面试题整理了出来,以供大家参考
8.15 一面 (60min)
- 自我介绍,为什么投客户端
- python和java有什么区别
- java内存模型
- gc讲讲
- http https区别
- cookie,session
- https握手过程
- 对称非对称加密算法?哪个效率高?
- tcp握手要三次,挥手要几次,为什么
- 进程和线程,描述一下
- 进程通信方式
- 线程同步方式
- 写个生产者消费者模型,要求多线程环境下
- 为什么要用synchronized?原理?效率?
算法:
- 二叉树,打印所有根结点到叶节点路径和为k的路径。
反问
先别走,二面面试官马上来
8.15 二面 (40min):
- 自我介绍,为什么投客户端
- 讲讲在学校的科研项目
- python和java最大的区别是什么,从你的使用感受说说
- https(问过了)
- 数字签名验证过程
- 从输入一个url到页面展示出来的过程
- tcp怎么保证可靠性
- tcp报文序号怎么分配的
- utf-8,utf-16是啥?有啥区别?为什么网络传输大部分用utf-8?
- 内核态和用户态
- 智能指针了解吗(不了解)
算法比较简单:
- 二叉树,把每个节点的值反转,并输出所有节点和。
反问
8.20 三面 (60min):
- 评价一下自己前两面的表现?
- 为什么投客户端,听前面的同学说你觉得客户端简单?(不是不是,balabla)
- 问项目,问得很细,每一步是怎么实现的,过程,如果不是自己亲手一步一步做绝对会露馅
- 做项目时遇到了什么困难
- redis用来做什么?效率怎么样?
- 分布式锁都可以怎么实现?
- 问点计算机基础吧(终于)
- java代码从编写到运行的过程
- 堆内存通过gc自动回收,栈内存怎么回收?
- 栈溢出是什么?什么场景可能会出现栈溢出?
- 问点网络吧,syn攻击了解吗?(以前刷博客看过一眼,只懂个皮毛,不过面试官很好,说如果不了解就不问这方面的内容了。我赶紧说不了解)
- 那换个问题吧,输入url到页面展示的过程?(窃喜,问过了)
- 然而并没有让我说完,DNS解析详细问了一下,然后路由转发详细问了一下,说看我这方面挺熟的,没必要再说了。
本来说要写一道算法,但是估计看时间差不多了,就没让我写,直接反问环节
其实准备字节跳动的面试还是需要着重准备基础部分(数据结构、算法、操作系统、计算机网络),另外对做算法题的要求很高,如果在看到题目的时候能直接给出这个题目的最优时空复杂度解法,面试官对你的评价会很高。
如果基础知识比较扎实了,可以看看网络上的面试经验,找找自己不会的知识点,查漏补缺。
也祝大家都能拿到心仪的offer!
Java 多线程学习手册
这个文档内容的整合有博文、书籍、面试题等,对于一些已经讲解得很简明的技术点进行了一个直接的引用;对于一些没有讲解清楚的知识点,用图片或者代码实践进行展示;对于那些争论较大的技术点,本文档在核对了巨多材料的情况下,从而得出的最佳答案。
该笔记分为三大模块:基础+原理+JDK工具,共二十个小节;从基础由浅入深,直击底层原理。
计算机网络顶级教程
HTTP是一个在计算机世界里专门在两点之间传输文字、图片、音频、视频等超文本数据的约定和规范。简单来说,如果你不懂HTTP协议,那就相当于是个只有“半桶水”的程序员。
算法与数据结构
该文档的内容全部选自 LeetCode 和牛客网的原题,你只要按照顺序刷题,保你一个月速成算法。 还在为动态规划系列问题发愁吗?书中给动态规划总结出了一套框架模板,还有整整一个章节教你如何套模板做题
最后
现在其实从大厂招聘需求可见,在招聘要求上有高并发经验优先,包括很多朋友之前都是做传统行业或者外包项目,一直在小公司,技术搞的比较简单,没有怎么搞过分布式系统,但是现在互联网公司一般都是做分布式系统。
所以说,如果你想进大厂,想脱离传统行业,这些技术知识都是你必备的,下面自己手打了一份Java并发体系思维导图,希望对你有所帮助。