JVM 简介

JVM 组成

JVM包含两个子系统和和两个组件,连个子系统为类装载(Class Loader)和执行引擎(Execution engine);两个组件为运行时数据区(Runtime data area),本地接口(Native Interface)。
类装载(Class Loader):根据给定的全限定名类名(如:java.lang.Object)来装载class 文件到 运行时数据区(Runtime data area )中的方法区(method area)
执行引擎(Execution engine):执行classes 中的指令。
本地接口(Native Interface) :与native libraries 交互,是其他编程语言交互的接口。
运行时数区域(Runtime data arae):这就是我们常说的JVM 内存

在这里插入图片描述

JVM 作用

首先通过编译器把java代码转换成字节码,类加载(Classloader)器再把字节码加载到内存中,将其放在运行时数据区(Runtime data area)的方法区(method area)内,而字节码文件只是JVM的一套指令集规范,并不能直接交给底层操作系统去执行,因此需要特定的命令解析器执行引擎(Execution Engine),将字节码翻译成底层系统指令,再交由cpu 去执行,而这个过程中需要调用其他语言的本地库接口(Native Interface) 来实现整个过程

java 程序运行机制的详细说明

1.首先利用IDE集成开发工具编写java源代码,源文件的后缀为:【.java】
2.再利用编译器(javac命令)将源代码编译成字节码文件,字节码文件的后缀为:【.class】
3.运行字节码的工作是由解释器(java命令来执行)
在这里插入图片描述

从上图可以看到。java文件通过编译器变成了class文件,接下来类加载器又将这些class文件加载到JVM中
总结:类的加载指的是将类的class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆中创建一个java.lang.Class对象来封装类在方法区的数据结构。

JVM运行时数据区

java 虚拟机在执行java程序的过程中会把它管理的内存区域划分成若干个不同的数据区域,这些区域都有各自的用途,以及创建和销毁的时间,有些区域随着虚拟机进程单位启动而存在,有些区域则是依赖线程的启动和结束而建立和销毁。java 虚拟机所管理的内存被划分为如下几个区域
在这里插入图片描述
不同虚拟机的运行时数据区可能会略微有所不同,但都会遵从java 虚拟机规范,java虚拟机规范规定的区域分为以下五部分:
程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器,字节码解析器的工作是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、跳转,异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
java 虚拟机栈(Java Virtual Machine Stacks):用于存储局部变量表,操作数栈,动态链接,方法的出口等信息。
本地方法栈(Native Method Stack):与虚拟机栈的作用是一样的,只不过虚拟机栈是服务java方法的,而本地方法栈是为虚拟机调用native方法服务的。
java推(java Heap):java 虚拟机中内存中内存最大的一块,是被所有线程共享的,几乎所有的对象实例都在这里分配内存,
方法区(Method area):用于存储已经被虚拟机加载的类信息,常量,静态变量,即时编译后的代码等数据。

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当涉及到Nginx和JVM的调优时,我们可以从两个方面来讨论。 首先是Nginx的调优。Nginx是一个高性能的Web服务器和反向代理服务器,以下是一些常见的Nginx调优方法: 1. 调整worker_processes和worker_connections:根据服务器的硬件配置和负载情况,适当调整worker_processes(工作进程数)和worker_connections(每个工作进程的最大连接数)参数,以提高并发处理能力。 2. 启用gzip压缩:开启gzip压缩可以减小传输的数据量,提高网站的响应速度。 3. 调整缓冲区大小:通过调整proxy_buffer_size、proxy_buffers和proxy_busy_buffers_size等参数,可以优化Nginx对后端服务器的请求和响应的缓冲区管理,提高性能。 4. 使用缓存:使用Nginx的缓存功能可以减轻后端服务器的负载,提高响应速度。可以通过配置proxy_cache和相关参数来启用缓存。 5. 负载均衡:通过配置upstream模块,可以实现Nginx的负载均衡功能,将请求分发到多个后端服务器上,提高系统的可用性和性能。 接下来是JVM的调优。JVMJava虚拟机的缩写,以下是一些常见的JVM调优方法: 1. 调整堆内存大小:通过调整-Xms和-Xmx参数,可以设置JVM的初始堆大小和最大堆大小,以适应应用程序的内存需求。 2. 设置垃圾回收器:根据应用程序的特点和性能需求,选择合适的垃圾回收器,如Serial GC、Parallel GC、CMS GC或G1 GC,并通过相关参数进行配置。 3. 调整线程数:通过调整-Xss参数,可以设置线程栈的大小,以及通过调整-XX:ParallelGCThreads参数来设置并行垃圾回收线程数,以提高并发处理能力。 4. 监控和分析工具:使用JVM提供的监控和分析工具,如jstat、jconsole、jvisualvm等,可以实时监控JVM的运行状态和性能指标,帮助定位性能瓶颈和优化机会。 5. 代码优化:通过对代码进行优化,如减少对象的创建、避免过多的同步、合理使用缓存等,可以减少JVM的负载,提高性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值