主頁 >  其他 > 記一次618軍演壓測TPS上不去排查及優化

記一次618軍演壓測TPS上不去排查及優化

2023-06-06 09:08:47 其他

本文內容主要介紹,618醫藥供應鏈質量組一次軍演壓測發現的問題及排查優化程序,旨在給大家借鑒參考,

背景

本次軍演壓測背景是,2B業務線及多個業務側共同和B中臺聯合軍演,

現象

當壓測商品卡片介面的時候,cpu達到10%,TPS只有240不滿足預期指標,但是TP99已經達到了1422ms,

排查

對于這種TPS不滿足預期目標,但是TP99又超高,其實它的原因有很多中可能,通過之前寫過的文章對性能瓶頸的一個分析方式《性能測驗監控指標及分析調優》,我們可以采用自下而上的策略去進行排查:

首先是作業系統層面的CPU、記憶體、網路帶寬等,對于集團內部的壓測,機器的配置、網路帶寬,這些因素運維人員已經配置到最優的程度了,無需我們再關心是否是因為硬體資源系統層面導致的因素,

接下來從代碼層面和JVM層面進行排查,可能是專案代碼中出現了執行緒阻塞,導致執行緒出現等待,回應時間變長,請求不能及時打到被測服務器上,對于這種猜測,我們可以在壓測程序中打執行緒dump檔案,從dump檔案中找到哪個執行緒一致處于等待狀態,從而找到對應的代碼,查看是否可以進行優化,這塊同開發一同分析整個介面的呼叫鏈路,商品卡片介面呼叫運營端的優惠券的可領可用介面,通過查看此介面的ump監控那個,發現呼叫量其實并不高,接下來通過查看運營端機器的日志發現,呼叫可領可用優惠券介面已經超時了,并且機器CPU已經偏高,使用率平均在80%以上,是什么原因導致呼叫可領可用介面大量超時,成為了問題的關鍵點,

image.png

首先我們代碼層面分析,這個可領可用優惠券介面還會呼叫一個過濾器進行過濾,于是猜測是不是這個過濾器介面把CPU打滿了,但是通過監控過濾器介面的ump中可以看到它的TP99并不是很高,說明它的呼叫量沒有上去,這種猜測可能不成立,還好當時代碼這設定了一個開關是否使用過濾器,我們把過濾器的開關關閉后,再次進行壓測商品卡片介面,發現還是沒有解決問題,TPS仍然不高,并且TP99還是很高,說明這個猜測真是不成立的,

接下來我們轉換思路,查看JVM日志,是否從中尋找到一些蛛絲馬跡,果然從JVM的GC日志中可看到Ygc和Fgc的時間占用比較長,其中Fullgc的時間占用時間達到了7165ms,并且從中可以查看jvm的引數配置,發現Xms 和Xmx配置的值都是1024,只有1個G,問題的原因找到了,這臺被壓測的機器JVM引數配置的Xms 和Xmx值太小了,如果-Xmx指定偏小,應用可能會導致java.lang.OutOfMemory錯誤

image.png

image.png

對于JVM的介紹這部分比較龐大涉及到類加載方式、JVM記憶體模型、垃圾回收演算法、垃圾收集器型別、GC日志,在這就不做詳細說明了,想要了解詳細內容可以看看《深入理解 JAVA 虛擬機》這本書,

此處簡單說明下什么是Ygc和Fgc,以及Xms、Xmx的含義,

JVM記憶體模型中,分為新生代、老年代和元空間,新生代又分為eden區、Survivor0、Survivor1區,物件優先在Eden區分配,當Eden區沒有足夠空間時會進行一次Minor GC,執行完第一次MGC之后,存活的物件會被移動到Survivor(from)磁區,當Survivor區存盤滿了之后會進行一次Ygc,但是Ygc一般不會影回應用,當老年代記憶體不足的時候,會進行一次Full GC,也就是Stop the world,系統將停止運行,清理整個記憶體堆(包括新生代和老年代) ,FullGC頻率過大和時間過長,會嚴重影響系統的運行,

Xms,JVM初始分配的堆記憶體

Xmx,JVM最大分配的堆記憶體

一般情況這兩個引數配置的值是相等的,以避免在每次GC 后堆記憶體重新進行分配,

優化

最后修改機器的JVM數配置

查看JVM配置引數

重啟后再次進行壓測,我們的TPS指標上來了,并且TP99的值也下去了,達到了預期的一個目標,

總結

其實對于一個性能瓶頸問題的分析排查定位,猶如醫生看病,需要望聞問切,通過表面現象逐層的去排除一種種的可能性,最終找到其根本原因,對癥下藥解決問題,本文介紹的也只是性能瓶頸問題中的一個小小的部分,其實在壓測程序中還會遇到各種各樣的問題,但是我們掌握了方法論,其實都可以按照相同的思路去排查,最終找到根源,

作者:京東健康 牛金亮

來源:京東云開發者社區

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/554361.html

標籤:其他

上一篇:9.3. Hibernate框架

