平时项目中有时遇到cpu过高的情况,在此基于自己有限的经验写个分享,此处的服务器都是基于linux平台。

cpu的占有线程类型总的来说分为两种:

us :用户空间占用CPU百分比

sy :内核空间占用CPU百分比

在linux下可以通过top命令查看详细,示例如下:

一般来讲CPU us高的解决方法:

CPU us 高的原因主要是执行线程不需要任何挂起动作,且一直执行,导致CPU 没有机会去调度执行其他的线程。

CPU sy高的解决方法:

CPU sy 高的原因主要是线程的运行状态要经常切换,对于这种情况,常见的一种优化方法是减少线程数。

我平时具体的步骤如下:1.得到线程最高的几个id(ps-process state)

ps-eLo pid,lwp,pcpu | grep 15285|sort -nk 3

2.导出JAVA线程栈信息

命令:kill-3[PID] 或者 jstack3.从栈信息中找到线程数多的几个

命令:sort 文件名| uniq -c | sort -nk 1

4.分别分析线程数最多的前十个线程和线程占用cpu最高的前10个线程

这步是最关键的,找出这些异常点,比如某个业务功能点占用较高的cpu或者某种类型的线程数量比较多,这个和业务以及具体程序紧密关联的,在此就不多说了。5.分析占用cpu最高的前10个线程,结果示例如下:0x1a5:gc线程"Concurrent Mark-Sweep GC Thread#0" prio=1 tid=0x0000002b29df1400 nid=0x1a5runnable0x35f:memcache线程"memcache5-CacheThread" prio=1 tid=0x0000002b3d277de0 nid=0x35f runnable [0x0000000042755000..0x0000000042755c30]0x35e:memcache线程"memcache1-CacheThread" prio=1 tid=0x0000002b371212f0 nid=0x35e runnable [0x0000000042654000..0x0000000042654cb0]0x14e9:RMI线程"RMI TCP Connection(102)-10.23.241.59" daemon prio=1 tid=0x0000002b37e72790 nid=0x14e9 runnable [0x000000005103c000..0x000000005103deb0]0x1be:memcache线程"memcache5-CacheThread" prio=1 tid=0x0000002b3dba4790 nid=0x1be runnable [0x0000000041a48000..0x0000000041a48eb0]0x1bd:memcache线程"memcache1-CacheThread" prio=1 tid=0x0000002b3fb70340 nid=0x1bd runnable [0x0000000041947000..0x0000000041947b30]0x1af:jdk编译线程"CompilerThread1" daemon prio=1 tid=0x0000002b30e11620 nid=0x1af waiting on condition [0x0000000000000000..0x000000004123f7c0]0x1ae:jdk编译线程"CompilerThread0" daemon prio=1 tid=0x0000002b30e10280 nid=0x1ae waiting on condition [0x0000000000000000..0x000000004113e440]0x1684:http请求线程,通过该线程栈可以看到此处调用的是hibernate查询"http-8080-Processor123" daemon prio=1 tid=0x0000002b37dfd9d0 nid=0x1684 runnable [0x000000005afd7000..0x000000005afdcd30]--------------------------------------------------------------------------------------------------------------------------------

6.系统优化

如果找出了哪些功能点占用cpu高,接下来就需要优化了,可以从业务和技术手段两方面来进行,平时工作中比较常用的技术手段:

弹性时间:对高使用率的请求,分散到不同的时间,比如采用队列或异步,减少同一时间处理的请求。

批处理或定时任务:把请求组合成批,这样可以使得时间真真的都有效的用在了处理上,而不是网络传输等准备工作上。(减少网络传输、数据库连接、socket连接)

缓存:将结果缓存起来,空间换时间。--------------------------------------------------------------------------------------------------------------------------------

7.如果是gc线程比较费时,则需要进一步的定位:

首先查看一下gc策略是否合理,然后用命令jmap-F -dump:live,file=jmap.hprof [PID] 导出内存dump文件,我一般每隔5s导一次,一共导出3次。用Eclipse Memory Analyzer分析导出来的文件,分析是哪个类占用内存比较多,分析出可能存在内存泄露的地方。

注意jvm分配内存时一个大对象的分配比多个小对象的分配效率要低,如果对象比较大,进行拆分能提高效率,具体原因如下:

Java对象所占用的内存主要从堆上进行分配,堆是所有线程共享的,因此在堆上分配内存时需要进行加锁,这导致了创建对象开销比较大。当堆上空间不足时,会触发GC,如果GC后空间仍然不足,则抛出OutOfMemory错误信息。Sun JDK为了提升内存分配的效率,会为每个新创建的线程在新生代的Eden Space上分配一块独立的空间,这块空间称为TLAB(Thread Local Allocation Buffer),其大小由JVM根据运行情况计算而得,可通过-XX:TLABWasteTargetPercent来设置TLAB可占用的Eden Space的百分比,默认值为1%。JVM将根据这个比率、线程数量及线程是否频繁分配对象来给每个线程分配合适大小的TLAB空间 。在TLAB上分配内存时不需要加锁,因此JVM在给线程中的对象分配内存时会尽量在TLAB上分配,如果对象过大或TLAB空间已用完,则仍然在堆上进行分配,因此在编写Java程序时,通常多个小的对象比大的对象分配起来更加高效。

