Java教程

【工作感悟】分布式技术:限流、通讯、缓存,全部一锅端

本文主要是介绍【工作感悟】分布式技术:限流、通讯、缓存,全部一锅端,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

前言

锁是一种用来控制多线程访问共享资源的工具。通常,锁可以独占共享资源:同一时间只有一个线程可以获得锁,并且所有访问共享资源的线程都必须首先获得锁。前面我们介绍过了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)]

这篇关于【工作感悟】分布式技术:限流、通讯、缓存,全部一锅端的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!