目录
一些技术专题的整理
Unix 下的 5 种 I/O 模型
《Unix 网络编程》中介绍了这 5 种 I/O 模型,由于该书中的示例图比较模糊,我照着画了一遍,原书中使用的是 UDP datagram 作为请求的数据,我这里统写为 data.
在阻塞的 I/O 模型中,发起读取调用时,应用程序阻塞在 recvfrom
方法上,recvfrom 方法会进行系统调用读取内核空间中的数据,当数据未就绪时,则会等待数据就绪;当数据就绪时,数据会从内核空间拷贝到用户空间,当拷贝完成后,recvfrom
方法返回,应用程序继续处理数据。在这整个过程中,recvfrom 方法和支持该方法的系统调用一直处于阻塞状态(无法返回),直到请求的数据到达内核,并从内核拷贝到了应用内存中。
进程是操作系统进行资源分配的最小单位;线程是进程的一个执行单元,是 CPU 调度的基本单位
进程之间的资源是互相独立的,一个进程内可以有多个线程运行,线程之间共享同一进程内的资源。
进程间的切换开销大,线程由于轻量开销相对少
本篇是学习 JVM 的一些知识点总结,翻阅了大量参考资料,不求多深入到细节,只求把一些重点的内容整理出来,所有参考资料均在文章末尾列出,这些参考资料才是最大的宝藏,文章所引用图片均来自于互联网。
一般来讲,JVM 的架构分为3个部分:类加载子系统、运行时数据区域、执行引擎。如下图。
类加载子系统将二进制的字节码读入和转换成虚拟机能够处理的数据结构,Java 虚拟机在执行Java程序的过程中将它所管理的内存区域划分为若干不同的数据区域,这些区域有不同作用,统称为运行时数据区域。执行引擎是虚拟机的执行字节码的概念模型,在虚拟机的实现中有解释执行(通过解释器执行)和编译执行(通过即时编译器生成本地代码执行)2种类型。
java -jar xxx.jar
执行时找不到主类 或 ClassNotFoundException
引入的 jar 包中依赖冲突了怎么办,有多个版本的依赖类
有没有想过 Spring Boot 项目可以直接打包成一个 jar 包还能直接通过java -jar
运行,而当我们自己去写一个小项目去打成 jar 包的时候,要么就是打成的 jar 包运行的时候报 “找不到主类”, 要么就是报一个依赖的Class找不到,这是为什么呢?
Understanding Reactor Pattern: Thread-Based and Event-Driven - DZone Java
(原文的图片挂了,这是我自己加的,使用的是 Doug Lea 的PPT中的)
Reactor 模式在实践中是怎么做的,为什么理解它很重要。
来源: https://dzone.com/articles/introduction-to-java-bytecode
这是一遍相对来说比较简单的Java 字节码入门文章,一开始作者讲到了阅读Java 字节码比较枯燥无味,但是通过自己的故事说明了字节码的作用,事情是这样的,这哥们在很早之前做了一次功能变更,目的是为了测试修复一个潜在的性能问题, 并且打好了 JAR 包部署到服务器上。不幸的是,他并没有将源码提交到版本控制系统上,后来不知什么原因这段代码找不到了,一点痕迹都没有了(做了什么新的功能,记得一定要提交代码到Git 上),几个月后当他想用到那段代码的时候,悲剧就发生了。还好这哥们在远程机器上部署的 JAR 包还在,于是他用反编译的工具来找到源码,更不幸的是,反编译工具在关键的Class
上崩溃了,也就是他正好要找的关键代码!
依赖关系是2个关联元素之间的语义连接,这种连接关系导致一个元素的变化可能会引起依赖它的其他元素的变化。依赖关系是单向的。
参考:Best Practices: Java Memory Arguments for Containers - DZone Java
TL;DR
简而言之,在容器内有3组参数来设置 JVM 的最大堆内存: