转:http://www.importnew.com/3151.html
这是“成为Java GC专家系列文章”的第四篇。
在第一篇文章 成为JavaGC专家Part I — 深入浅出Java垃圾回收机制 中我们学习了不同GC算法的执行过程,GC如何工作,新生代及老年代的基本概念,在JDK7中你应该了解的5种GC类型以及他们的性能如何。
在第二篇文章 成为JavaGC专家Part II — 如何监控Java垃圾回收机制 中我们学到了JVM到底是如何执行垃圾回收,我们如何监控GC,以及那些工具可以使得监控过程更高效。
在第三篇文章 成为Java GC专家系列Part III–如何优化Java垃圾回收机制中我们通过实际的例子学到了一些可以优化GC的参数。同时我们讲解了如何减少对象被转移到老年代空间,如何缩短Full GC时间,以及如何设置GC类型及内存空间。
在第四篇文章中,我们将阐述Apache中MaxClients
参数的重要性,以及他如何在GC发生时,显著地影响整个系统的性能。我将提供几个例子以方便你理解MaxClients
导致的问题。同时我还会说明如何根据系统的内存情况,设置最佳的MaxClients
参数值。
MaxClients对于系统的影响
NHN (译者注:NHN是作者工作的公司)服务的执行环境中存在一组Throttle valve-type参数(译者注:节流阀参数,用于控制系统负载)。这些参数对于系统来说十分重要。下面我们看一下Apache的 MaxClients
参数在Full GC 发生时是如何影响系统的。
大部分开发人员都知道在由于GC发生而导致的”停止世界现象(STW) “(详细请参见Understanding Java Garbage Collection)。尤其是,NHN的Java开发人员经常会遇到由于GC原因导致的Tomcat报错。由于Java 虚拟机 (JVM)管理着内存,以Java为基础的程序无法摆脱GC导致的STW现象。假如在某一个时间,当你正在操作你开发的应用时,GC开始执行。即使TTS错误没有发生,你的服务也会给客户展现未预期的503错误。
服务执行环境
由于架构本身的特点,相比较而言纵向扩展,Web服务更适合横向扩展(译者注:增加服务器的数量,而不是提高件配置)。因此,总体来讲,物理设备会 根据性能要求被配置成1台Apache+n台Tomcat。但是本文假设我们的环境是1台Apache+一台Tomcat同时安装在一台主机行,如下图所 示。
图1:本文假射的服务执行环境
仅供参考,本文描述的参数基于Apache 2.2.21 (prefork MPM),Tomcat 6.0.35,CentOS 4.72 (32-bit),jdk 1.6.0_24。
系统可用内存2GB,垃圾收集器使用ParallelOldGC,AdaptiveSizePolicy采用默认的设置true,堆内存空间600M
STW 和HTTP 503
让我们假设访问Apache的请求为 200 req/s且有10个httpd进程在运行,另外我们暂时不考虑每个请求的响应时间。在这种前提下,我们假设由于full GC导致的暂停时间为1秒。当Full GC发生的时候Tomcat会怎样?
第一件进入你脑海的事情应该是Tomcat会因为full GC而停止响应任何请求。在这种情况下,当Tomcat暂停相应请求时Apache会发生什么?
当Tomcat暂停时,请求会以200 req/s的速度不断的涌入Apache。一般来说,在Full GC发生之前,请求的响应可以快速地被10个或更多的httpd进程处理掉。但是,因为Tomcat暂停了,httpd进程会被不停地创建以相应新进请求。直到超过httpd.conf 文件中定义 MaxClients
为止。由于默认值为256,Apache不会在乎请求以200 req/s的速度涌入。
这时,新创建的httpd线程将如何呢?
Httpd进程通过mod_jk 模块所管理的空闲的AJP连接,将请求转发给Tomcat。如果没有空闲连接,他会申请创建新的连接。但是,因为Tomcat暂停了,创建新连接的请求会被拒绝。因此这些请求会被存储在backlog队列中,数量的多少取决于server.xml中关于AJP Connector的设置。一旦请求数量超过backlog队列的空间限制。Apache就会返回拒绝连接错误。并且返回HTTP 503 错误给用户。
在这种假设条件下,默认的backlog队列空间是100,而请求到达速度是200 req/s。因此,full GC导致的一秒钟的暂停会使得超过100个请求返回503错误。
这样,当Full GC结束后,backlog队列中存储的内容会被Tomcat接受并在通过工作线程处理,线程的最大数量取决于MaxThreads
的值(默认200)。
MaxClients 与backlog
在这种情况下,设定哪个参数可以避免返回给用户503错误呢?
首先,我们应该知道backlog的值要够大,以至于能够容纳所有因为Full GC导致暂停期间涌入的请求。换句话说太应该不小于200。
那么,这么设置之后会不会产生新的问题呢?
让我们假设将backlog设置为200后再重复一下上面的过程。得到的结果比之前更加严重。系统内存使用量一般情况下为50%,但是,在发生 Full GC时快速增加到100%,同时导致交换内存空间快速增加,更为严重的是导致Full GC的暂停时间从1秒变成了4秒甚至更多,系统在此期间完全宕机,不能响应任何请求。
在第一种情况下,只有100或更多的请求返回503错误。但是,当我们把backlog调整到200后,超过500个请求会挂起3秒甚至更多地时间无法得到应答
上面这个例子可以很好的说明当你没有完全理解各个设置之间的内在关系时(例如,对于系统的影响),盲目修改系统会导致什么后果。
那么,为什么会产生这个现象呢?
问题的根源在于 MaxClients
参数的特性。
将MaxClients
设置为一个很大的值本身没有问题,但最重要的是在设定MaxClients
参数时,你要确保即使等同于MaxClients
数量的httpd进程被同时创建,内存使用量也不会超过80%。
系统的内存交换参数一般被设定为60(默认)。因此,当内存使用量超过80%时,就会进行内存交换。
让我们再来看一下为什么这个特性会导致上面那个严重的问题。当请求以200 req/s的速度涌向Tomcat时,Tomcat由于full GC暂停了。此时backlog被设置为200。Apache大约创建100个httpd进程。在这种情况下,一旦内存使用量超过80%,操作系统会激活 交换内存区域,并且由于系统认为JVM的老年代中的对象在很长一段时间内未被使用,而将他们移动到交换区域。
最终的结果是,GC使用了内存交换空间,暂停时间剧增。因此httpd进程数进一步增加。从而导致上面描述的内存使用量达到100%的情况。
这两个场合的唯一区别就是backlog的值:100 vs.200。为什么只在200的情况下发生?
两者不同的原因在于创建的httpd进程的数量。当backlog设置为100时并且Full GC发生时,会创建100个请求的连接并保存在backlog队列中。其他请求得到拒绝连接错误信息并发挥503错误。因此,总的httpd 进程数量仅仅会略高于100。而当backlog被设置为200时,200个请求会创建连接,因此。总的httpd进程数会多于200。这样超过阀值,从 而导致内存交换的发生。紧接着,不考虑内存使用量而的设定 MaxClients
参数,Full GC导致httpd进程数量暴增,引发内存交换,降低系统性能。
如上所述,我们将内存设为700m后MaxClients
应该是多少呢?
这要取决于加载模块的数量,对于NHN Web服务来说。Apache只是个简单的代理转发,每个httpd线程4m内存(根据top命令的结果)足以(参见图2)。因此。700m内存对应的 MaxClients
应该是175。
总结
一个健壮的服务配置至少应该能够降低在服务过载时宕机的时间,在合理的范围内成功的应答请求。针对基于Java的Web服务。你必须检查你的服务在Full GC导致的STW时间内能否稳定的响应请求。
为了响应更多的用户请求和应对DDoS攻击,在没有全面考虑系统内存等因素的情况下,贸然地将 MaxClients
设置为一个很大的值,那么它将失去作为阀值的功能,而导致系统出现更严重的问题。
本文提到的情况只会持续3-5秒,因此绝大多数传统的监控工具都无法及时的发现。
作者 Dongsoon Choi 高级工程师@Game Service Technical Support Team, NHN Corporation.
译文地址: http://www.importnew.com/3151.html
【如需转载,请在正文中标注并保留原文链接、译文链接和译者等信息,谢谢合作!】
相关推荐
1、理解Java垃圾回收; 2、Java垃圾回收的监控; 3、GC 调优; 4、Apache的MaxClients设置及其对Tomcat Full GC的影响; 5、Java应用性能优化的原则
Notes 我的笔记: 知识不总结,就会被大脑当垃圾清理 :horse:求知之路必然不会...Apache的MaxClients参数详解及其在Tomcat执行FullGC时的影响 JavaEE 浅析Web容器 计算机网络 UDP&TCP DB MySQL索引背后的数据结构
内容概要:本文详细介绍了如何利用三菱FX3G/FX3S PLC通过485接口控制四台E700变频器的方法。首先,文章讲解了硬件连接的具体步骤,包括485BD扩展板的安装以及变频器之间的线路连接方式。接着,深入探讨了变频器参数的设定,确保各设备能够正确通信。然后,重点阐述了PLC程序的设计,包括MOV指令的应用、CRC校验的实现以及RS指令的使用。此外,还涉及了触摸屏的配置方法,使用户可以通过触摸屏进行频率设定和状态监控。最后,提供了常见问题的解决方案,如超时时间设置不当、CRC校验错误等。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些熟悉三菱PLC和变频器操作的人群。 使用场景及目标:适用于需要通过PLC控制多个变频器的工业应用场景,旨在提高系统的响应速度和稳定性,降低开发成本。具体目标包括掌握485接口的硬件连接、参数设置、PLC编程技巧以及故障排查方法。 其他说明:文中提供的方案不仅限于三菱品牌,其他支持Modbus RTU协议的变频器也可以参照此方案进行配置。
最新版kibana-9.0.0-windows-x86_64.zip
内容概要:本文详细介绍了基于STM32的PID温控系统的设计与实现,涵盖硬件选型、PID算法实现、温度传感器驱动、PWM驱动控制以及LCD显示等多个方面。系统采用STM32F103C8T6作为主控芯片,通过PID算法实现精确的温度控制,利用PWM驱动半导体制冷片实现加热和制冷的双向控制。文中提供了详细的代码示例,包括PID初始化、温度采集、PWM输出控制、LCD显示刷新等功能模块。此外,还讨论了常见的调试问题及解决方法,如积分限幅、温度传感器滤波、H桥驱动保护等。 适合人群:具有一定嵌入式开发基础的研发人员,特别是对PID控制算法和温控系统感兴趣的工程师。 使用场景及目标:适用于需要高精度温度控制的应用场合,如实验室设备、工业自动化控制系统等。目标是帮助读者掌握PID温控系统的原理和实现方法,能够独立搭建和调试类似的温控系统。 其他说明:文中提供的Proteus仿真文件可以帮助初学者更好地理解和验证系统的工作原理。完整的工程代码和仿真文件可以在评论区获取。
2303040222橡胶232熊文栋(苯乙烯悬浮聚合)副本.pdf
内容概要:本文详细介绍了如何使用MATLAB及其工具包yalmp和cplex实现含冰蓄冷空调的冷热电联供型微网(CCHP-MG)多时间尺度优化调度模型。主要内容涵盖日前计划和日内调度两大部分,前者通过多场景描述应对可再生能源的不确定性,后者提出双层滚动优化模型以适应冷热负荷变化。文中不仅展示了具体的MATLAB代码实现细节,如场景生成、优化模型构建以及求解方法,还讨论了一些调试过程中遇到的问题及解决方案。 适合人群:从事能源管理和电力系统优化的研究人员和技术人员,尤其是对MATLAB有一定基础并关注冷热电联供系统的从业者。 使用场景及目标:适用于希望深入了解CCHP-MG系统优化调度原理的人群,旨在帮助他们掌握如何利用MATLAB进行此类系统的建模与优化,从而提高能源利用率、降低运营成本。 其他说明:文章强调了冰蓄冷空调在CCHP-MG系统中的重要作用,指出其能够有效协调冷热电之间的关系,同时通过实例演示了如何处理实际运行中的不确定性和复杂性。此外,作者还分享了一些实用的经验教训,如场景削减技术和求解器设置优化等。
nRF-Connect Android源码,开发ble手机app必备
JDBC的Jar包
基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计,个人经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做大作业的学生和需要项目实战练习的学习者,可作为毕业设计、课程设计、期末大作业,代码资料完整,下载可用。 基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设计基于Python的天气预测和天气可视化项目(源码+文档说明)高分毕业设
内容概要:本文详细介绍了如何利用MATLAB将预训练的深度学习模型(如ResNet50、YOLOv2和LaneNet)转化为高效的C++代码,并部署到嵌入式系统中。首先,通过ResNet50展示了图像分类任务的代码生成流程,强调了输入图像的预处理和归一化步骤。接着,YOLOv2用于车辆检测,讨论了anchor box的可视化及其优化方法,特别是在Jetson Nano平台上实现了显著的速度提升。最后,LaneNet应用于车道线识别,探讨了实例分割和聚类算法的实现细节,以及如何通过OpenMP和CUDA进行性能优化。文中还提供了多个实用技巧,如选择合适的编译器版本、处理自定义层和支持动态输入等。 适合人群:具有一定MATLAB和深度学习基础的研发人员,尤其是关注嵌入式系统和高性能计算的应用开发者。 使用场景及目标:适用于希望将深度学习模型高效部署到嵌入式设备的研究人员和工程师。主要目标是提高模型推理速度、降低内存占用,并确保代码的可移植性和易维护性。 其他说明:文中不仅提供了详细的代码示例和技术细节,还分享了许多实践经验,帮助读者避免常见的陷阱。此外,还提到了一些高级优化技巧,如SIMD指令集应用和内存管理策略,进一步提升了生成代码的性能。
内容概要:本文详细介绍了利用MATLAB实现CT成像仿真的全过程,特别是滤波反投影(FBP)算法的具体实现。首先,通过radon函数生成投影信号,接着进行傅立叶变换将投影数据映射到频域,在频域中应用Ram-Lak滤波器进行滤波,然后通过逆傅立叶变换回到时域,最后使用iradon函数完成反投影重建。文中不仅提供了完整的代码实现,还分享了许多实用的经验和注意事项,如补零操作、滤波器选择以及插值方法的影响等。 适合人群:从事医学影像处理的研究人员和技术爱好者,尤其是有一定MATLAB基础并希望深入了解CT成像原理的人群。 使用场景及目标:适用于想要深入理解CT成像原理及其具体实现方式的学习者。通过亲手实践,能够更好地掌握滤波反投影算法的工作机制,提高解决实际问题的能力。 其他说明:作者强调了传统FBP算法的重要性,并鼓励读者尝试不同的参数配置以获得更好的重建效果。此外,还提到了未来可以探索的方向,比如使用GPU加速反投影过程。
内容概要:本文详细介绍了ESC(电子稳定控制系统)的标定开发流程,涵盖标定前准备、参数调整实战、验证测试等多个方面。首先,标定前需要搭建控制器与上位机的连接,如编写Python CAN通讯工具。接着,在参数调整过程中,涉及到具体参数的选择与调整,如横摆角速度阈值、滑移率补偿等,并且需要注意数据溢出等问题。验证测试部分则强调了使用MATLAB进行离线数据分析以及处理实车数据中的异常值。此外,文章还讲述了标定工程师在不同环境下的实际工作经验,如极端天气下的标定挑战,以及如何通过调整PID控制器参数来优化车辆表现。最后,文章指出标定工作的终极目标是在确保安全的同时提升驾驶体验。 适合人群:从事汽车电控系统开发的技术人员,尤其是对标定工程师日常工作感兴趣的读者。 使用场景及目标:适用于希望深入了解ESC标定全过程的专业人士,旨在帮助他们掌握从理论到实践的具体方法和技术要点。 其他说明:文中不仅提供了具体的代码示例,还分享了许多宝贵的实际操作经验和教训,对于提高标定效率和准确性具有重要指导意义。
一、环境准备 操作系统 CentOS 7/8 或 Ubuntu 20.04 LTS(推荐)16 确保网络配置正确(IP、网关、DNS)6 关闭SELinux和防火墙(临时关闭命令:setenforce 0,systemctl stop firewalld)8 依赖环境 数据库:MySQL/MariaDB(版本需适配Zabbix)13 Web服务器:Apache/Nginx(需支持PHP)17 PHP版本:≥7.2(建议安装php-gd、php-mysqlnd等扩展)17 硬件要求:2核CPU、4GB内存、20GB磁盘1 二、安装步骤(以CentOS 7为例) 1. 安装Zabbix Server bash Copy Code # 安装YUM源及依赖 rpm -Uvh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-1.el7.noarch.rpm yum install -y zabbix-server-mysql zabbix-web-mysql zabbix-agent mariadb-server:ml-citation{ref="7,8" data="citationList"} 2. 配置数据库 bash Copy Code # 启动数据库并创建Zabbix用户 systemctl start mariadb && systemctl enable mariadb mysql -e "CREATE DATABASE zabbix CHARACTER SET utf8 COLLATE utf8_bin" mysql -e "GRANT ALL ON zabbix.* TO 'zabbix'@'localhost' IDENTIFIED BY 'zabb
内容概要:本文档是《星闪创为_XSCW6000模组使用手册》,版本为Rev1.1,由北京星闪创为科技有限公司发布。手册详细介绍了XSCW6000模组的法律声明、安全须知、模块选型、产品综述、应用接口、射频特性、电气性能和可靠性、机械尺寸以及生产及包装信息等内容。XSCW6000模组是一款支持5G ISM频段、80MHz带宽、SLB协议1.0版本的高性能无线通信模组,适用于大带宽音视频业务、网络游戏、智慧家庭、智慧工厂、体育场、演唱会、网络直播、应急等多种场景。手册还提供了详细的引脚分布、电源设计、天线设计要点及射频性能参数,确保用户能够正确使用和集成该模组。 适合人群:从事无线通信模块开发的技术人员、硬件工程师及相关领域的研发人员。 使用场景及目标:①帮助用户了解XSCW6000模组的基础特性、功能框图、引脚分布等信息;②指导用户完成正确的电源设计、天线选择及射频性能优化;③确保用户在实际应用中遵循安全使用规范,保障产品稳定性和可靠性。 其他说明:此手册为受控版本,版权归属于星闪创为,未经许可不得复制或传播。手册内容会根据实际情况进行更新,建议用户定期查阅最新版本。星闪创为提供技术支持与服务,如有疑问可通过指定联系方式咨询。
内容概要:本文详细介绍了利用MATLAB和YALMIP工具包实现两阶段鲁棒优化问题的Benders分解方法。主要内容涵盖主问题和子问题的建模、割平面的生成逻辑以及算法的迭代过程。文中通过具体的代码实例解释了如何定义变量、约束条件、目标函数,并展示了如何通过不断的迭代使上下界逐渐收敛,从而找到最优解。同时,文章还讨论了一些常见的实现细节和潜在的陷阱,如对偶变量的提取、不确定性集合的设计、初始割的添加等。 适合人群:具有一定MATLAB编程基础并希望深入了解优化算法的研究人员和技术爱好者。 使用场景及目标:适用于解决带有不确定性的优化问题,尤其是涉及到资源分配、生产计划等领域的问题。通过学习本文,读者可以掌握Benders分解的基本原理及其在MATLAB环境下的具体实现方法。 其他说明:文章提供了完整的代码示例,并附有详细的注释帮助理解每个步骤的作用。此外,作者还分享了许多实用的小技巧来提高算法效率和稳定性,如采用稀疏矩阵存储、动态调整收敛阈值等。
内容概要:本文深入探讨了在微网环境中,利用改进的二进制粒子群算法(IBPSO)解决含需求响应的机组组合问题。研究背景指出,随着能源结构的变化,微网系统日益重要,而需求响应(DR)的引入为提高微网运行效率提供了新思路。文中详细介绍了机组组合的基本模型及其扩展模型,后者将需求响应纳入考虑范围。接着,重点讲解了改进二进制粒子群算法的具体实现步骤,包括粒子位置和速度的更新规则。此外,还展示了基于MATLAB和CPLEX/Gurobi平台的仿真实验结果,验证了改进算法的有效性。最终,通过详细的代码注释和丰富的可视化工具,使得整个研究过程更加透明易懂。 适合人群:从事电力系统优化、微网管理及相关领域研究的专业人士和技术爱好者。 使用场景及目标:适用于需要优化微网系统运行效率的实际工程应用,特别是在处理大规模机组组合问题时,能够显著降低成本并提高系统稳定性。目标是帮助研究人员理解和掌握改进二进制粒子群算法的应用技巧,促进需求响应机制在电力系统中的广泛应用。 其他说明:本文不仅提供了完整的MATLAB代码实现,还包括详尽的理论推导和实验数据分析,有助于读者全面理解该课题的技术细节。同时,附带的可视化模块可以帮助用户更好地解读求解结果,便于进一步优化和调整参数。
内容概要:本文详细介绍了使用LTspice进行LDO(低压差线性稳压器)及其相关模拟集成电路的电源设计与分析方法。首先,文章讲解了如何利用AC分析评估环路稳定性和相位裕度,确保系统的稳定性。接着,探讨了电源抑制比(PSRR)的测试方法,通过加入交流扰动源来测量输出端的衰减情况。此外,还讨论了负载瞬态响应测试,通过施加脉冲电流源来观察输出电压的变化。文中提供了具体的SPICE代码示例,如AC分析、PSRR测试和瞬态负载测试的代码片段,并强调了库文件的使用和注意事项。最后,分享了一些实用技巧,如保存常用测试电路为模板、调整元件参数以提高仿真精度等。 适合人群:电子工程专业学生、模拟电路设计师以及对LDO设计感兴趣的工程师。 使用场景及目标:① 学习如何使用LTspice进行LDO电路的稳定性分析;② 掌握电源抑制比(PSRR)的测试方法;③ 进行负载瞬态响应测试,优化补偿网络设计。 其他说明:本文不仅提供理论指导,还附带具体的操作步骤和代码示例,使读者能够快速上手并深入理解LDO设计的关键技术和常见问题。
内容概要:本文详细介绍了如何使用C++、Qt和OpenCV构建一个车牌识别系统。首先,通过颜色空间转换和边缘检测进行车牌定位,利用HSV颜色空间和形态学操作去除噪声并找到候选区域。接着,采用SVM和支持向量机进行字符识别,提取HOG特征并训练模型。字符切割则使用垂直投影法处理粘连字符。数据库方面,使用Qt的SQL模块将识别结果保存到SQLite或MySQL数据库中。视频流处理通过Qt的QMediaPlayer和QVideoProbe实现,确保系统的实时性和稳定性。为了提高性能,引入了多线程处理,分离图像处理和界面刷新任务。 适合人群:具有一定C++编程基础,熟悉Qt和OpenCV库的开发者,尤其是对图像处理和机器学习感兴趣的工程师。 使用场景及目标:适用于需要开发车牌识别系统的应用场景,如停车场管理、交通监控等。主要目标是帮助开发者理解和实现车牌识别的关键技术和优化方法。 其他说明:文中提供了详细的代码片段和技术细节,强调了传统方法与机器学习相结合的优势,并分享了一些实战经验和常见问题的解决方案。