(五)Linux性能優化-CPU-性能優化

性能優化文章參考倪朋飛老師的Linux性能優化實戰課程

性能優化方法論

Q:怎么評估性能優化的效果?
A:對系統的性能指標進行量化,并且要分別測試出優化前、后的性能指標,用前后指標的變化來對比呈現效果。確定性能的量化指標;測試優化前的性能指標;測試優化后的性能指標
Q:多個性能問題同時存在,要怎么選擇?
A:不是所有的性能問題都值得優化,找出最重要的、可以最大程度提升性能的問題
Q:有多種優化方法時,要如何選擇?
A:性能優化通常會帶來復雜度的提升,降低程序的可維護性,還可能在優化一個指標時,引發其他指標的異常;切記,不要想著“一步登天”,試圖一次性解決所有問題;也不要只會“拿來主義”,把其他應用的優化方法原封不動拿來用,卻不經過任何思考和分析

CPU優化

  1. 應用程序優化
    • 編譯器優化
    • 算法優化
    • 異步處理
    • 多線程
    • 緩存
  2. 系統優化
    • CPU綁定:把進程綁定到一個或者多個 CPU 上,可以提高 CPU 緩存的命中率,減少跨 CPU 調度帶來的上下文切換問題
    • CPU獨占:跟 CPU 綁定類似,進一步將 CPU 分組,并通過 CPU 親和性機制為其分配進程。這樣,這些 CPU 就由指定的進程獨占,換句話說,不允許其他進程再來使用這些 CPU
    • 優先級調整:使用 nice 調整進程的優先級,正值調低優先級,負值調高優先級。優先級的數值含義前面我們提到過,忘了的話及時復習一下。在這里,適當降低非核心應用的優先級,增高核心應用的優先級,可以確保核心應用得到優先處理。
    • 為進程設置資源限制:使用 Linux cgroups 來設置進程的 CPU 使用上限,可以防止由于某個應用自身的問題,而耗盡系統資源。
    • NUMA(Non-Uniform Memory Access)優化:支持 NUMA 的處理器會被劃分為多個 node,每個 node 都有自己的本地內存空間。NUMA 優化,其實就是讓 CPU 盡可能只訪問本地內存。
    • 中斷負載均衡:無論是軟中斷還是硬中斷,它們的中斷處理程序都可能會耗費大量的 CPU。開啟 irqbalance 服務或者配置 smp_affinity,就可以把中斷處理過程自動負載均衡到多個 CPU 上。
# 查看系統平均負載
watch -d uptime
# 查看系統CPU情況
mpstat -P ALL 1
# 查看進程CPU使用情況
pidstat -u 1
# 查看上下文切換
vmstat 1 10

在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86754.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86754.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86754.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ThreadLocal原理及內存泄漏分析

介紹 每個線程內部都有一個私有的 ThreadLocalMap 實例&#xff0c;用于存儲該線程關聯的所有 ThreadLocal 變量。 ThreadLocalMap 內部的 Entry 繼承自 WeakReference<ThreadLocal<?>>。所以**Entry 的 key&#xff08;即 ThreadLocal 對象本身&#xff09;是通…

Oracle OCP認證考試考點詳解083系列18

題記&#xff1a; 本系列主要講解Oracle OCP認證考試考點&#xff08;題目&#xff09;&#xff0c;適用于19C/21C,跟著學OCP考試必過。 86. 第86題&#xff1a; 題目 解析及答案&#xff1a; 86、使用FLASHBACK TABLE的兩個先決條件是什么&#xff1f; A&#xff09;必須對…

git merge合并分支push報錯:Your branch is ahead of ‘xxx‘ by xx commits.

git merge合并分支push報錯&#xff1a;Your branch is ahead of xxx by xx commits. Your branch is ahead of xxx by xx commits.(use "git push" to publish your local commits)解決方案&#xff1a; git checkout 到要合入的分支&#xff0c;然后&#xff1a; …

英語作文模板

核心原則&#xff1a;三段式結構 ?英文: The core principle is a three-paragraph structure (Introductory paragraph Main body paragraph Concluding paragraph).?中文: 核心原則是采用三段式結構&#xff08;開頭引論段 中間主體段 結尾總結段&#xff09;。 模板 …

[安卓按鍵精靈輔助工具]一些安卓端可以用的雷電模擬器adb命令

在雷電論壇上看到很多adb命令&#xff0c;不過并沒有針對安卓按鍵進行處理&#xff0c;這里做了一下測試&#xff0c;把能用在安卓按鍵上的adb命令整理出來。 調用adb命令使用的山海插件中的Execute 執行shell命令 adb命令源碼如下&#xff1a; Import "shanhai.lua&quo…

uni-app項目怎么實現多服務環境切換

前情 uni-app是我比較喜歡的跨平臺框架&#xff0c;它能開發小程序/H5/APP(安卓/iOS)&#xff0c;重要的是對前端開發友好&#xff0c;自帶的IDE可視化的運行和打包也讓開發體驗也非常棒&#xff0c;公司項目就是主推uni-app&#xff0c;現在我的開發模式是用HBuilder X跑項目…

論文閱讀:強化預訓練

大型語言模型 (LLMs) 的驚人能力很大程度上歸功于在海量文本語料庫上進行下一詞元預測 (Next-Token Prediction, NTP) 的規模化訓練。與此同時&#xff0c;強化學習 (Reinforcement Learning, RL) 已成為微調 LLMs、使其與人類偏好對齊或增強特定技能&#xff08;如復雜推理&am…