java web对cpu要求_java web服务器cpu占用过高 (转载)相关推荐

  1. linux服务器怎么查看cpu配置信息,linux服务器cpu信息查看详解

    在linux系统中,提供了/proc目录下文件,显示系统的软硬件信息.如果想了解系统中CPU的提供商和相关配置信息,则可以查/proc/cpuinfo.但是此文件输出项较多,不易理解.例如我们想获取, ...

  2. 服务器淘汰cpu组装的电脑,服务器CPU该不该买?

    [前言]在撕逼鱼和某宝上有大量的商家卖服务器CPU主机配置,也经常有小白拿服务器CPU配置来问老哥好不好的问题,今天老哥这篇文章将告诉你服务器CPU到底该不该买?且听老哥分析. [概念]服务器CPU顾 ...

  3. 无盘服务器内存问题,无盘服务器内存占用过高

    无盘服务器内存占用过高 内容精选 换一换 Windows操作系统云服务器蓝屏,如图1所示.使用了来源不明的第三方软件.CPU占用过高导致.因为误操作或者病毒引起的系统文件.注册表损坏.操作系统在蓝屏的 ...

  4. 服务器内存占用太高如何解决及知识点介绍

    背景 服务器内存占用太高 查看内存 free -m 查看服务器内存使用情况,-m的意思是内存显示单位是mb top 查看服务器所有进程占用内存,为了查看方便,可以使用 shift+md可以让进程按照内 ...

  5. java web学什么软件_java web开发是什么?该怎么学习?

    Java中有前端这个开发方向,上回我们说到了javaweb是什么?你们应该对javaweb有了一定的了解了,那你们知道该如何学习web吗?小编这里整理了一些相关知识,快来看看吧. 一.javaweb是 ...

  6. java web初级面试题_Java Web应用程序初学者教程

    java web初级面试题 Java Web Application is used to create dynamic websites. Java provides support for web ...

  7. java项目使用过滤器实例_Java web开发--过滤器篇(详细介绍)

    一. web过滤器的介绍 1.过滤器 在生活中,过滤这种我们时常可见:比如水资源的处理,化学药剂的提取等等.所谓过滤,就是指对某事物的处理进行一定的处理获取相应的结果的一个过程.它可以总结为下: 过滤 ...

  8. java目前开发的背景_Java web 开发构想[一] 背景和形势

    [Java web 开发构想系列 转自JavaEye社区,在此申明] 1.背景.形势 能够进行Web开发的编程语言和技术很多 (1) 动态解释语言 PHP; Perl; Python (Zope, P ...

  9. 服务器cpu型号各个数字,服务器cpu型号 数字

    服务器cpu型号 数字 内容精选 换一换 接口名称GetCloudPhoneServerModelsGetCloudPhoneServerModels功能描述查询云手机服务器的规格列表.查询云手机服务 ...

  10. 2018主流服务器cpu,【热门服务器CPU排行榜】2021热门服务器CPU排名_热门服务器CPU排行榜10强-太平洋产品报价...

    TOP 1 Intel Xeon E5-2689 八核 核心数量 2.6GHz 主频 暂无评分 暂无报价 这款Intel Xeon E5-2689是一款性能很稳定的服务器CPU,能够积极响应服务请求并 ...

最新文章

  1. 主成分分析(PCA):通过图像可视化深入理解
  2. 如何把选择屏幕放到标准屏幕上
  3. jbpm 和 drools_jBPM和Drools工作台中的用户和组管理
  4. Coinbase在上市前选择在Reddit线上路演
  5. 3027 - Corporative Network
  6. Java泛型之类型擦除
  7. 基于C语言+sqlite3的FTP爬虫和搜索引擎系统
  8. 地理信息系统概论 - 地理信息系统(1)
  9. 为什么计算机不显示桌面工具栏,笔记本电脑开机后不显示桌面图标或任务栏怎么解决...
  10. 触宝发布2018年第四季度财报 净收入增长147%
  11. auto.js B0012 进入各频道 查找父控件 子控件 2021-10-03
  12. Java十六:Scanner,配合hasNext()/hasNextInt()/hasNextFloat()....实现人机互动
  13. 网络探测工具(二)——traceroute
  14. 【机器人学习】Delta机器人三维模型+正逆运动学分析+matlab代码
  15. oppo推广开户费用介绍!oppo信息流广告怎么投放?
  16. 【内网—内网转发】——代理转发_ew(Earthworm)代理转发
  17. vis实现类知识图谱的拓扑图
  18. Alink如何读写Libsvm格式数据【Alink使用技巧】
  19. Newman如何生成报告?
  20. java 时间段重叠_java 判断两个时间段是否重叠的案例

热门文章

  1. 精通开关电源设计(二)
  2. 手机电子词典_【摘要】陈玉珍:词典使用对搭配产出与记忆保持的效能研究—— 以手机在线词典为例...
  3. 渝粤题库 陕西师范大学 《文字学概论》作业
  4. 利用ENVI自带全球DEM数据计算区域平均高程
  5. 什么软件测试出来的网速准确,百度应用的网速测试工具最不准确
  6. APU~ZPU全掌握!
  7. 游戏中植入广告的例子
  8. java 7下载_java7下载 v7.0 官方最新版
  9. iPhoneamp;iPad DFU及恢复模式刷机、降级教程
  10. 软件测试面试之智力题