【工作感悟】分布式技术:限流、通讯、缓存,全部一锅端
作者:互联网
前言
锁是一种用来控制多线程访问共享资源的工具。通常,锁可以独占共享资源:同一时间只有一个线程可以获得锁,并且所有访问共享资源的线程都必须首先获得锁。前面我们介绍过了synchronized,使用synchronized的方法和代码块作用域机制使得使用监视器锁更加简单,并且帮助避免了许多关于锁的常见编程错误,比如锁未及时释放等问题。但是有时候我们需要更灵活的使用锁资源,例如,一些遍历并发访问的数据结构的算法需要使用“手动”方法,或者“锁链”:你先获得节点A的锁,然后是节点B,然后释放A获得C,再释放B获得D,以此类推。这种方式如果要使用synchronized就不是很好实现,但是有了Lock就不一样了,Lock接口允许以不同的范围去获取和释放锁,并且允许同时获得多把锁,也可以以任意的顺序释放。
一、网络原理
- OSI 与 TCP/IP 各层的结构与功能,都有哪些协议
- TCP 建立连接的过程,为什么要三次握手?
- TCP、UDP 协议的区别,各自的应用场景
- 打开浏览器,输入 URL 地址,访问主页的过程
- HTTP 有哪些方法?
- HTTP 和 HTTPS 有什么区别?
二、Java 核心技术
- HashMap 底层数据结构是什么,时间复杂度多少?
- JDK 8 中对 HashMap 做了怎样的优化?
- HashMap 和 TreeMap 什么区别?
- ConcurrentHashMap 的实现原理
- 包装类的缓存机制如何应用
- Error 和 Exception 有什么区别?
- 通过一个例子描述下 BIO、NIO、AIO 三者的区别?
- 动态代理实现有几种方式?
- 阐述 JDBC 操作数据库的步骤?
- Lambda 表达式有哪些应用?
三、Java 并发编程
- 线程有哪几种状态?
- 创建线程池需要指定什么参数?
- 线程池底层如何实现,工作原理怎样?
- volatile 的实现原理是什么?
- Synchronized 和 Lock 什么区别?
- Java 中有哪些锁?有什么区别?
- Synchronized 锁升级的原理是什么?
- 使用 ThreadLocal 有哪些注意事项?
- CAS 如何实现的?
- Thread 类的 sleep() 方法和对象的 wait() 方法都可以让线程暂停执行,它们有什么区别?
- 守护线程是什么?
- 说一下 Atomic 的原理?
- 如何用 Java 实现生产者消费者?
- Java 内存模型是什么?
- JMM 在并发中有什么应用?
四、Java 虚拟机
- 描述一下 JVM 的内存结构?
- Java 8 的内存分化有哪些改进?
- 有哪些对象分配规则?
- Java 对象创建过程
- 描述 JVM 加载 class 文件的机制?
- 双亲委派模型是什么?
- 字节码是什么?字节码增强有哪些?
- JVM 有哪些编译优化?
- 常见的垃圾回收算法和收集器有哪些?
- 如何打印虚拟机堆栈信息?
五、Spring 系列
- 什么是 AOP,AOP 的作用是什么?
- 如何理解 Spring 的 IOC 和 DI?
- CGLIB 和 JDK 动态代理什么区别?
- Spring Boot 支持哪些嵌入式容器,如何配置?
六、数据库
- MySQL 中 MyISAM 与 InnoDB 引擎的区别
- MySQL InnoDB 的默认隔离级别是什么?
- 举一个数据库死锁的例子,MySQL 怎么解决死锁?
- MySQL InnoDB 存储的文件结构,为什么使用 B-Tree(B+Tree)?
- 索引的类型有哪些?
- 如何创建合理的索引,索引如何优化?
- 索引失效有哪几种情况?
- …
七、分库分表
- 为什么要分库分表?
- 如何解决分库分表主键问题?
- 分库分表有哪些中间件,有什么优点和缺点?
- …
八、分布式缓存
- 怎么保证缓存与数据库的双写一致性
- Redis 新版本支持多线程,性能怎么样?
- Redis 有什么数据类型,都在哪些场景下使用?
- Redis 的高可用有哪些机制?
- Redis 的持久化有哪些方式?
- Redis 过期策略都有哪些?
- 写一下 Java 版本的 LRU 代码?
九、分布式服务框架
- Dubbo 的架构和服务调用过程怎样?
- 注册中心挂了可以继续通信吗?
- ZooKeeper 的原理是什么?
- Dubbo 支持哪些序列化协议?
十、分布式消息队列
- 消息队列有什么作用?
- 如何保证消息队列的高可用?
- 如何保证消息不被重复消费?
- 不同消息队列的选型和对比
十一、分布式系统
- CAP 理论是什么?
- Base 理论是什么?
- 数据一致性有哪几种?
- 分布式事务有哪些解决方案?
- 如何使用 Redis 实现分布式锁?
- 负载均衡有哪些常见策略?
**看完你能回答上几道?据我所知,如果能回答的出其中的一半,就算是勉强及格了。**如果都答对你都能全部回答出来,那你应该是妥妥的技术大牛了!可以放心去投大厂简历了!
最后
给大家送一个小福利
资料都是免费分享的,附送高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。点我免费领取!!!
的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。点我免费领取!!!
[外链图片转存中…(img-H58rjXva-1620870407424)]
标签:缓存,Java,哪些,什么,区别,Redis,限流,线程,一锅端 来源: https://blog.csdn.net/m0_56604758/article/details/116737716