Linux系統內核參數優化

来源:https://www.cnblogs.com/eddie1127/archive/2019/11/06/11806372.html
-Advertisement-
Play Games

Linux系統內核參數優化 在工作中,平常我們使用官方鏡像安裝的Linux系統(非自定製化的)系統內核考慮的是最通用的場景,通常設定都偏向穩定保守,比較典型的代表如紅帽系列的RHEL、CentOS等。而在正式的生成環境使用中,伺服器的CPU、記憶體等硬體配置都比較高,而安裝系統時預設的系統內核參數設定 ...


Linux系統內核參數優化

  在工作中,平常我們使用官方鏡像安裝的Linux系統(非自定製化的)系統內核考慮的是最通用的場景,通常設定都偏向穩定保守,比較典型的代表如紅帽系列的RHEL、CentOS等。而在正式的生成環境使用中,伺服器的CPU、記憶體等硬體配置都比較高,而安裝系統時預設的系統內核參數設定並不符合用於支持高併發訪問的業務伺服器,因此我們需要根據實際的業務特性來對系統的預設內核參數設定加以優化,以便能充分發揮伺服器的硬體計算處理能力,提高資源利用率的同時也給企業節省IT設備資源成本。

  以centos為例,可以通過vim /etc/sysctl.conf 文件來更改內核參數,可使用sysctl -p命令立即生效。

Linux系統常用的內核參數及定義總結如下:

以下內核參數配置僅供參考,具體使用應當根據業務環境特性及伺服器硬體配置來設置合理的值。

net.ipv4.ip_nonlocal_bind = 1 
#允許非本地IP地址socket監聽,當主機作為網關、反向代理或負載均衡器實現雙機熱備高可用時,主機需要綁定監聽虛擬VIP地址時,必須開啟此項。

net.ipv4.ip_forward = 1 
#開啟IPv4轉發。當伺服器作為路由網關、反向代理與負載均衡(開啟客戶端IP透傳時)必須開啟。

net.ipv4.tcp_timestamps = 1 
#開啟TCP時間戳,以一種比重發超時更精確的方法(請參閱 RFC 1323)來啟用對 RTT 的計算;為了實現更好的性能應該啟用這個選項。預設為0不啟用。

fs.file-max = 6553560 
#系統所有進程一共可以打開的文件數量,即系統當前最大的文件句柄數,屬於系統級別的限制,預設值大小通常與系統物理記憶體有關。註意:ulimit的open file值(預設1024)是單個進程可以打開的最大文件數,在高併發業務下,這個2個值都需要進行調整。

net.ipv4.tcp_tw_reuse = 1 
#預設為0不啟用,設置為1啟用tcp復用,表示允許將TIME_WAIT狀態的socket重新用於新的TCP鏈接,這對於高併發的伺服器來說意義重大,因為總有大量TIME_WAIT狀態的鏈接存在。

net.ipv4.tcp_tw_recycle = 1 
#預設為0表示關閉,為1時表示開啟TCP連接中TIME-WAIT sockets的快速回收,用於大量TIME_OUT場景。

net.ipv4.tcp_keepalive_time = 600 
#當keepalive啟用時,TCP發送keepalive消息的頻度;預設是2小時,將其設置為10分鐘,可更快的清理無效鏈接。

net.ipv4.tcp_keepalive_probes = 3
#當keepalive啟用時,如果對方不予應答,探測包的發送次數。

net.ipv4.tcp_keepalive_intvl = 15 
#當keepalive啟用時,keepalive探測包的發送間隔,單位為秒。

net.ipv4.tcp_fin_timeout = 30 
#當伺服器主動關閉鏈接時,socket保持在FIN_WAIT_2狀態的最長時間,單位為秒。

net.ipv4.tcp_syn_retries = 1 
#在內核放棄建立連接之前發送SYN包的數量

net.ipv4.tcp_syncookies = 1 
#與性能無關,用於解決TCP的SYN攻擊。1表示開啟TCP SYN Cookies。當出現SYN等待隊列溢出時,啟用cookies來處理,可防範少量SYN攻擊,預設為0,表示關閉。

net.ipv4.icmp_echo_ignore_broadcasts = 1 
#忽略icmp ping廣播包,避免放大攻擊。

net.ipv4.icmp_ignore_bogus_error_responses = 1 
#開啟惡意icmp錯誤消息保護

net.inet.udp.checksum=1 
#防止不正確的udp包的攻擊

net.ipv4.conf.default.accept_source_route = 0 
#是否接受含有源路由信息的ip包。參數值為布爾值,1表示接受,0表示不接受。在充當網關的linux主機上預設值應為1,在一般的linux主機上預設值應為0。從安全性角度出發,建議關閉該功能。

