我注意到在 java中播放音频时,gc中的MarkSweepCompact阶段太长并导致短暂的静音,这是不可接受的.所以我需要使用低暂停gc.我尝试过Parallel和CMS,它们似乎工作得更好,因为我认为暂停时间更短,并且它们不会像默认那样经常完全收集.

到目前为止,我已经使用ParallelGC的以下选项测试了我的程序:

-XX:+UseParallelGC 
-XX:MaxGCPauseMillis=70

对于ConcurrentMarkSweep:

-XX:+UseConcmarkSweepGC
-XX:+CMSIncrementalMode
-XX:+CMSIncrementalPacing

我也尝试过G1GC,但它仍然在java 6中实验性.两种模式的选项:

-xms15m
-Xmx40m
-XX:+UnlockExperimentalVMOptions
-XX:+CMSClassUnloadingEnabled
-XX:+TieredCompilation
-XX:+AggressiveOpts
-XX:+UseAdaptiveSizePolicy
-Dsun.java2d.noddraw=false
-Dswing.aatext=true
-XX:MaxPermSize=25m
-XX:MaxHeapFreeRatio=10
-XX:MinHeapFreeRatio=10

哪种GC在这种情况下更好?是否可以针对最佳cpu性能和最小内存使用量对这些设置进行优化?

编辑为了识别暂停,我记录了将音频数据写入输出线的时间,通常在92到120毫秒之间(我正在写16384字节= ~92毫秒),广告在运行全GC时,它是200毫秒:

65.424: [Full GC (System) [PSYoungGen: 872K->0K(2432K)] [PSOldGen: 12475K->12905K(16960K)] 13348K->12905K(19392K) [PSPermGen: 15051K->15051K(22272K)],0.2145081 secs] [Times: user=0.20 sys=0.00,real=0.21 secs] 
Was writing 16384 bytes,time to write 263 ms

EDIT2我的应用程序的分配模式如下:它在启动时加载一堆对象,然后它开始播放,我猜之后的大多数对象都由gui分配,因为凝视/暂停音频不会改变GC图形许多.这是visualgc与并行gc一起显示的内容:

图表在启动时开始,我开始播放.标记是

1)声音延迟和完整的gc,我认为它增加了旧尺寸:

101.646: [Full GC [PSYoungGen: 64K->0K(6848K)] [PSOldGen: 15792K->12773K(19328K)] 15856K->12773K(26176K) [PSPermGen: 15042K->14898K(23808K)],0.2411479 secs] [Times: user=0.19 sys=0.00,real=0.24 secs]

2)我打开应用程序窗口并暂停播放.什么都没有改变,稍后它增加了伊甸园的大小.

3)我打开窗口再次开始播放.

所以我需要增加分配的旧Gen大小?我怎么做?我正在使用-XX:NewRatio = 10和-XX:NewSize = 10m

谢谢.

解决方法

你提供的日志太小,无法提供真实的分析,但它表示,由于旧的基本上已经满了,它花了200毫秒做v.这意味着您的堆太小或您有内存泄漏.在这种情况下,您无法调整GC算法.因此,本回复的其余部分是关于如何从应用程序中获取更多信息和/或如何在消除内存泄漏或具有更大堆时调整GC.

在很大程度上,低暂停意味着尽一切可能将集合保留为年轻集合.

您确实需要在开始和完成写入时准确记录,然后将其与在此期间发生在JVM中的STW暂停相关联,否则您实际上不知道可能导致问题的原因或问题的严重程度.

我马上做的事情;

>更改日志记录,以便输出可由脚本轻松解析的单行(可能是starttime,endtime,duration)
>添加PrintGCApplicationStoppedTime和PrintGCApplicationConcurrentTime开关,以便获得每个STW暂停的记录,而不仅仅是GC事件
>使用最新的JVM(即6u23),因为在过去的一两年里,热点已经有很多改进,所以有一点使用较旧的
>你没有说你是否受到内存限制但是如果可以的话我肯定会增加堆大小,40M非常小,所以你没有足够的空间来玩
>运行连接visualgc的应用程序,它可以更全面地了解IMO的内容,因为您一次可以查看所有不同的视图

关键是确定你的空间不足以及原因.答案可能在于你的应用程序的分配模式是什么样的,它是否会产生一堆短暂的物体,这样你就可以很快地烧掉你的小伊甸园?暂停阈值太高,以至于你无论如何都要通过幸存者空间ping对象,从而迫使频繁的终身gcs(慢)?

还有一些要记住的事情……

