Java旅程(五)Spring 框架与微服务架构 了解 JVM 内部原理和调优
在现代企业级应用中,Spring 框架和微服务架构已经成为主流技术,而 Java 虚拟机(JVM)的理解和调优对于保证应用的高性能和稳定性也至关重要。本篇博客将深入讲解 Spring 框架与微服务架构,并进一步探讨 JVM 内部原理和调优,帮助你提升开发和性能调优的技能。
1. Spring 框架与微服务架构
Spring 框架是 Java 平台上的一个轻量级开源框架,它可以帮助开发者快速构建可扩展、松耦合的应用。Spring 框架通过一系列的模块(如 Spring Core、Spring MVC、Spring Boot 等)提供了强大的功能支持。在现代开发中,Spring 被广泛用于构建 微服务架构,使得应用变得更加灵活和可维护。
1.1 Spring 框架基础
Spring 框架的核心理念是 控制反转(IoC) 和 面向切面编程(AOP)。
1.1.1 控制反转(IoC)与依赖注入(DI)
IoC 使得对象的创建和管理交给 Spring 容器,而不是由程序员手动控制。依赖注入(DI)是 IoC 的一种实现方式,它允许通过构造函数、字段或方法注入对象的依赖。
示例:使用 Spring IoC 容器
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class HelloWorld {public static void main(String[] args) {// 加载 Spring 配置文件ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");// 从容器中获取 beanMessageService messageService = (MessageService) context.getBean("messageService");messageService.sendMessage("Hello, Spring!");}
}interface MessageService {void sendMessage(String message);
}class EmailService implements MessageService {@Overridepublic void sendMessage(String message) {System.out.println("Sending email: " + message);}
}
解释:
- 使用
ApplicationContext加载 Spring 配置文件(如beans.xml)。 EmailService类作为一个 Spring Bean 被管理,可以通过getBean方法获取并使用。
1.1.2 面向切面编程(AOP)
AOP 是 Spring 提供的一个强大特性,允许将横切关注点(如日志、事务管理等)从业务逻辑中分离出来。AOP 通过切面(Aspect)来实现功能的横向扩展。
示例:AOP 日志记录
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;@Aspect
@Component
public class LoggingAspect {@Before("execution(* com.example.service.*.*(..))")public void logBeforeMethod() {System.out.println("Method execution started...");}
}
解释:
@Aspect标注该类为切面。@Before注解表示在目标方法执行前执行logBeforeMethod方法,用于记录日志。
1.2 Spring Boot:简化开发流程
Spring Boot 是基于 Spring 的一个开源框架,它通过约定优于配置的方式,极大地简化了 Spring 应用的开发。它通过自动化配置、嵌入式服务器等特性,使得开发者可以快速启动和开发应用。
1.2.1 使用 Spring Boot 创建 RESTful 服务
Spring Boot 提供了强大的支持来快速构建 RESTful 服务。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@SpringBootApplication
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}@RestController
class HelloController {@GetMapping("/hello")public String sayHello() {return "Hello, Spring Boot!";}
}
解释:
@SpringBootApplication注解是 Spring Boot 应用的入口。@RestController和@GetMapping用于定义 RESTful API。
1.3 微服务架构与 Spring Cloud
微服务架构是一种将应用拆分成多个小型、独立、可独立部署和扩展的服务的架构模式。Spring Cloud 提供了一系列工具来支持微服务架构,如服务注册与发现、负载均衡、分布式配置、断路器等。
1.3.1 服务注册与发现:Eureka
Spring Cloud 提供了 Eureka 作为服务注册和发现的解决方案。每个微服务都向 Eureka 注册,客户端通过 Eureka 查找服务实例。
示例:Eureka 客户端和服务端
// 服务端
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {public static void main(String[] args) {SpringApplication.run(EurekaServerApplication.class, args);}
}// 客户端
@EnableEurekaClient
@SpringBootApplication
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
解释:
@EnableEurekaServer启动 Eureka 服务端。@EnableEurekaClient启动 Eureka 客户端并注册到服务注册中心。
1.4 微服务架构的优势
- 模块化:每个微服务可以独立开发、部署和扩展,减少了不同模块之间的耦合。
- 独立扩展:可以根据需求扩展服务,提升系统的可伸缩性。
- 容错性:使用像 Hystrix 这样的断路器模式可以有效避免系统崩溃。
2. 了解 JVM 内部原理和调优
Java 虚拟机(JVM)是运行 Java 程序的核心,它负责将字节码转换为可以在特定平台上运行的机器码。JVM 的内部工作原理以及性能调优是开发高效、稳定的 Java 应用的关键。
2.1 JVM 内部原理
JVM 主要由以下几个组件构成:
- 类加载器(Class Loader):负责加载 Java 类的字节码。
- 内存区域:
- 堆(Heap):用于存储所有的对象实例。
- 栈(Stack):用于存储方法调用及局部变量。
- 方法区(Method Area):用于存储类的元数据。
- 垃圾回收器(Garbage Collector):负责自动管理内存,回收不再使用的对象。
2.2 JVM 内存模型与垃圾回收
JVM 内存结构包括多个区域,每个区域都有不同的功能和目的。常见的垃圾回收算法包括 Serial GC、Parallel GC、CMS GC 和 G1 GC。不同的 GC 算法适用于不同的场景,选择合适的垃圾回收策略对于性能优化至关重要。
2.2.1 Java 堆内存与垃圾回收
Java 堆内存用于存储动态分配的对象。JVM 中的垃圾回收器通过追踪不再使用的对象并释放其占用的内存。
- 年轻代(Young Generation):存储新创建的对象。包含 Eden 区 和 Survivor 区。
- 老年代(Old Generation):存储长时间存活的对象。
- 永久代(PermGen) 或 元空间(Metaspace):存储类和方法的元数据。
2.2.2 常见垃圾回收算法
- Serial GC:适合小型应用,使用单线程进行垃圾回收。
- Parallel GC:适合多核处理器,使用多线程来回收垃圾。
- CMS GC(Concurrent Mark Sweep):适合需要低停顿时间的应用,回收过程中不会停止应用。
- G1 GC:适合大规模应用,提供更好的响应时间和吞吐量。
2.3 JVM 调优
JVM 调优通常涉及以下几个方面:
-
堆大小调整:
-Xms:设置初始堆大小。-Xmx:设置最大堆大小。
-
垃圾回收参数调整:
-XX:+UseG1GC:使用 G1 垃圾回收器。-XX:MaxGCPauseMillis=200:设置垃圾回收的最大停顿时间。
-
JVM 性能监控:
-Xlog:gc*:记录垃圾回收日志。- 使用
JVisualVM 或 JConsole 工具监控 JVM 性能。
2.3.1 调整堆大小
java -Xms512m -Xmx1024m -jar yourApp.jar
解释:
-Xms512m设置初始堆大小为 512MB。-Xmx1024m设置最大堆大小为 1024MB。
3. 总结
通过学习 Spring 框架与微服务架构 和 JVM 内部原理及调优,我们可以:
- 构建高效的企业级应用,利用 Spring 的依赖注入、AOP、Spring Boot 等特性简化开发。
- 实现可扩展的微服务架构,利用 Spring Cloud 轻松管理微服务的注册、发现、配置、负载均衡等。
- 优化 Java 应用性能,深入理解 JVM 内存模型和垃圾回收机制,通过合理的 JVM 调优策略提升应用性能和响应速度。
掌握这些知识,可以帮助你开发出更高效、可靠的应用程序,并在面对复杂的生产环境时,能够进行合理的性能调优和故障排查,提升应用的稳定性和可维护性。
相关文章:
Java旅程(五)Spring 框架与微服务架构 了解 JVM 内部原理和调优
在现代企业级应用中,Spring 框架和微服务架构已经成为主流技术,而 Java 虚拟机(JVM)的理解和调优对于保证应用的高性能和稳定性也至关重要。本篇博客将深入讲解 Spring 框架与微服务架构,并进一步探讨 JVM 内部原理和调…...
Niushop-master靶场漏洞
靶场搭建 将 niushop-master.zip 压缩包放到网站的根目录,解压后访问 浏览器访问 install.php ,根据提示安装即可 1.SQL注入漏洞 随便选择一种商品分类,发现有参数,测试注入 测试闭合发现页面报错有sql注入 应该是环境的问题&am…...
35道面向初中级前端的基础面试题
新鲜出炉的8月前端面试题 跨域资源共享 CORS 阮一峰 3. JSONP 是什么? 这是我认为写得比较通俗易懂的一篇文章jsonp原理详解——终于搞清楚jsonp是啥了。 4. 事件绑定的方式 嵌入dom 按钮 直接绑定 btn.onclick function(){} 事件监听 btn.addEventList…...
MFC用List Control 和Picture控件实现界面切换效果
添加List Control 和Picture控件 添加 3个子窗体 把子窗体边框设置为None, 样式设为Child 声明 CListCtrl m_listPageForm;void ShowForm(int nIndex);void CreatFormList();void CMFCApplication3Dlg::DoDataExchange(CDataExchange* pDX) {CDialogEx::DoDataExchange(pDX);DD…...
1. 解决前端vue项目 vite打包内存溢出问题
探索问题原因: 项目开发时正常运行不影响,打包出现上图错误,意味着打包过程中消耗了太多的内存导致的。 解决方法: 在 package.json中的打包命令替换如下: 解决前: "build:dev": "vite…...
Springboot高并发乐观锁
Spring Boot分布式锁的主要缺点包括但不限于以下几点: 性能开销:使用分布式锁通常涉及到网络通信,这会引入额外的延迟和性能开销。例如,当使用Redis或Zookeeper实现分布式锁时,每次获取或释放锁都需要与这些服务进行交…...
【WPS安装】WPS编译错误总结:WPS编译失败+仅编译成功ungrib等
WPS编译错误总结:WPS编译失败仅编译成功ungrib等 WPS编译过程问题1:WPS编译失败错误1:gfortran: error: unrecognized command-line option ‘-convert’; did you mean ‘-fconvert’?解决方案 问题2:WPS编译三个exe文件只出现u…...
pytorch MoE(专家混合网络)的简单实现。
专家混合(Mixture of Experts, MoE)是一种深度学习模型架构,通常用于处理大规模数据和复杂任务。它通过将输入分配给多个专家网络(即子模型),然后根据门控网络(gating network)的输出…...
虚拟机VMware的安装问题ip错误,虚拟网卡
要么没有虚拟网卡、有网卡远程连不上等 一般出现在win11 家庭版 1、是否IP错误 ip addr 2、 重置虚拟网卡 3、查看是否有虚拟网卡 4、如果以上检查都解决不了问题 如果你之前有vmware 后来卸载了,又重新安装,一般都会有问题 卸载重装vmware: 第一…...
Linux下基于最新稳定版ESP-IDF5.3.2开发esp32s3入门hello world输出【入门一】
开发环境搭建:Linux-Ubuntu下搭建ESP32的开发环境的步骤,使用乐鑫最新稳定版的esp-idf-CSDN博客 一、安装好开发环境后,在esp目录下再创建一个esp32的目录【用于编程测试demo】 二、进入esp32目录,打开终端【拷贝esp-idf的hello工…...
重温设计模式--命令模式
文章目录 命令模式的详细介绍C 代码示例C代码示例2 命令模式的详细介绍 定义与概念 命令模式属于行为型设计模式,它旨在将一个请求封装成一个对象,从而让你可以用不同的请求对客户端进行参数化,将请求的发送者和接收者解耦,并且能…...
电力通信规约-104实战
电力通信规约-104实战 概述 104规约在广泛应用于电力系统远动过程中,主要用来进行数据传输和转发,本文将结合实际开发实例来讲解104规约的真实使用情况。 实例讲解 因为个人技术栈是Java,所以本篇将采用Java实例来进行讲解。首先我们搭建一…...
什么是事务
在数据库管理系统中,事务(Transaction)是执行一系列操作的最小工作单元,这些操作要么全部成功,要么全部失败。为了确保数据的一致性和完整性,事务被设计为具备四大特性,即原子性(Ato…...
数据结构:双向循坏链表
目录 1.1双向循环链表的结构 2.双向链表功能的实现 2.1初始化链表 2.2销毁链表 2.3创建结点 2.4打印链表 2.5链表查找 2.6链表在pos的前面进行插入 2.7链表删除pos位置的节点 2.8链表的头插,头删 ,尾插,尾删 1.1双向循环链表的结构 …...
3.1、SDH的5种标准容器
1、定义与作用 在 SDH(同步数字体系)中,标准容器(C)是一种用来装载各种速率的 PDH(准同步数字系列)信号的信息结构。它的主要作用是进行速率适配,使不同速率的 PDH 信号能够在 SDH 的…...
Jenkins介绍
Jenkins 是一款流行的开源自动化服务器,在软件开发和持续集成 / 持续交付(CI/CD)流程中发挥着关键作用。 一、主要功能 1.持续集成(CI) (1).自动构建:Jenkins 可以配置为监听代码仓…...
5G学习笔记之Non-Public Network
目录 0. NPN系列 1. 概述 2. SNPN 2.1 SNPN概述 2.2 SNPN架构 2.3 SNPN部署 2.3.1 完全独立 2.3.2 共享PLMN基站 2.3.3 共享PLMN基站和PLMN频谱 3. PNI-NPN 3.1 PNI-NPN概述 3.2 PNI-NPN部署 3.2.1 UPF独立 3.2.2 完全共享 0. NPN系列 1. NPN概述 2. NPN R18 3. 【SNPN系列】S…...
网页生成鸿蒙App
如何网页生成鸿蒙App 纯鸿蒙发布后,鸿蒙App需求上升。如何快速生成鸿蒙App。变色龙云(http://www.appbsl.cn)推出了鸿蒙App打包服务。可以在线自动打包鸿蒙App。 第一步 创建应用 输入网站网址,上传图标。 第二步 生成鸿蒙证书 打开华为开发者管理中…...
JavaWeb通过Web查询数据库内容:(pfour_webquerymysql)
JavaWeb通过Web查询数据库内容: 数据库: 自行建库建表,主键 id 后端: 新建项目模块选择模块,添加依赖创建配置文件: db.propertiesJava类: query查询 前端: Web添加创建query.html…...
将java项目部署到linux
命令解析 Dockerfile: Dockerfile 是一个文本文件,包含了所有必要的指令来组装(build)一个 Docker 镜像。 docker build: 根据 Dockerfile 或标准指令来构建一个新的镜像。 docker save: 将本地镜像保存为一个 tar 文件。 docker load: 从…...
关于前端获取DOM节点的兼容IE6的代码封装
返回所有子元素节点的代码封装// 封装一个函数,这个函数可以返回元素的所有子元素节点(兼容到IE6),类似children的功能function getChildren(node){// 结果数组var children [];// 遍历node这个节点的所有子节点,判断每一个子节点的nodeType…...
屏幕水印革命:在代码里嵌入反扫描图腾
引言:测试安全的隐形护盾在软件测试领域,敏感数据泄露如同悬顶之剑——测试用例、缺陷报告、核心算法一旦被非法截屏传播,轻则导致知识产权流失,重则引发商业灾难。传统防护手段(如权限管控)在手机拍照、截…...
ONNX模型获取全攻略:从环境适配到质量验证的系统化方案
ONNX模型获取全攻略:从环境适配到质量验证的系统化方案 【免费下载链接】models A collection of pre-trained, state-of-the-art models in the ONNX format 项目地址: https://gitcode.com/gh_mirrors/model/models 模型获取是AI开发流程的关键起点&#…...
Debug神器:C语言assert断言的5个高效用法
C语言assert断言的5个高效调试技巧 调试是每个程序员日常工作中不可避免的环节,而assert断言就像一位沉默的代码卫士,能在关键时刻帮你揪出那些隐藏的bug。不同于普通的打印调试,assert提供了一种更系统化的验证机制,尤其适合处理…...
PowerShell自动化批量修改注册表路径:解决用户文件夹重命名后的遗留问题
1. 为什么需要批量修改注册表路径 最近帮同事处理了一个典型的Windows系统问题:他的用户文件夹最初使用了中文命名,导致各种开发工具和环境频繁报错。这个问题其实很常见,特别是当我们需要重命名用户文件夹时,虽然修改了系统路径&…...
颠覆叙事设计:用Arrow打造3类互动故事的零代码解决方案
颠覆叙事设计:用Arrow打造3类互动故事的零代码解决方案 【免费下载链接】Arrow Game Narrative Design Tool 项目地址: https://gitcode.com/gh_mirrors/arrow/Arrow 在游戏开发的黄金时代,叙事设计师们正面临着前所未有的创作困境:当…...
收藏 | 小白程序员必看:轻松入门RAG技术,让大模型拥有你的专业知识领域
收藏 | 小白程序员必看:轻松入门RAG技术,让大模型拥有你的专业知识领域 本文介绍了RAG(检索增强生成)技术,一种经济高效地解决大模型缺乏特定领域知识的方案。文章详细阐述了RAG的工作流程:用户请求→查询资…...
HR筛简历,第一眼先看什么?
HR筛简历,第一眼先看什么? 很多求职者投简历石沉大海,总觉得是自己能力不够,其实真相是:HR根本没看到你的亮点,就已经把你刷掉了。在海量简历面前,HR筛一份简历通常只需要6到15秒,第…...
优化问题存储格式对比:CBF vs MPS vs LP,哪种更适合你的场景?
优化问题存储格式深度对比:CBF、MPS与LP的技术选型指南 1. 优化问题存储格式的核心价值 在数学优化领域,数据存储格式的选择往往决定了工作流的效率和可扩展性。当处理包含混合整数变量、锥约束或大规模稀疏矩阵的复杂优化问题时,一个设计良好…...
Chat Bot 开发实战:从零构建高可用对话系统的核心技术与避坑指南
Chat Bot 开发实战:从零构建高可用对话系统的核心技术与避坑指南 在当今的数字化交互中,Chat Bot(聊天机器人)已成为连接用户与服务的关键桥梁。无论是客服咨询、智能助手还是娱乐互动,一个稳定、智能的对话系统都至关…...
