RPC概述

RPC(Remote Procedure Call)即远程过程调用,允许一台计算机调用另一台计算机上的程序得到结果,而代码中不需要做额外的编程,就像在本地调用一样。

现在互联网应用的量级越来越大,单台计算机的能力有限,需要借助可扩展的计算机集群来完成,分布式的应用可以借助RPC来完成机器之间的调用。

一面

一面就做了一道算法题,要求两小时内完成,给了长度为N的有重复元素的数组,要求输出第10大的数。典型的TopK问题,快排算法搞定。

算法题要注意的是合法性校验、边界条件以及异常的处理。另外,如果要写测试用例,一定要保证测试覆盖场景尽可能全。加上平时刷刷算法题,这种考核应该没问题的。

二面

  1. 自我介绍下呗
  2. 开源项目贡献过代码么?(Dubbo提过一个打印accesslog的bug算么)
  3. 目前在部门做什么,业务简单介绍下,内部有哪些系统,作用和交互过程说下
  4. Dubbo踩过哪些坑,分别是怎么解决的?(说了异常处理时业务异常捕获的问题,自定义了一个异常拦截器)
  5. 开始进入正题,说下你对线程安全的理解(多线程访问同一个对象,如果不需要考虑额外的同步,调用对象的行为就可以获得正确的结果就是线程安全)
  6. 事务有哪些特性?(ACID)
  7. 怎么理解原子性?(同一个事务下,多个操作要么成功要么失败,不存在部分成功或者部分失败的情况)
  8. 乐观锁和悲观锁的区别?(悲观锁假定会发生冲突,访问的时候都要先获得锁,保证同一个时刻只有线程获得锁,读读也会阻塞;乐观锁假设不会发生冲突,只有在提交操作的时候检查是否有冲突)这两种锁在Java和MySQL分别是怎么实现的?(Java乐观锁通过CAS实现,悲观锁通过synchronize实现。mysql乐观锁通过MVCC,也就是版本实现,悲观锁可以通过select… for update加上排它锁)
  9. HashMap为什么不是线程安全的?(多线程操作无并发控制,顺便说了在扩容的时候多线程访问时会造成死锁,会形成一个环,不过扩容时多线程操作形成环的问题再JDK1.8已经解决,但多线程下使用HashMap还会有一些其他问题比如数据丢失,所以多线程下不应该使用HashMap,而应该使用ConcurrentHashMap)怎么让HashMap变得线程安全?(Collections的synchronize方法包装一个线程安全的Map,或者直接用ConcurrentHashMap)两者的区别是什么?(前者直接在put和get方法加了synchronize同步,后者采用了分段锁以及CAS支持更高的并发)
  10. jdk1.8对ConcurrentHashMap做了哪些优化?(插入的时候如果数组元素使用了红黑树,取消了分段锁设计,synchronize替代了Lock锁)为什么这样优化?(避免冲突严重时链表多长,提高查询效率,时间复杂度从O(N)提高到O(logN))
  11. redis主从机制了解么?怎么实现的?
  12. 有过GC调优的经历么?(有点虚,答得不是很好)
  13. 有什么想问的么?

三面

  1. 简单自我介绍下
  2. 监控系统怎么做的,分为哪些模块,模块之间怎么交互的?用的什么数据库?(MySQL)使用什么存储引擎,为什么使用InnnoDB?(支持事务、聚簇索引、MVCC)
  3. 订单表有做拆分么,怎么拆的?(垂直拆分和水平拆分)
  4. 水平拆分后查询过程描述下
  5. 如果落到某个分片的数据很大怎么办?(按照某种规则,比如哈希取模、range,将单张表拆分为多张表)
  6. 哈希取模会有什么问题么?(有的,数据分布不均,扩容缩容相对复杂 )
  7. 分库分表后怎么解决读写压力?(一主多从、多主多从)
  8. 拆分后主键怎么保证惟一?(UUID、Snowflake算法)
  9. Snowflake生成的ID是全局递增唯一么?(不是,只是全局唯一,单机递增)
  10. 怎么实现全局递增的唯一ID?(讲了TDDL的一次取一批ID,然后再本地慢慢分配的做法)
  11. Mysql的索引结构说下(说了B+树,B+树可以对叶子结点顺序查找,因为叶子结点存放了数据结点且有序)
  12. 主键索引和普通索引的区别(主键索引的叶子结点存放了整行记录,普通索引的叶子结点存放了主键ID,查询的时候需要做一次回表查询)一定要回表查询么?(不一定,当查询的字段刚好是索引的字段或者索引的一部分,就可以不用回表,这也是索引覆盖的原理)
  13. 你们系统目前的瓶颈在哪里?
  14. 你打算怎么优化?简要说下你的优化思路
  15. 有什么想问我么?

