改善Java性能的基本建议

简介: 改善Java性能的基本建议 Document #: 2811085C29001 Body: [标题]下面是在AIX上改善 Java 性能的基本建议· 当进行过多的字符串操作以避免不必要地创建那些最终必须经历垃圾收集的对象时,可使用 StringBuffer 功能而不是字符串并置。

改善Java性能的基本建议

Document #: 2811085C29001

Body:

[标题]

下面是在AIX上改善 Java 性能的基本建议

· 当进行过多的字符串操作以避免不必要地创建那些最终必须经历垃圾收集的对象时,可使用 StringBuffer 功能而不是字符串并置。
· 避免连续写入 Java 控制台以减少字符串操作、文本格式化以及输出的花费。
· 必要时通过使用变量的原语类型来避免对象创建和操作的花费。
· 对常用对象进行高速缓存,以减少必须的垃圾收集量,并避免重新创建对象的需要。
· 尽可能分组本地操作以减少 Java 本地接口(JNI)的调用。
· 仅当在 JVM 和操作系统中必须限制多任务时才使用同步方法。
· 除非必要避免调用垃圾回收器。如果您必须调用它,只有在空闲时间或一些非关键阶段再这样做。
· 尽可能使用整型而不是长整型,因为 32 位操作的执行快于 64 位操作。
· 尽可能声明方法为 final。JVM 可较好地处理 final 方法。
· 在创建常量以减少需要初始化变量的次数时请使用关键字 static final。
· 避免不必要的“casts”和“instanceof”引用,因为 Java 中的数据类型转换是在运行时完成的。
· 当数组可以满足要求时尽可能避免使用向量。
· 把项添加到向量尾部或从向量尾部删除项。
· 使用 -O 选项编译 Java 文件。
· 避免在循环中分配对象。
· 使用缓冲区 I/O 并调整缓冲区大小。
· 使用连接池和准备缓存声明进行数据库访问。
· 使用连接池连接到数据库并重用连接而不是重复打开和关闭连接。
· 最大化和最小化线程创建和销毁周期。
· 最小化共享资源的争用。
· 最小化短生命周期对象的创建。
· 避免远程方法调用。
· 使用回调以避免阻塞远程方法调用。
· 避免创建仅用于访问方法的对象。
· 保持同步方法处于循环外。
· 在数据库中以 Unicode 形式存储字符串和字符数据。
· 对 CLASSPATH 重新排序使得最常用的库先出现。


AIX 的 Java 调优


以下参数是适用于您的 JAVA 环境的推荐 AIX 设置:
AIXTHREAD_SCOPE=S
该变量的缺省值为 P,表示进程级的争用作用域(M:N)。对于 Java 应用程序,您应该设置这个值为 S,它表示系统级争用作用域(1:1)。
AIXTHREAD_MUTEX_DEBUG=OFF
用调试器为使用目的维持一个活动人工干预列表。
AIXTHERAD_COND_DEBUG=OFF
用调试器为使用目的维持一个条件变量列表。
AIXTHREAD_RWLOCK_DEBUG=OFF
维护由调试器使用的活动互斥锁、条件变量和读写锁的列表。当初始化某个锁时,如果列表中没有这个锁,它就加入到该列表中。此列表以链表形式实现,因此当列表变大时通过搜索它来确定锁是否存在就暗含了性能问题。问题是此列表由锁保护的事实复合而成的,这个锁在搜索操作过程中一直持有。对 pthread_mutex_init() 子例程的其它调用必须等待,直到搜索完成为止。为获得最佳性能,应该将此线程调试选项的值设置为 OFF。它们的缺省值为 ON。
SPINLOOPTIME=500
一个进程在阻塞之前可以在繁忙锁上自旋的次数。这个值缺省设置为 40。如果 tprof 命令输出表明 check_lock 例程的 CPU 使用率很高,并且如果锁通常在短时间内可用,则您应该通过将值设置为 500 或更高来延长自旋时间。
同样,为您的 Java 环境推荐以下设置:
ulimit -d 不限制
ulimit -m 不限制
ulimit -n 不限制
ulimit -s 不限制
操作系统内一定的环境参数和设置可以用来调优 Java 性能。此外,还有许多调优系统(如 CPU、内存、网络、I/O 等等)的技术可以提高 Java 的性能。
为获得尽可能好的 Java 性能和可伸缩性,请使用操作系统和 Java,以及即时(JIT)编译器的最新可用版本。

目录
相关文章
|
20天前
|
缓存 算法 Java
Java 实现的局域网管控软件的性能调优
局域网管控软件在企业网络管理中至关重要,但随着网络规模扩大和功能需求增加,其性能可能受影响。文章分析了数据处理效率低下、网络通信延迟和资源占用过高等性能瓶颈,并提出了使用缓存、优化算法、NIO库及合理管理线程池等调优措施,最终通过性能测试验证了优化效果,显著提升了软件性能。
30 1
|
3月前
|
Kubernetes Cloud Native Java
云原生之旅:从容器到微服务的演进之路Java 内存管理:垃圾收集器与性能调优
【8月更文挑战第30天】在数字化时代的浪潮中,企业如何乘风破浪?云原生技术提供了一个强有力的桨。本文将带你从容器技术的基石出发,探索微服务架构的奥秘,最终实现在云端自由翱翔的梦想。我们将一起见证代码如何转化为业务的翅膀,让你的应用在云海中高飞。
|
3月前
|
存储 监控 Java
Java多线程优化:提高线程池性能的技巧与实践
Java多线程优化:提高线程池性能的技巧与实践
107 1
|
11天前
|
Java 数据库连接 数据库
优化之路:Java连接池技术助力数据库性能飞跃
在Java应用开发中,数据库操作常成为性能瓶颈。频繁的数据库连接建立和断开增加了系统开销,导致性能下降。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接,显著减少连接开销,提升系统性能。文章详细介绍了连接池的优势、选择标准、使用方法及优化策略,帮助开发者实现数据库性能的飞跃。
20 4
|
9天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
13 1
|
16天前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
16 2
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
375 37
|
1月前
|
缓存 Java 数据库连接
使用 NCache 将 Java 微服务扩展到极致性能
使用 NCache 将 Java 微服务扩展到极致性能
26 8
|
2月前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
2月前
|
监控 算法 Java
深入理解Java中的垃圾回收机制在Java编程中,垃圾回收(Garbage Collection, GC)是一个核心概念,它自动管理内存,帮助开发者避免内存泄漏和溢出问题。本文将探讨Java中的垃圾回收机制,包括其基本原理、不同类型的垃圾收集器以及如何调优垃圾回收性能。通过深入浅出的方式,让读者对Java的垃圾回收有一个全面的认识。
本文详细介绍了Java中的垃圾回收机制,从基本原理到不同类型垃圾收集器的工作原理,再到实际调优策略。通过通俗易懂的语言和条理清晰的解释,帮助读者更好地理解和应用Java的垃圾回收技术,从而编写出更高效、稳定的Java应用程序。
下一篇
无影云桌面