草庐IT

jvm调优

全部标签

JVM 解释和编译指南

Java是一种跨平台的编程语言。程序源代码会被编译为 字节码bytecode,然后字节码在运行时被转换为 机器码machinecode。解释器interpreter 在物理机器上模拟出的抽象计算机上执行字节码指令。即时just-in-time(JIT)编译发生在运行期,而 预先ahead-of-time(AOT)编译发生在构建期。本文将说明解释器、JIT和AOT分别何时起作用,以及如何在JIT和AOT之间权衡。源代码、字节码、机器码应用程序通常是由C、C++或Java等编程语言编写。用这些高级编程语言编写的指令集合称为源代码。源代码是人类可读的。要在目标机器上执行它,需要将源代码转换为机器可读

京东小程序接入ARVR的技术方案和性能调优

作者:京东零售戴旭京东小程序是一个开放技术平台,正在被越来越多的头部品牌选择,用于站内私域流量的营销和运营。诸如各种日化、奢侈品等品牌对ARVR有较多的诉求,希望京东小程序引擎提供一些底层能力,叠加品牌自主的个性化开发和定制,以支持更加丰富的场景和玩法,比如AR试妆、试戴等。我们小程序引擎联合ARVR团队,在双方产研测的努力和协作下,完成了相关能力的设计和开发。整体功能于京东APP11.6.6版本发布上线,期待为更多的商家和品牌赋能。体验路径和效果(负责相关模块的产品小姐姐友情录屏)技术方案这里以人脸识别为例,先介绍整体的技术方案。概念介绍技术关键词:相机、实时帧、AR算法、同层渲染、WebG

Flink实时任务性能调优

前言通常我们在开发完Flink任务提交运行后,需要对任务的参数进行一些调整,通常需要调整的情况是任务消费速度跟不上数据写入速度,从而导致实时任务出现反压、内存GC频繁(FullGC)频繁、内存溢出导致TaskManager被Kill。今天讲一下Flink任务中常见的性能场景及解决思路。反压在Flink任务中多个Task之间需要进行数据交换,在流式计算中数据的生产方的生产速度和消费方的消费速度不匹配时,可能会导致计算节点OOM或丢失数据,在Flink中通过反压机制平衡数据生产方和消费方的处理速度,以求系统达到整体的平衡。实时任务出现反压时,在Blink版本中做了大量的改进,从资源使用、作业调优、

一个java文件的JVM之旅

准备我是小C同学编写得一个java文件,如何实现我的功能呢?需要去JVM(JavaVirtualMachine)这个地方旅行。变身我高高兴兴的来到JVM,想要开始JVM之旅,它确说:“现在的我还不能进去,需要做一次转换,生成class文件才行”。为什么这样呢?JVM不能直接加载java文件的原因:Java源代码中包含了许多高级语言特性和语法,比如类、继承、多态、异常处理等等。这些高级特性在JVM中没有直接对应的形式,只有通过编译器的处理才能转化为JVM可以理解的字节码指令。Java源代码需要经过编译器的编译过程,才能生成相应的字节码文件,然后再由JVM加载、解释执行。在编译过程中,编译器对源代

线上JAVA应用平稳运行一段时间后出现JVM崩溃问题

一、问题是怎么发现的系统是一个定时任务系统,需要定时执行业务代码,业务代码主要是访问MYSQL数据库和缓存进行操作,该开始启动,系统日志一切正常,但是运行一段时间到凌晨后,系统就自动崩溃了,java进程没有了,只留下了程序崩溃日志如下:cat:/proc/1/environ:Permissiondenied[admin@host-11-40-38-52~]$morehs_err_pid231.log##AfatalerrorhasbeendetectedbytheJavaRuntimeEnvironment:##SIGSEGV(0xb)atpc=0x00007f21a8c21325,pid=2

JVM 内存结构详解,看这一篇就够了

本文主要对JVM内存结构进行讲解,注意不要和Java内存模型混淆了。内存结构是指Jvm运行时将数据分区域存储,强调对内存空间的划分。内存模型(JavaMemoryModel,简称JMM)是定义了线程和主内存之间的抽象关系,即JMM定义了JVM在计算机内存(RAM)中的工作方式,是虚拟机的内存管理模型,是一种虚拟机工程规范。运行时数据区内存是非常重要的系统资源,是硬盘和CPU的中间仓库及桥梁,承载着操作系统和应用程序的实时运行。JVM内存布局规定了Java在运行过程中内存申请、分配、管理的策略,保证了JVM的高效稳定运行。不同的JVM对于内存的划分方式和管理机制存在着部分差异。下图是JVM整体架

Prometheus监控JVM

1.部署说明JMXExporter的两种用法JMX-Exporter提供了两种用法:1.启动独立进程.JVM启动时指定参数,暴露JMX的RMI接口,JMX-Exporter调用RMI获取JVM运行时状态数据,转换为Prometheusmetrics格式,并暴露端口让Prometheus采集.2.JVM进程内启动.JVM启动时指定参数,通过javaagent的形式运行JMX-Exporter的jar包,进程内读取JVM运行时状态数据,转换为Prometheusmetrics格式,并暴露端口让Prometheus采集。官方不推荐使用第一种方式,一方面配置复杂,另一方面因为它需要一个单独的进程.本次

MySQL进阶之性能优化与调优技巧

数据库开发-MySQL1.多表查询1.1概述1.1.2介绍1.1.3分类1.2内连接1.3外连接1.4子查询1.4.1介绍1.4.2标量子查询1.4.3列子查询1.4.4行子查询1.4.5表子查询2.事务2.1介绍2.2操作2.3四大特性3.索引3.1介绍3.2结构3.3语法1.多表查询1.1概述1.1.2介绍多表查询:查询时从多张表中获取所需数据单表查询的SQL语句:select字段列表from表名;要执行多表查询,只需要使用逗号分隔多张表即可,如:select字段列表from表1,表2;查询用户表和部门表中的数据:select*fromtb_emp,tb_dept;此时,我们看到查询结果中

深入理解JVM内存模型

内存结构JVM内存结构主要包括以下几个部分:方法区(MethodArea):用于存储类的信息、常量、静态变量等。在JDK8及之前的版本中,方法区被实现为永久代(PermanentGeneration),而在JDK8之后的版本中,方法区被替换为元空间(Metaspace)。堆(Heap):用于存储对象实例。所有通过new关键字创建的对象都会被分配到堆中。堆是Java虚拟机管理的最大一块内存区域,也是垃圾回收的主要区域。栈(Stack):用于存储方法的局部变量、方法参数、返回值等。每个线程在执行方法时,都会创建一个对应的栈帧(StackFrame),栈帧中存储了方法的局部变量表、操作数栈、动态链接

腾讯面试复盘:数据库+数据结构+JVM+网络+JAVA+分布式+操作系统

腾讯面试复盘,总结了一下,面试总共是问了七个方面的问题(仅仅是个人面试经历,后台开发岗),包含:数据库、数据结构、JVM、网络、JAVA、分布式、操作系统等七个模块,下面就给大家介绍一下这七个方面的面试问题有哪些并且针对每一个模块还会分享一些我的学习笔记注意注意:需要下面分享的这七个模块的全部学习笔记的朋友可以评论区留言或是私信获取第一个模块:数据库1.1腾讯数据库面试问题解释ACID四大特性原子性的底层实现数据库宕机后恢复的过程如何保证事务的ACID特性MySQL日志类型这5个题目相对来说是比较普遍的,这里我就不一一给出答案了,给大家看下我的那个数据库学习笔记,这些题目在笔记里都是能找到的1