下一篇:返回列表

標籤雲
其他(160387) Python(38206) JavaScript(25475) Java(18198) C(15237) 區塊鏈(8269) C#(7972) AI(7469) 爪哇(7425) MySQL(7234) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5346) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4582) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1981) 功能(1967) HtmlCss(1952) Web開發(1951) C++(1929) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 記一次618軍演壓測TPS上不去排查及優化

    本文內容主要介紹,618醫藥供應鏈質量組一次軍演壓測發現的問題及排查優化程序。旨在給大家借鑒參考。 ### 背景 本次軍演壓測背景是,2B業務線及多個業務側共同和B中臺聯合軍演。 ### 現象 當壓測商品卡片介面的時候,cpu達到10%,TPS只有240不滿足預期指標,但是TP99已經達到了1422 ......

    uj5u.com 2023-06-06 09:08:47 more
  • 9.3. Hibernate框架

    Hibernate是一個開源的持久層框架,它可以幫助我們將Java物件映射到資料庫表中,并實作物件的持久化操作。Hibernate提供了豐富的API,可以方便地進行CRUD(增刪改查)操作,而無需手動撰寫復雜的JDBC代碼。 #### 9.3.1. Hibernate核心組件 Hibernate主要 ......

    uj5u.com 2023-06-06 09:08:32 more
  • python學習框架

    1. Python簡介與安裝 - Python的歷史與特點 - Python的安裝與配置 2. Python基礎語法 - 變數與資料型別 - 運算子與運算式 - 控制結構(條件判斷與回圈) - 函式與模塊 - 錯誤處理與例外 3. Python資料結構 - 串列(List) - 元組(Tuple) ......

    uj5u.com 2023-06-06 09:08:24 more
  • 【解決方法】網路設備使用CLI命令列模式進入Telnet登錄,如交換機,

    # 環境: >工具:銳捷EVE模擬器,VMware Workstation Pro 遠程工具:SecureCRT 系統版本:Windows 10 # 問題描述: >描述:在實驗使用路由器遠程SSH登錄交換機時,無法連接,一直提示:% Destination unreachable; gateway ......

    uj5u.com 2023-06-06 09:08:15 more
  • 安全可信 | 天翼云自研密鑰管理系統(KMS)獲得《商用密碼產品認證證

    近日,天翼云自研密鑰管理系統(KMS)通過國家密碼管理局安全性審查,符合GM/T 0051《密碼設備管理 對稱密鑰管理技術規范》要求,獲得由國家密碼管理局商用密碼檢測中心頒發的《商用密碼產品認證證書》。 《商用密碼產品認證證書》具有權威性及唯一性,該證書的獲得標志著天翼云密鑰管理系統(KMS)的合規 ......

    uj5u.com 2023-06-06 09:08:02 more
  • 【解決方法】loopback口添加同目的網段的地址后,無法用默認路由pi

    # 環境: >工具:銳捷EVE,VMware Workstation Pro 遠程工具:SecureCRT 系統版本:Windows 10 # 問題描述: >描述:原本可用默認路由ping該地址,但是在lookback口添加同該地址網段地址后,就無法ping通。 >提示:若按照教程還是無法完成操作, ......

    uj5u.com 2023-06-06 09:07:51 more
  • VLAN——提高網路性能、安全性和靈活性的利器

    # 前言 VLAN是Virtual Local Area Network的縮寫,它是一種通過網路交換機虛擬劃分局域網的技術。VLAN可以將一個物理局域網劃分成多個邏輯上的虛擬局域網,各個虛擬局域網之間相互獨立,彼此隔離,進而提高網路性能、靈活性和安全性。本文將為大家介紹VLAN的作業原理、優點及應用 ......

    uj5u.com 2023-06-06 09:07:43 more
  • 某OA 11.10 未授權任意檔案上傳

    之前也對通達OA做過比較具體的分析和漏洞挖掘,前幾天看到通達OA11.10 存在未授權任意檔案上傳漏洞,于是也打算對此進行復現和分析。 ......

    uj5u.com 2023-06-06 09:07:11 more
  • 1.6. 陣列

    陣列是一種資料結構,用于存盤相同型別的多個元素。在 Java 中,陣列是一個物件,它具有一定數量的連續記憶體空間。陣列中的每個元素都有一個索引,用于訪問和操作元素。 #### 1.6.1. 陣列的宣告與初始化 在 Java 中,可以使用以下語法宣告一個陣列: ```java 元素型別[] 陣列名; ` ......

    uj5u.com 2023-06-06 09:06:21 more
  • OSI7層模型和TCP/IP模型

    ## 前言 在計算機網路領域中,OSI7層模型和TCP/IP模型是兩個重要的概念。本文將對這兩個模型進行介紹和比較,讓大家了解它們的區別和聯系。 [TOC](OSI7層模型和TCP/IP模型) ## OSI7層模型 OSI(Open System Interconnection)層模型是國際標準化組 ......

    uj5u.com 2023-06-06 09:06:13 more