**程序员小李:**额~是说那四种线程池吗?还是线程池的工作原理、工作流程?
**面试官:**额~那换一个问题吧!什么是中间件?
程序员小李:
中间件是处于操作系统和应用程序之间软件,使用时往往是一组中间件集成在一起,构成一个平台(开发平台+运行平台),在这组中间件中必须要有一个通信中间件,即中间件=平台+通信。该定义也限定了只有用于分布式系统中才能称为中间件。
主要分类:远程过程调用、面向消息的中间件、对象请求代理、事物处理监控。
面试官:那如果要你自己设计一个中间件,你会怎么设计呢?
**程序员小李:**我会从以下几个方面考虑:
1、远程过程调用
**2、面向消息:**利用高效的消息传递机制进行平台无关的数据交流,并给予数据通信来进行分布式系统的集成,有以下三个特点:
通讯程序可以在不同的时间运行
通讯晨旭之家可以一对一、一对多、多对一甚至是上述多种方式的混合
程序将消息放入消息队列会从小吸毒列中取出消息来进行通讯
3、对象请求代理:提供不同形式的通讯服务包括同步、排队、订阅发布、广播等。
可构筑各种框架如:事物处理监控器、分布数据访问、对象事务管理器 OTM 等。
4、事物处理监控有以下功能:
进程管理,包括启动 server 进程、分配任务、监控其执行并对负载进行平衡
事务管理,保证在其监控下的事务处理的原子性、一致性、独立性和持久性
通讯管理,为 client 和 server 之间提供多种通讯机制,包括请求响应、会话、排队、订阅发布和广播等
面试官:嗯,很好,那个MySQL优化怎么做?
**程序员小李:**MySQL 的优化一般可以从存储引擎的选择、字段类型的选择、索引的选择、分区分表、主从复制、读写分离、SQL 优化等这里方面入手。
额,例如,储存引擎方面,在创建表的时候我们使用sql语句…
**面试官:**行了行了,不用太细了,我听不懂,那个,讲一下Redis吧!
Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?
**程序员小李:**Redisson、Jedis、lettuce 等等,官方推荐使用 Redisson。
面试官:Redis 如何做内存优化?
**程序员小李:**尽可能使用散列表(hashes),散列表(是说散列表里面存储的数少)使用的内存非常小,所以应该尽可能的将数据模型抽象到一个散列表里面。
比如 web 系统中有一个用户对象,不要为这个用户的名称,姓氏,邮箱,密码设置单独的 key,而是应该把这个用户的所有信息存储到一张散列表里面。
面试官:那个Redis缓存雪崩、穿透这些你是不是也知道?
**程序员小李:**嗯,知道,缓存雪崩就是缓存同一时间大面积的失效,所以…
**面试官:**可以了可以了,咳咳~
面试官左手掏出了右口袋的纸巾,擦了一把汗。
**面试官:**嗯,你的表现很好,技术功底也很扎实,包括我,前两个面试官也很满意…
程序员小李面露欣喜,心中也已经对这份工作十拿九稳了。
**面试官:**但是,事情是这样的啊,就你现在的情况,我们招不起,想招一个更便宜的
**程序员小李:**啊?没关系的,你就按照你们发的那个薪资范围来就行…
**面试官:**实话告诉你吧,那就是写在上面吸引人的,实际上我们连最低那个都达不到,这样,如果你接受10K的话,明天就来上班
**程序员小李:**这样啊~耽误我这么久时间,那行吧,我先回家,你们等通知吧!
读者福利
由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴
关注+点赞后,点击这里获取完整面试题(含答案)!
更多笔记分享
转存中…(img-sTbub0NV-1628290094645)]
[外链图片转存中…(img-Aqsdwglx-1628290094646)]
更多笔记分享