当前位置: 首页 > news >正文

塔罗牌手机网站制作深圳百度推广联系方式

塔罗牌手机网站制作,深圳百度推广联系方式,创新的网站,武汉seo创造者文章目录 前言一、内存使用过高导致CPU满载案例代码分析思路 二、出现了类似死循环导致cpu负载案例代码分析思路 三、死锁案例代码分析思路 前言 首先线上接口变慢,原因可能有很多,有可能是网络,有可能是慢 SQL,有可能是服务本身…

文章目录

  • 前言
  • 一、内存使用过高导致CPU满载
    • 案例代码
    • 分析思路
  • 二、出现了类似死循环导致cpu负载
    • 案例代码
    • 分析思路
  • 三、死锁
    • 案例代码
    • 分析思路

前言

首先线上接口变慢,原因可能有很多,有可能是网络,有可能是慢 SQL,有可能是服务本身出现了问题,还有可能是机器达到了性能瓶颈。而机器性能瓶颈也又可以分为磁盘 IO 瓶颈、CPU 性能瓶颈、网卡瓶颈等等。

线上接口过慢,排除网络的原因之外无非有以下三点:

  1. 内存使用过高,频繁gc导致cpu占满
  2. 内存使用不高,出现了类似死循环场景
  3. 死锁
    一般在遇到问题的时候先使用top -c 命令查看cpu是否占满,然后再使用free -m查看内存使用率,初步
    判断是上面问题的哪一种,然后再针对这一种问题深入排查。下面来模拟一下以上几种情况:

一、内存使用过高导致CPU满载

案例代码

public class FullGc {public static void main(String[] args) {List<Object> list = new ArrayList<>();for (int i = 0; i < 10000000; i++) {String str = "";for (int j = 0; j < 1000; j++) {str += UUID.randomUUID().toString();}list.add(str);System.out.println(str);}}}

分析思路

  1. 查看负载高的cpu进程id: top -c
    在这里插入图片描述

    这时发现进程id为70719的cpu负载较高

  2. 查看该进程id的线程id: top -Hp 70719
    在这里插入图片描述

    这时发现线程id为70720的线程负载较高

  3. 将十进制的线程id转换为16进制小写的:printf “%x\n” 69476
    在这里插入图片描述

    发现16进制的线程id为11440

  4. 查看该线程的运行的情况:jstack 70719|grep 11440 -A60
    在这里插入图片描述

    发现是FullGc这个类的第14行有问题

  5. 通过jamp工具导出内存日志,分析堆的情况:jmap -dump:format=b,file=dump.dat 70719
    在这里插入图片描述

  6. 使用MAT工具分析堆的情况
    在这里插入图片描述

发现了以上大量的字符串

二、出现了类似死循环导致cpu负载

案例代码

public class Cpu {public static void main(String[] args) {while (true) {}}
}

分析思路

基本上跟内存使用率过高的前几步差不多的,依然是以下几步:

  1. top命令查看当前CPU消耗过高的进程,得到进程id
  2. 根据进程id得到占比较高的线程id
  3. 将线程id转换为十六进制
  4. 根据进程编号用jstack命令查看线程id,可以得到线程的具体堆栈信息
    在这里插入图片描述

从图中可以看出Cpu这个类的第三行有问题

三、死锁

案例代码

public class DeadLock {private static Object left = new Object();private static Object right = new Object();private static class Thread1 implements Runnable {@Overridepublic void run() {synchronized (left) {try {Thread.sleep(2000);} catch (InterruptedException e) {}synchronized (right) {}}}}private static class Thread2 implements Runnable {@Overridepublic void run() {synchronized (right) {try {Thread.sleep(2000);} catch (InterruptedException e) {}synchronized (left) {}}}}public static void main(String[] args) {new Thread(new Thread1()).start();new Thread(new Thread2()).start();}
}

分析思路

这个就简单了

  1. 先使用jps查看进程id,如图:
    在这里插入图片描述
  2. 找出死锁的线程:jstack [进程id]
    在这里插入图片描述
    jvm会自动搜索出死锁的堆栈信息
http://www.tj-hxxt.cn/news/22522.html

相关文章:

  • 论坛上怎么做网站优化如何做企业网站
  • 什么是网站单页百家号seo
  • 产品展示型网站建设百度下载安装app
  • 怎样查公司是不是正规公司成都seo优化公司
  • 电商设计图片南京搜索引擎推广优化
  • 建设个人网站用什么软件好世界羽联巡回赛总决赛
  • 驻马店哪里做网站aso优化排名
  • 电商运营 网站运营专业的网络推广
  • 广州网站制作抖音seo什么意思
  • 软件学校网站模板站长工具seo综合查询columbu cat
  • 如何用axure做网站网站查询服务器
  • 三七批发可做网站名吗互联网营销师培训机构
  • 男女做那个的视频网站石家庄网络营销网站推广
  • 清远市网站建设公司百度网址大全 旧版本
  • 网站后台管理系统教程推广app的单子都在哪里接的
  • 汉阳网站建设公司站内seo和站外seo区别
  • 请人帮忙做网站推广广州seo优化公司
  • 网站怎么建设商城大众点评seo关键词优化
  • 在线教育网站建设投标书网站申请流程
  • 做网站如何快速推广一款产品网络推广员是干嘛的
  • 达州住房和城乡建设厅网站宁波网站推广联系方式
  • 手表哪个网站正品交换链接营销
  • 软件开发包括网站开发吗最新中国新闻
  • 现在网站如何做优化谷歌推广和seo
  • 海洋网站建设百度投放广告平台
  • wordpress metro手机主题seo优化官网
  • 化妆品网站设计思路浏览器里面信息是真是假
  • 哪里有免费的wordpress主题山西免费网站关键词优化排名
  • 启铭网站建设南宁seo手段
  • 建设网站需要什么知识什么平台可以免费推广产品