Java 大視界——Java大數據在智能安防視頻監控中的異常事件快速響應與處理機制

??摘要&#xff1a;?? 在智慧城市和工業4.0浪潮下&#xff0c;智能安防系統日均產生PB級視頻流數據。如何在實時性、準確性、成本三者間取得平衡&#xff0c;成為行業核心挑戰。本文將深入探討??Java技術棧在大規模視頻分析系統中的核心作用??&#xff1a;基于FlinkJav…

華為云Flexus+DeepSeek征文| 基于Dify-LLM平臺應用實踐:創建智能知識庫問答助手

華為云FlexusDeepSeek征文&#xff5c; 基于Dify-LLM平臺應用實踐&#xff1a;創建智能知識庫問答助手 前言一、相關名詞介紹1.1 華為云Flexus X實例介紹1.2 華為云ModelArts Studio介紹 二、本次實踐介紹2.1 本次實踐環境介紹2.2 Dify平臺介紹 三、搭建Dify-LLM開發平臺3.1 進…

Spark on yarn的作業提交流程

一、YarnClient 二、YarnCluster 三、詳細描述 客戶端&#xff08;Client&#xff09;通過YARN的ResourceManager提交應用程序。在此過程中&#xff0c;客戶端進行權限驗證&#xff0c;生成Job ID和資源上傳路徑&#xff0c;并將這些信息返回給客戶端。客戶端將jar包、配置…

MySQL 主從復制與一主多從架構實戰詳解

文章目錄 一、MySQL 主從復制的本質原理 數據同步流程&#xff1a; 主從復制三大線程&#xff1a; 二、主從復制的三種模式 三、一主多從架構設計與應用 應用場景&#xff1a; 優勢&#xff1a; 四、單機模擬主從復制&#xff08;實戰配置&#xff09; 環境準備&#xff1a…

分布式光纖測溫及紅外測溫系統的區別?

在現代工業監控系統中&#xff0c;溫度監測是保障設備安全運行的關鍵環節。分布式光纖測溫&#xff08;DTS&#xff09;和紅外測溫&#xff08;IR&#xff09;是兩種常見的溫度監測技術。 本文將介紹這兩種技術的原理、優勢以及應用場景的區別。 光纖測溫技術的原理是利用光纖…

sql優化:使用 exists 優化 in () 或 = ()

1、使用 exists 優化 in () 優化前&#xff1a; select id, order_no, apply_time, apply_dept, apply_operator, purpose, stage, remark from BranchWarehouseApplyMaster where stage 0 and warehouse_id 1 and apply_dept in ( select emp_DeptID from Employee where …

HTTP 響應狀態碼

HTTP 響應狀態碼&#xff08;Response Status Codes&#xff09; HTTP 響應狀態碼用于表示服務器對客戶端請求的處理結果&#xff0c;由3位數字 組成&#xff0c;分為5類&#xff1a; 狀態碼 類別 常見狀態碼 說明 1xx 信息響應 100&#xff08;Continue&#xff09; …

如何通過插件系統打造個性化效率工作流

在現代工作流中&#xff0c;快速調用工具與自動化操作已成為提升生產力的核心環節。一款真正出色的效率工具&#xff0c;不僅要在響應速度和跨平臺兼容性上表現出色&#xff0c;更需要具備高度的可擴展性&#xff0c;以滿足多樣化的使用場景。 它不僅輕量高效&#xff0c;還支…

Spring上下文模塊設計

經過此前我們設計的如&#xff1a;IoC、Web、數據訪問、AOP等模塊的設計&#xff0c;我們從設計上已經搭建好了Spring的基礎骨架了&#xff0c;但聰明的碼友會思考想到&#xff1a;作為一個基礎框架而言&#xff0c;目前應該是已經夠用了的&#xff0c;但是上進的碼友怎么會就此…

keil5怎么關閉工程

在project里面有一個close project&#xff0c;點擊后就關掉了&#xff0c;之前還按照其他軟件的操作習慣&#xff0c;右鍵工程選項&#xff0c;但是始終沒有發現關閉選項。

騰訊云:6月30日起,自動禁用,及時排查

大家好&#xff0c;我是小悟。 騰訊云發布公告&#xff0c;宣布從2025年6月30日開始&#xff0c;對長期未使用的AccessKey&#xff08;API訪問密鑰&#xff09;進行自動禁用。 簡單來說&#xff0c;如果你的密鑰在90天內沒動靜&#xff0c;系統就會把它關掉&#xff0c;不管是…

【C++】多重繼承與虛繼承

多重繼承與虛繼承 1.單繼承和多重繼承的區別2.語法規則示例代碼&#xff1a;多重繼承子類指定父類的構造示例代碼&#xff1a;多重繼承子類隱藏父類的同名方法 3.虛繼承解決多重繼承遇到的bug示例代碼&#xff1a;環狀繼承引發的問題 3.1 虛基類&#xff1a;3.2 語法規則&#…

GCC編譯/連接/優化等選項

1. GCC編譯/連接/優化等選項 1. GCC編譯/連接/優化等選項 1.1. 簡介1.2. 常用選項 1.2.1. -c -E -S -o1.2.2. -L<path> -l<library>1.2.3. -D<macro>1.2.4. -I<path> 1.3. 代碼生成和優化 1.3.1. -std<standard>1.3.2. -shared1.3.3. -fPIC1.3.…