> iCMS(增量版)适用于1或2台核心机器,是否描述了您的机器?你有多少核心?你可能只是想放弃那个选项
> CMS确实有单线程阶段(初始标记),这可能会伤害到你
> CMS通常比其他收藏家更喜欢堆,你的收藏家相当小

在visualgc图表添加到问题后编辑
由于你的内存受限,那么你需要充分利用你拥有的空间,唯一的方法就是通过重复的基准测试…理想情况下可重复测试.

>你可以使用-Xmn指定设置年轻代的大小,剩余部分将给予终身.
>你可能想要调整你对幸存者空间的使用,这样你就可以让它们在被交换之前变得更饱满,并让对象在它们终身之前存活更长时间

> -XX:TargetSurvivorRatio = 90设置它,因此幸存者空间在复制之前需要90%已满,显然这里需要在复制和使用空间的成本之间进行权衡
>使用-XX:PrintTenuringdistribution来显示每个空间的大小以及事物的方式,你也可以在visualgc中看到这个
>使用-XX:MaxTenuringThreshold来指定一个对象在年终集合(从1个幸存者空间复制到另一个幸存者空间)之前能够存活多少次,例如,如果你知道你只是得到了短暂的垃圾或永远存在的东西,那么把它设置为1是明智的

>您需要了解触发终身收藏的内容,并考虑采取措施以便稍后触发

>对于CMS,这可能涉及调整-XX:CMSInitiatingOccupancyFraction =< value>,设置为80,它将触发CMS 80%的终身入住率(注意:这是一个坏事,所以你可能更喜欢让热点管理这个;设置太小,它收集过于频繁的杀戮性能,设置它太大,它可能触发得太晚导致计划外的完整收集,相应的长暂停时间

>如果它真的是旧的收藏品会伤害你,你需要低停顿然后使用CMS和ParNew

最后得到一个分析器并找出垃圾来自哪里,您可能会发现更容易控制垃圾产生的速度,然后将力量投入到可以进行GC调节的黑洞中!

调整GC用于Java音频应用程序的更多相关文章

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. js中‘!.’是什么意思

  3. InnoDB 和 MyISAM 引擎恢复数据库,使用 .frm、.ibd文件恢复数据库

  4. Error: Cannot find module ‘node:util‘问题解决

    控制台 安装 Vue-Cli 最后一步出现 Error: Cannot find module 'node:util' 问题解决方案1.问题C:\Windows\System32>cnpm install -g @vue/cli@4.0.3internal/modules/cjs/loader.js:638 throw err; &nbs

  5. yarn的安装和使用(全网最详细)

    一、yarn的简介:Yarn是facebook发布的一款取代npm的包管理工具。二、yarn的特点:速度超快。Yarn 缓存了每个下载过的包,所以再次使用时无需重复下载。 同时利用并行下载以最大化资源利用率,因此安装速度更快。超级安全。在执行代码之前,Yarn 会通过算法校验每个安装包的完整性。超级可靠。使用详细、简洁的锁文件格式和明确的安装算法,Yarn 能够保证在不同系统上无差异的工作。三、y

  6. 前端环境 本机可切换node多版本 问题源头是node使用的高版本

    前言投降投降 重头再来 重装环境 也就分分钟的事 偏要折腾 这下好了1天了 还没折腾出来问题的源头是node 使用的高版本 方案那就用 本机可切换多版本最终问题是因为nodejs的版本太高,导致的node-sass不兼容问题,我的node是v16.14.0的版本,项目中用了"node-sass": "^4.7.2"版本,无法匹配当前的node版本根据文章的提

  7. 宝塔Linux的FTP连接不上的解决方法

    宝塔Linux的FTP连接不上的解决方法常见的几个可能,建议先排查。1.注意内网IP和外网IP2.检查ftp服务是否启动 (面板首页即可看到)3.检查防火墙20端口 ftp 21端口及被动端口39000 - 40000是否放行 (如是腾讯云/阿里云等还需检查安全组)4.是否主动/被动模式都不能连接5.新建一个用户看是否能连接6.修改ftp配置文件 将ForcePassiveIP前面的#去掉 将19

  8. 扩展element-ui el-upload组件,实现复制粘贴上传图片文件,带图片预览功能

  9. 微信小程序canvas实现水平、垂直居中效果

    这篇文章主要介绍了小程序中canvas实现水平、垂直居中效果,本文图文实例代码相结合给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

  10. 使用HTML5做的导航条详细步骤

    这篇文章主要介绍了用HTML5做的导航条详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部