编程语言
首页 > 编程语言> > Java线程池面试问题,赶紧收藏起来!

Java线程池面试问题,赶紧收藏起来!

作者:互联网

## 一,session共享 首先第一个要解决的就是sesison共享的问题,如下图。 ![](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321330964434.jpg) 通常有两种解决方案,第1种是配置nginx的负载集群策略为ip_hash,第2种是将session存储到其它地方,一般推荐放到redis中。 第1种方案适合于临时解决或者是为了兼容历史项目,但是从应用服务器无状态的角度考虑,推荐把用户会话session放到redis,如下图。 ![](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321330954915.jpg) ## 二,本地缓存 如果使用本地缓存,当从单体迁移到集群后,就会面临缓存同步的问题,如下图。 ![](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321330602824.jpg) 最佳实践是上分布式缓存,既解决了缓存同步的问题,也释放了应用服务器的内存资源,如下图。 ![](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321330905332.jpg) ## 三,文件服务 应用服务器在上集群之前,文件通常会放在本地,或者单独的文件服务器上,因为文件服务需要占用大量的硬盘空间,以上两种方案都无法很好的解决硬盘扩容的问题,最佳实践是放到云存储上,比如阿里云的OSS,或者腾讯云的COS上,这样可以做到按需扩容,如下图。 ![](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321330594340.jpg) ## 四,分布式环境下线程同步问题 在单机环境下,使用lock就可以解决线程同步的问题,一旦上了集群之后,lock就不管用了,这时需要上分布式锁,分布式锁的解决方案也有很多,我这里推荐使用redis的setnx,需要注意的是,如果redis是集群部署的,需要考虑这种情形:假设我们在redis的主节点上添加了一把分布式锁,不幸的是主节点挂掉了,而且主节点上的锁还没有同步到从节点上,如果此时有客户端来请求获得同一把锁,那么它将顺利地获得锁,之前那把锁会被无情地忽视掉,这就是分布式锁在Redis集群中遇到的麻烦。 # 独家面经总结,超级精彩 本人面试腾讯,阿里,百度等企业总结下来的面试经历,都是真实的,分享给大家! ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321331727135.jpg) ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321331475203.jpg) ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321331136788.jpg) ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321331795203.jpg) # Java面试准备 准确的说这里又分为两部分: 1. Java刷题 2. 算法刷题 Java刷题:此份文档详细记录了千道面试题与详解; ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321332345233.jpg) ![image](http://www.icode9.com/i/li/?n=2&i=images/20210703/1625321332303392.jpg) **以上所有文档已经打包好,只需要动动手指点击【转发+关注】,然后[点击即可免费获取](https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB)!**

标签:Java,20210703,s2.51,面试,线程,https,images,cto,com
来源: https://blog.51cto.com/u_15292609/2973468