net.ipv4.tcp_slow_start_after_idle = 0 
#關閉tcp的連接傳輸的慢啟動,即先休止一段時間,再初始化擁塞視窗。

net.ipv4.route.gc_timeout = 100 
#路由緩存刷新頻率,當一個路由失敗後多長時間跳到另一個路由,預設是300秒。

net.ipv4.tcp_max_tw_buckets = 5000 
#表示操作系統允許保持TIME_WAIT套接字數量的最大值,如超過此值,TIME_WAIT套接字將立刻被清除並列印警告信息,預設為8000,過多的TIME_WAIT套接字會使伺服器響應變慢。

net.ipv4.ip_local_port_range = 1024 65000 
#定義UDP和TCP鏈接的本地埠的取值範圍。

net.ipv4.tcp_rmem = 10240 87380 12582912 
#定義了TCP接受socket請求緩存的記憶體最小值、預設值、最大值。

net.ipv4.tcp_wmem = 10240 87380 12582912 
#定義TCP發送緩存的最小值、預設值、最大值。該值為自動調優定義每個 socket 使用的記憶體。
#第一個值是為 socket 的發送緩衝區分配的最少位元組數。
#第二個值是預設值(該值會被 wmem_default 覆蓋),緩衝區在系統負載不重的情況下可以增長到這個值。
#第三個值是發送緩衝區空間的最大位元組數(該值會被 wmem_max 覆蓋)。

net.core.netdev_max_backlog = 8096 
#當網卡接收數據包的速度大於內核處理速度時,會有一個緩衝隊列保存這些數據包。這個參數表示該列隊的最大值。

net.core.somaxconn=262114 
#選項預設值是128,表示socket監聽的backlog(監聽隊列)上限。這個參數用於調節系統同時發起的TCP連接數,在高併發的請求中,預設的值可能會導致鏈接超時或者重傳,因此需要結合高併發請求數來調節此值。

net.core.optmem_max = 10000000 
#該參數指定了每個套接字所允許的最大緩衝區的大小(以位元組為單位)

net.core.rmem_default = 6291456 
#表示內核接收套接字緩衝區預設大小(以位元組為單位)。該參數定義了預設的發送視窗大小,對於更大的 BDP 來說,這個大小也應該更大。

net.core.wmem_default = 6291456 
#表示內核發送套接字緩衝區預設大小(以位元組為單位)

net.core.rmem_max = 12582912 
#表示內核接收套接字緩衝區最大大小(以位元組為單位)。該參數定義了預設的發送視窗大小,對於更大的 BDP 來說,這個大小也應該更大。

net.core.wmem_max = 12582912 
#表示內核發送套接字緩衝區最大大小(以位元組為單位)

net.ipv4.tcp_mem
#確定 TCP 棧應該如何反映記憶體使用;每個值的單位都是記憶體頁(通常是 4KB)。
#第一個值是記憶體使用的下限。
#第二個值是記憶體壓力模式開始對緩衝區使用應用壓力的上限。
#第三個值是記憶體上限。在這個層次上可以將報文丟棄,從而減少對記憶體的使用。對於較大的 BDP 可以增大這些值(其單位是記憶體頁,而不是位元組)。

net.ipv4.tcp_max_syn_backlog = 8192 
#這個參數表示TCP三次握手建立階段接受SYN請求列隊的較大長度,預設1024,將其設置的大一些可使出現伺服器程式繁忙來不及accept新連接時,可以容納更多等待連接的網路連接數,Linux不至於丟失客戶端發起的鏈接請求。

net.ipv4.tcp_max_orphans=262114 
#選項用於設定系統中最多有多少個TCP套接字不被關聯到任何一個用戶文件句柄上。如果超過這個數字,孤立鏈接將立即被覆位並輸出警告信息。這個限制指示為了防止簡單的DOS攻擊,不用過分依靠這個限制甚至認為的減小這個值,更多的情況是增加這個值。

net.ipv4.netfilter.ip_conntrack_max=204800 
#設置系統開始iptables防火牆對TCP連接進行狀態跟蹤的最大隊列長度限制,超過此限定值,將會發生數據表溢出丟棄,對於高併發業務通常也可以使用iptables的raw表設置免跟蹤處理。

net.ipv4.conf.all.rp_filter = 1 
#用於控制系統是否開啟對數據包源地址的校驗,1為嚴謹模式  (推薦),0為鬆散模式。預設為1開啟。

net.ipv4.conf.default.rp_filter = 1 
#用於控制系統是否開啟對數據包源地址的校驗,1為嚴謹模式  (推薦),0為鬆散模式。預設為1開啟。

