`

64位多核x86服务器的企业级Java缩放(优化JVM)

 
阅读更多
多核心和64位CPU是在企业服务器市场上这几天最热门的商品。近年来,由于增加的成本和更快的CPU时钟速度的功率要求,在单CPU的原始时钟速度增长(通常是衡量兆赫)放缓。硬件制造商继续提高基于X86的服务器的性能,提高多任务处理能力和内部数据带宽。英特尔和超微出货内部有两个CPU内核的64位处理器,四核心处理器是很快跟进。从戴尔第九代服务器利用这种新一代芯片。例如,PowerEdge 1955刀片服务器,最多支持两个64位双核心处理器在刀片配置,7机架单元(12.25“)机箱等十刀片。

然而,这些新世代的服务器软件也构成新的挑战。比如,采取多核心CPU的优势,软件应用程序必须能够并行地执行任务,整个CPU的,采取的64位内存带宽的优势,应用程序还必须能够管理大量有效的内存。作为企业级服务器上的关键软件平台,Java企业版(Java EE)是在这个多核心,64位革命的最前沿。 Java EE开发人员必须适应这些挑战,使硬件投资最。

当Java第一次是在1997年,国家的最先进的电脑与小于300MHz的时钟速度和小于64MB的RAM单CPU。第一个Java应用程序大多是在客户端上。高性能的多任务和大容量内存处理显然不是当时Java的设计者优先。但是,作为Java服务器端应用程序成为被广泛采用,事情开始发生变化。 Web应用程序本质上是多线程的,因为每个Web请求可以在一个单独的线程来处理,并行到其他请求。最新的Java平台,大大提高现代服务器硬件上的性能。

在这篇文章中,我们期待在企业Java的当前状态,分析面临的挑战与新一代服务器。根据我们的经验,戴尔可扩展企业技术中心的JBoss应用服务器上运行的Java EE应用的工作​​,我们提供最新的服务器硬件扩展的Java EE应用程序的解决方案和技巧。
调整JVM

Java平台的核心是Java虚拟机(JVM)。整个Java应用服务器运行在一个JVM。 JVM的许多启动参数以命令行标志,他们中的一些应用程序的性能有很大的影响。所以,让我们来看看一些重要的服务器应用程序的JVM参数。

首先,你应该尽可能的JVM使用的-,XMS <SIZE>(最小内存)和-Xmx <SIZE>标志(最大内存)分配尽可能多的内存。例如,-Xms1g Xmx1g标签分配给JVM 1GB的RAM。在JVM启动的标志,如果你不指定内存大小,JVM将限制在堆内存64MB(Linux上的512MB),无论你在服务器上有多少物理内存!更多的内存,允许应用程序来处理更多的并发Web会话,缓存更多的数据,以提高缓慢的I / O和数据库操作。我们通常指定为标志相同数量的内存,强制服务器使用所有分配的内存从启动。通过这种方式,JVM不会需要动态改变堆的大小在运行时,这是一个JVM中不稳定的首要原因。对于64位服务器,请确保您的64位JVM上运行64位操作系统的服务器上所有的RAM的优势之上。否则,JVM只能够使用2GB或更少的内存空间。 64位JVM通常只适用于JDK 5.0中。

有了一个大的堆内存,垃圾收集(GC)操作可能会成为一个主要的性能瓶颈。这可能需要超过10秒的GC通过多个千兆字节堆扫。在JDK 1.3和早期版本中,GC是一个单线程操作,这在JVM停止所有其他任务。这不仅会导致长期和不可预知的应用程序中的暂停,但它也多CPU计算机上的表现很差的结果,因为其他所有的CPU必须等待在闲置,而一个CPU运行在100%释放堆内存空间。这是至关重要的,我们选择了JDK 1.4 + JVM的支持并行和并发GC操作。其实,在JDK 1.4 JVM的一系列并发GC实施还不是很稳定。因此,我们强烈建议您升级到JDK 5.0。使用命令行标志,你可以选择从以下两个GC算法。它们都是多CPU计算机优化。

    如果你的首要任务是增加总吞吐量的应用,你可以容忍偶尔GC暂停,你应该使用-XX:UseParallelGC和第XX:UseParallelOldGC(后者仅仅是JDK 5.0中可用)标志打开并行GC。并行GC使用所有可用的CPU来执行GC操作,因此,它是速度远远高于默认的单个线程的GC。它仍然暂停在GC在JVM中的所有其他活动,但。

    如果您需要,以最大限度地减少GC暂停,你可以使用-XX:+ UseConcMarkSweepGC标志打开并发GC。并发GC仍然暂停JVM使用并行GC清理短命的对象。然而,清理使用一个后台线程并行运行的其他JVM线程堆起来长寿命的对象。并发GC大大减少GC暂停,但管理后台线程并添加到系统的开销,降低了总吞吐量。

此外,还有一些JVM参数,你可以调整优化GC操作。

    在64位系统,为每个线程的调用栈分配1MB的内存空间。大多数线程不使用那么多的空间。使用-XX:ThreadStackSize = 256K标志,可以减少堆栈大小为256K,让更多的线程。

    使用-XX:+ DisableExplicitGC标志忽略明确的应用程序调用System.gc()的。如果应用程序经常调用此方法,那么我们可以做很多不必要的地方选区。

    -XMN <SIZE>标志可以让你手动设置“年轻一代”短命对象内存空间的大小。如果您的应用程序产生大量新的对象,你可能会提高地方选区的显着增加这个值。 “年轻一代”的大小几乎从未超过50%的堆。

由于GC对性能有很大的影响,JVM提供几个标志,以帮助您进行微调,为特定的服务器和应用程序的GC算法。这超出了本文的范围,讨论GC算法和调整详细的提示,但我们想指出,在JDK 5.0 JVM GC微调称为人体工程学的自适应功能。它可以自动优化GC算法基于底层硬件,应用程序本身,而由用户指定(例如,最大暂停时间和所需的吞吐量)的预期目标的参数。这可以节省您的时间,自己尝试不同的GC参数组合。人体工程学是尚未升级到JDK 5.0中的另一个令人信服的理由。有兴趣的读者可以参考调整5.0 Java虚拟机的垃圾收集。如果GC算法是错误配置,这是比较容易发现的问题,在您的应用程序的测试阶段。在后面的章节中,我们将讨论几种方法来诊断JVM中的GC问题。

最后,确保你服务器标志的JVM启动。它优化了Just-In-时间(JIT)编译器来换取更快的运行性能较慢的启动时间。有更多的JVM标志我们还没有讨论这些细节,请检查JVM选项文档页面。
使用新的平台API

除了JVM,Java平台库也经历了广泛的变化,以适应新的服务器硬件。我们强烈建议您升级您的应用程序到JDK 5.0 +,以便采取所有内置到平台的性能增强优势。三个新的库API的最后两个主要版本的JDK中引入多CPU计算机的特殊重要性。

    JDK 5.0中的并发工具库,多线程应用程序是非常重要的。它简化了Java线程API,并提供了一​​个收集实现线程安全的集合。例如,新ConcurrentHashMap是线程安全的HashMap,你可以读/写没有一个synchronized块。在本文稍后的更多细节,我们会得到这个。

    在JDK 1.4中引入的NIO(新I / O)库。它允许多个线程到硬盘或网络共享一个物理连接(例如,插座)。一个线程不再需要阻止I / O插座,读取或写入数据。使用NIO,我们可以大大减少线程一个阻塞的套接字数量有限所造成的等待时间。 NIO的是有用的,尤其是在多CPU计算机的CPU往往等待的I / O,那里有许多线程。

    在JDK 1.4中引入的日志库提供了一个方便的API来从应用程序的信息记录到控制台,日志文件,或网络目的地。日志库的重要性能特点是,你可以通过改变在运行时通过配置文件的日志记录级别配置日志输出。这有助于我们减少记录 - 其中包括减缓I / O操作,并等待CPU的重要原因 - 在运行时无需重新编译应用程序代码,。

你应该写新的应用和升级旧的应用程序使用并发,NIO的,日志记录API尽可能。如果你不能升级,你应该使用替代的开源库,提供类似的功能。例如,Doug Lea的util.concurrent库有许多相同的功能,作为JDK 5.0中的并发API;此外,Apache的Log4j的库是在JDK 1.4 +日志库相媲美。
分享到:
评论

相关推荐

    ASP.NET某中学图书馆系统的设计与实现(源代码+论文).zip

    ASP.NET是一种基于.NET框架的服务器端编程模型,用于构建高性能、易于维护的Web应用程序。在这个中学图书馆系统的案例中,开发者利用ASP.NET的技术栈设计并实现了这样一个功能丰富的平台,旨在为中学生、教师以及图书馆管理员提供方便的信息管理和检索服务。下面我们将深入探讨这个系统的核心知识点。 1. **ASP.NET架构**:ASP.NET提供了多种开发模式,如Web Forms、MVC、Web API和Blazor。本系统可能采用了Web Forms或MVC架构,这两种模式都支持事件驱动和模型-视图-控制器(MVC)设计原则,便于创建动态网页和处理用户交互。 2. **数据库设计**:图书馆系统通常需要管理书籍信息、借阅记录、用户账户等数据,因此数据库设计是关键。可能使用了SQL Server或MySQL等关系型数据库,通过ADO.NET或Entity Framework进行数据访问,实现CRUD(创建、读取、更新、删除)操作。 3. **身份验证与授权**:为了确保系统安全,。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    图书管理系统(基于ASP .NET)

    《图书管理系统(基于ASP .NET)》是一款专为学习者设计的应用程序,旨在提供一个全面的图书管理平台。系统的设计采用ASP .NET技术,这是一款由微软开发的用于构建动态网站、web应用和web服务的强大工具。ASP .NET框架以其高效、安全和易于维护的特点,深受开发者的喜爱。 该系统包含了多个核心模块,这些模块覆盖了图书管理的主要功能。有图书录入模块,它允许管理员录入图书的基本信息,如书名、作者、出版社、ISBN号、分类等。图书查询模块提供给用户方便快捷的搜索功能,用户可以根据书名、作者、关键词等条件进行检索。此外,借阅与归还模块确保图书的流通管理,记录图书的借阅状态,提醒用户按时归还,并处理超期罚款等事务。 系统还具备用户管理模块,允许用户注册、登录、修改个人信息。对于权限管理,后台有专门的管理员角色,他们可以对用户进行操作,如分配权限、冻结或解冻账户。同时,系统的统计分析模块能够生成各类报表,如图书借阅量、热门书籍、用户活跃度等,这些数据对于图书馆运营决策有着重要参考价值。 在。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    思维导图制作-会计初级知识重难点-会计务实-会计基础

    本专刊的主要目的是帮助初学者系统化和结构化地掌握会计知识。我们采用思维导图的形式,将复杂的会计概念和流程进行有效的简化,旨在让学习者能够更清晰地理解这些内容,并增强记忆效果。通过视觉化的方式,读者不仅能够感受到会计知识的关联性,还能轻松掌握关键点,提升学习效率。无论是在学习新知识还是复习旧知识时,这种方法都能够为学习者提供极大的便利和帮助。

    精选毕设项目-todolist,带简易后端.zip

    精选毕设项目-todolist,带简易后端

    精选毕设项目-美食菜谱.zip

    精选毕设项目-美食菜谱

    精选毕设项目-地图定位.zip

    精选毕设项目-地图定位

    精选毕设项目-学富网家教电商平台.zip

    精选毕设项目-学富网家教电商平台

    精选毕设项目-乐租租房工具.zip

    精选毕设项目-乐租租房工具

    chromedriver-linux64_123.0.6296.0.zip

    chromedriver-linux64_123.0.6296.0

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建 附参考资料

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建。 附参考资料

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15)

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者。 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15) 2、FactoryIO 2.4.0 内容清单: 1、FactoryIO中文说明书+场景模型文件 2、博图V15PLC程序(源码)。

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    基于STM32的智能家居控制系统.zip

    STM32使用技巧,实战应用开发小系统参考资料,源码参考。经测试可运行。 详细介绍了一些STM32框架的各种功能和模块,以及如何使用STM32进行应用开发等。 适用于初学者和有经验的开发者,能够帮助你快速上手STM32并掌握其高级特性。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    基于数据驱动进化算法的风电场布局优化研究与应用

    内容概要:本文提出了一种数据驱动进化算法(ADE-GRNN)来优化风电场布局,旨在最大化风电场功率输出并减少计算时间。文中引入了自适应差分演化算法和通用回归神经网络来训练数据驱动模型,通过快速过滤低效候选解来提高求解效率。同时详细描述了风力发电机组的位置排布对功率产生成关键影响的因素如湍流效应以及不同算法(ADE、JADE、CLPSO)间的性能对比实验结果。研究表明,在多个评估指标方面,所提出的 ADE-GRNN 方法均表现出显著优势。 适合人群:对于希望深入理解智能算法在工程实践中特别是新能源领域的应用的研发人员和技术爱好者非常适合。 使用场景及目标:用于需要高效能解决复杂组合最优化问题的企业或项目组,特别是在涉及大规模风电场布局规划时的目标定位是提升能源转换率,降低成本消耗,提高运算速度。 其他说明:未来的研究可以进一步考虑更为复杂的风电场拓扑结构及更精确地模拟尾流效应,并探索三维空间下最优布局的可能性;此外还可以尝试不同的机器学习方法来稳定代理模型的表现。

    电流计算方法:.docx

    电流计算方法:.docx

    精选毕设项目-茶叶商城(含后端).zip

    精选毕设项目-茶叶商城(含后端)

    精选毕设项目-化妆品商城.zip

    精选毕设项目-化妆品商城

    chromedriver-linux64_123.0.6286.0.zip

    chromedriver-linux64_123.0.6286.0

    智慧图书管理系统设计与实现-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip

    Spring Boot是Spring框架的一个模块,它简化了基于Spring应用程序的创建和部署过程。Spring Boot提供了快速启动Spring应用程序的能力,通过自动配置、微服务支持和独立运行的特性,使得开发者能够专注于业务逻辑,而不是配置细节。Spring Boot的核心思想是约定优于配置,它通过自动配置机制,根据项目中添加的依赖自动配置Spring应用。这大大减少了配置文件的编写,提高了开发效率。Spring Boot还支持嵌入式服务器,如Tomcat、Jetty和Undertow,使得开发者无需部署WAR文件到外部服务器即可运行Spring应用。 Java是一种广泛使用的高级编程语言,由Sun Microsystems公司(现为Oracle公司的一部分)在1995年首次发布。Java以其“编写一次,到处运行”(WORA)的特性而闻名,这一特性得益于Java虚拟机(JVM)的使用,它允许Java程序在任何安装了相应JVM的平台上运行,而无需重新编译。Java语言设计之初就是为了跨平台,同时具备面向对象、并发、安全和健壮性等特点。 Java语言广泛应用于企业级应用、移动应用、桌面应用、游戏开发、云计算和物联网等领域。它的语法结构清晰,易于学习和使用,同时提供了丰富的API库,支持多种编程范式,包括面向对象、命令式、函数式和并发编程。Java的强类型系统和自动内存管理减少了程序错误和内存泄漏的风险。随着Java的不断更新和发展,它已经成为一个成熟的生态系统,拥有庞大的开发者社区和持续的技术创新。Java 8引入了Lambda表达式,进一步简化了并发编程和函数式编程的实现。Java 9及以后的版本继续在模块化、性能和安全性方面进行改进,确保Java语言能够适应不断变化的技术需求和市场趋势。 MySQL是一个关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)来管理和存储数据。MySQL由瑞典MySQL AB公司开发,并于2008年被Sun Microsystems收购,随后在2010年,Oracle公司收购了Sun Microsystems,从而获得了MySQL的所有权。MySQL以其高性能、可靠性和易用性而闻名,它提供了多种特性来满足不同规模应用程序的需求。作为一个开源解决方案,MySQL拥有一个活跃的社区,不断为其发展和改进做出贡献。它的多线程功能允许同时处理多个查询,而其优化器则可以高效地执行复杂的查询操作。 随着互联网和Web应用的快速发展,MySQL已成为许多开发者和公司的首选数据库之一。它的可扩展性和灵活性使其能够处理从小规模应用到大规模企业级应用的各种需求。通过各种存储引擎,MySQL能够适应不同的数据存储和检索需求,从而为用户提供了高度的定制性和性能优化的可能性。

    (螳螂voc数据)农作物病虫害识别目标检测数据集,VOC格式,螳螂数据集,纯手动标注,用来进行目标检测代码训练的数据

    (螳螂voc数据)农作物病虫害识别目标检测数据集,VOC格式,螳螂数据集,纯手动标注,用来进行目标检测代码训练的数据。

Global site tag (gtag.js) - Google Analytics