四面

  1. 介绍下自己
  2. 为什么要做逆向?
  3. 怎么理解微服务?
  4. 服务治理怎么实现的?(说了限流、压测、监控等模块的实现)
  5. 这个不是中间件做的事么,为什么你们部门做?(当时没有单独的中间件团队,微服务刚搞不久,需要进行监控和性能优化)
  6. 说说Spring的生命周期吧
  7. 说说GC的过程(说了young gc和full gc的触发条件和回收过程以及对象创建的过程)
  8. CMS GC有什么问题?(并发清除算法,浮动垃圾,短暂停顿)
  9. 怎么避免产生浮动垃圾?(记得有个VM参数设置可以让扫描新生代之前进行一次young gc,但是因为gc是虚拟机自动调度的,所以不保证一定执行。但是还有参数可以让虚拟机强制执行一次young gc)
  10. 强制young gc会有什么问题?(STW停顿时间变长)
  11. 知道G1么?(了解一点 )
  12. 回收过程是怎么样的?(young gc、并发阶段、混合阶段、full gc,说了Remember Set)
  13. 你提到的Remember Set底层是怎么实现的?
  14. 有什么想问的么?

五面

五面是HRBP面的,和我提前预约了时间,主要聊了之前在蚂蚁的实习经历、部门在做的事情、职业发展、福利待遇等。阿里面试官确实是具有一票否决权的,很看重你的价值观是否match,一般都比较喜欢皮实的候选人。HR面一定要诚实,不要说谎,只要你说谎HR都会去证实,直接cut了。

  1. 之前蚂蚁实习三个月怎么不留下来?
  2. 实习的时候主管是谁?
  3. 实习做了哪些事情?(尼玛这种也问?)
  4. 你对技术怎么看?平时使用什么技术栈?(阿里HR真的是既当爹又当妈,)
  5. 最近有在研究什么东西么
  6. 你对SRE怎么看
  7. 对待遇有什么预期么

最后

看完上述知识点如果你深感Java基础不够扎实,或者刷题刷的不够、知识不全面

小编专门为你量身定制了一套<Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法>

针对知识面不够,也莫慌!还有一整套的<Java核心进阶手册>,可以瞬间查漏补缺

全都是一丢一丢的收集整理纯手打出来的——收整在***【我的学习笔记大全】***,有需要的朋友可以自取

更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~

、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~

[外链图片转存中…(img-LyRC32BP-1619325953851)]

