最近参加了一次面试,我这篇文章将对面试进行复盘,因为没有复盘的面试,不是一次成功的面试。
面试问题大概几个模块:
1、java基础
2、javaweb
3、运维
4、数据库
5、微服务基础
6、微服务设计
7、成长性
第一次面试的问题:
都是循序渐进的,这是我面试的一些回答,以及反思
1、io,nio,aio的区别?
回答:io 是 同步阻塞,nio同步非阻塞,aio当时记不大清(以为自己没用过,其实后来一想,Callable,Future不就是aio吗),
aio异步非阻塞
2、讲讲nio
回答:nio 是同步非阻塞,由一个或多个线程处理多个channel,基于事件驱动,也就是selector,Linux 的 selector,poll,epoll,如果可以讲讲这方面就更好了
3、问有用过Spring吗?IOC是个咋回事?
回答:用过,IOC就是控制反转,也可以叫依赖注入,将本来由程序员做的一些操作,比如new 对象,现在交个spring容器来处理,简化了编程。
4、那IOC创建的对象默认是单例对吧?那么他是否是线程不安全的呢?
回答:是的,Ioc创建对象默认是单例,也可以通过scope的prototype设置为非单例,他是线程不安全的,因为他是单例模式,是会出现线程不安全的情况
5、那么让你来做如何让他保证线程安全呢?
回答:可以,我之前对HttpRequestServlet也进行过测试,我将其使用@Autowide注解方式注入,然后测试了高并发情况下,我发现它是线程安全的,然后我分析它的源码,发现了它底层使用的是ThreadLocal来保证线程安全。
6、那么来问问你微服务,微服务使用过哪些组件?
回答:eureka做注册中心,config来做中心化配置,hystrix来做服务降级熔断。。。。。。
7、那么讲一讲hystrix
回答:hystrix做服务降级熔断,熔断方面就像一个断路器,当请求失败超过一定的阈值,则将其处于熔断状态,然后熔断一定时间,将恢复半熔断状态,半熔断状态可以接受请求,不用快速失败,如果请求成功则恢复。
8、那么来设计一下几个服务,服务A,下订单,服务B,涨积分,服务C,调用物流接口,现在支付成功后设计,可以使用其他的组件,如果需要的话
回答:我认为下订单要给客户一个良好的体验,时间越短越好,流程越短越好,所以我认为将其分为核心业务和非核心业务,比如订单服务为核心业务,涨积分为非核心业务(当时这里我对物流不清楚,我就把它划分成核心业务了= =沙雕),一个请求过来,先同步走订单服务,然后再将涨积分服务发送给MQ,让积分服务监听MQ,这里就将涨积分服务给异步实现了。
9、那么如果这里涨积分如果失败了怎么办?
回答:(当时这里我就知道要考分布式事务了)当时我用过txn框架,是一款分布式事务处理的框架,采用的是补偿机制。
我还认为分布式事务也可以不用技术方面来实现,我之前公司是做互联网金融的,如果是P2P,有一个用户下了100万的订单,但是P2P,都知道,100万订单可能并不是一单,而是将100万拆成了许多单,比如10个10万,那么现在有一个失败了,总不能让其回滚把,那么现在就需要由客服马上电话处理,通知该用户,我们将把您下的单进行处理,所以这里用人工服务更好,我们要让用户已最快的速度将钱打过来,给用户一个良好的体验
大概谈到这里,就差不多了,也谈了将近40分钟。
然后就结束了这一次面试。
总的来说,面试官会将你所掌握的知识,尽可能的深入挖掘,看看你最终能够回答到哪一步,他们不是为了想出难的题目让你回答不出来,而是想看看你对知识的掌握边界在哪,更好的了解你。