net.ipv4.tcp_congestion_control = cubic 
#TCP擁塞控制演算法,centos7預設設置是cubic。Linux內核中提供了若幹套TCP擁塞控制演算法,已載入進內核的可以通過內核參數net.ipv4.tcp_available_congestion_control看到:sudo sysctl net.ipv4.tcp_available_congestion_control 沒有載入進內核的一般是編譯成了模塊,可以用modprobe載入。這些演算法各自適用於不同的環境。reno是最基本的擁塞控制演算法,也是TCP協議的實驗原型。bic適用於rtt較高但丟包極為罕見的情況,比如北美和歐洲之間的線路,這是2.6.8到2.6.18之間的Linux內核的預設演算法。cubic是修改版的bic,適用環境比bic廣泛一點,它是2.6.19之後的linux內核的預設演算法。hybla適用於高延時、高丟包率的網路,比如衛星鏈路——同樣適用於中美之間的鏈路。多人實驗表明,TCP擁塞控制演算法對TCP傳輸速率的影響可很大。修改TCP擁塞控制演算法需要修改內核參數net.ipv4.tcp_congestion_control=xxx

net.ipv4.tcp_window_scaling = 0 
#關閉tcp_window_scaling,啟用 RFC 1323 定義的 window scaling;要支持超過64KB的視窗,必須啟用該值。

net.ipv4.tcp_ecn = 0 
#關閉TCP的直接擁塞通告(tcp_ecn)

net.ipv4.tcp_sack = 1 
#關閉tcp_sack,啟用有選擇的應答(Selective Acknowledgment),這可以通過有選擇地應答亂序接收到的報文來提高性能(這樣可以讓發送者只發送丟失的報文段),(對於廣域網通信來說)這個選項應該啟用,但是這會增加對CPU的占用。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、簡介 方法可以稱為函數,函數又可以稱為方法,方法主要的作用是將一堆代碼進行重用的一種機制,避免太多的冗餘的代碼,還有方便後期維護。 二、語法 函數的語法: 描述: public:訪問修飾符,公開的; static:靜態的; 返回值類型:比如int 、string 、double等的類型,如果不寫 ...
  • 上一篇隨筆記錄到RabbitMQ的安裝,安裝完成,我們就開始使用吧。 RabbitMQ簡介 AMQP,即Advanced Message Queuing Protocol,高級消息隊列協議,是應用層協議的一個開放標準,為面向消息的中間件設計。消息中間件主要用於組件之間的解耦,消息的發送者無需知道消息 ...
  • Ubuntu下經常遇到無法用快捷鍵關閉觸控板的情況,博主的電腦安裝Ubuntu18.04後便出現了該問題。 解決辦法: 首先查看輸入設備的id,命令行輸入: xinput ,如圖,博主的TouchPad的id=17,電腦不同id各異, 知道了id=17之後,就可以通過命令關閉/開啟觸控板, 關閉命令 ...
  • 文本處理工具awk awk:(Aho, Weinberger, Kernighan,)報告生成器,格式化文本輸出 有多種版本:New awk(nawk),GNU awk( gawk) @[toc] gawk:模式掃描和處理語言 awk語言 ⽣成需要的測試數據: [root@magedu ~] hea ...
  • Shell內置命令、外部命令、別名、函數、保留關鍵字的優先順序 在Shell中,有5種可調用的東西:別名(alias)、函數(function)、shell保留關鍵字、shell內置命令、外部命令。 如果它們同名了,那麼優先調用誰呢?可使用 查看。 內置命令、別名、函數、外部命令 $ alias ki ...
  • 回到目錄 BJT晶體管可以實現邏輯門,事實上,在場效應管被髮明用於集成電路以前,各種邏輯門晶元中的電路就是用BJT晶體管來實現的。最早人們使用二極體與BJT組合來實現邏輯門,這個稱為二極體-晶體管邏輯(Diode-Transistor Logic),簡稱DTL;後來改進為全部用BJT晶體管來實現邏輯 ...
  • 框架是用visual studio創建的win32控制台模板,然後自己添加最小化及還原部分代碼。 需要額外包含的頭文件: #include <shellapi.h> #include <WinUser.h> 方式是在托盤區創建圖標,隱藏主視窗。 托盤創建圖標: void ToTray(HWND hW ...
  • 今天在安裝Python模塊matplotlib的時候,一直安裝不成功,老是提示“socket.timeout: The read operation timed out”或者“Read timed out.” 因為國內的網路訪問國外延遲很高,所以安裝模塊很慢就不說了,還一定安裝不上。 1 [root ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...