又是一年金九银十!一起看看这些大厂面试真题查漏补缺吧,程序员翻身之路相关推荐

  1. 又是一年金九银十!java实战第二版pdf下载

    一. 什么是架构和架构本质 在软件行业,对于什么是架构,都有很多的争论,每个人都有自己的理解. 此君说的架构和彼君理解的架构未必是一回事.因此我们在讨论架构之前,我们先讨论架构的概念定义,概念是人认识 ...

  2. 又是一年金九银十!docker搭建ssr

    ClickHouse 是什么? ClickHouse:是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS) 我们首先理清一些基础概念 OLTP:是传统的关系型数据库,主要操作增删改查,强调事 ...

  3. 又是一年金九银十!java编程思想第五版百度云下载

    前言 高并发,几乎是每个程序员都想拥有的经验.原因很简单:随着流量变大,会遇到各种各样的技术问题,比如接口响应超时.CPU load升高.GC频繁.死锁.大数据量存储等等,这些问题能推动我们在技术深度 ...

  4. 金九银十已到,大厂面试大全+面试经历都在这了(建议收藏)

    前言 疫情到现在已经持续有3年的时间了,由于疫情的影响,无数行业都受到了影响,互联网寒冬下,许多程序员被裁,大环境格外困难. 我发现一个奇怪的现象:那些跳槽的人,总是从一个坑,跳进令一个坑中.毕竟一年 ...

  5. 2021年金九银十最新的VUE面试题☀️《❤️记得收藏❤️》

    2021年金九银十最新的VUE面试题☀️<❤️记得收藏❤️> 目录

  6. 10.牛批了 Android 2022高级 资深面试题 一线大厂和二线大厂面试真题精选 (蚂蚁金服 附答案)第十套 40k+

    笔者是面霸,面试500+场       当过考官:面过别人500+场     去过500强,也呆过初创公司. 斩获腾讯.华为.字节跳动,蚂蚁金服,OPPO,美团,安卓岗offer!我有一套速通大厂技巧 ...

  7. 2022年金九银十软件测试面试题大全,精心挑选常问面试题

    以下是软件测试相关的面试题及答案,欢迎大家参考! 1.你的测试职业发展是什么? 测试经验越多,测试能力越高.所以我的职业发展是需要时间积累的,一步步向着高级测试工程师奔去.而且我也有初步的职业规划,前 ...

  8. 捡漏!蚂蚁金服面试题泄露,看完这十道面试必问真题,冲刺金九银十,稳拿大厂Offer!!

    前言 最近编程讨论群有位小伙伴去蚂蚁金服面试了,以下是面试的真题,跟大家一起来讨论怎么回答. 1. 用到分布式事务嘛?为什么用这种方案,有其他方案嘛? 什么是分布式事务 谈到事务,我们就会想到数据库事 ...

  9. python高频面试题_2019下半年金九银十Python高频面试题(第四弹)

    第四弹来了,Python高频面试题总结! 一. 将字符串 "k:1 |k1:2|k2:3|k3:4",处理成字典 {k:1,k1:2, str1 = "k:1|k1:2| ...

  10. 金九银十!字节跳动三轮面试惨败,总结面试经验,下次再战!

    写在开篇 和往年相比,今年的秋招看上去不是那么顺利,多少都受疫情有所影响,但是令我惊讶的是第一家给我面试机会的公司竟然是宇宙条.一开始接到面试通知时,心情特别复杂,紧张又兴奋,字节跳动是出了名的考算法 ...

最新文章

  1. 模仿Hibernate的逆向工程_java版_源码下载
  2. 为什么不推荐使用uuid或者雪花id作为主键?
  3. Erlang error?
  4. windows下安装mysql以及解决(MySQL 服务正在启动 . MySQL 服务无法启动。服务没有报告任何错误。)...
  5. 图像修复中的TV模型
  6. MySQL执行外部sql脚本
  7. ip guard保证java代码安全_IP-guard加密新增四大功能 让一“密“防百疏
  8. 谋定菲律宾农业全产业链建设 对话国际农民丰收节贸易会
  9. wamp测试mysql_Wamp 配置及测试
  10. 抢攻5G网络功能虚拟化,英特尔推专用FPGA加速卡
  11. 基于motion的视频压缩的实时监控系统
  12. 排序算法总结(四)快速排序【QUICK SORT】
  13. Linux后台运行python程序并输出到日志文件
  14. 公司管理系列--最难挖的阿里,最好挖的百度;最难走的360,最易走的腾讯
  15. 多层感知机BP算法推导
  16. 沁恒MCU串口使用指南
  17. 关于电脑突然产生数字文件夹用360删不掉的情况
  18. easyExcel导出文件为空解决
  19. 猜java数字游戏大全_Java 猜数字游戏
  20. MySQL---规范数据库设计

热门文章

  1. linux虚拟ip secondary ip primary ip;scope global secondary eth0 zuoxudong ;veth
  2. AXI5 new feature: support atomic transaction
  3. 服务器上没有空闲位置星露谷,星露谷物语 献祭全房间收集攻略(上)
  4. 职业锚和倾向测试,让你发现真实的自己
  5. 【视频转码】ubuntu视频转windows视频
  6. 使用python爬取号码归属地列表,制作握手包破解字典
  7. 现在,让客服接管数字化企业
  8. Doris ODBC外表使用
  9. JavaScript图标移动小案例
  10. 做你的大玩具——轩小样儿的六一