欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

高并發(fā)nginx服務(wù)器的linux內(nèi)核優(yōu)化配置講解

 更新時(shí)間:2019年03月18日 10:10:40   作者:CODETC  
今天小編就為大家分享一篇關(guān)于高并發(fā)nginx服務(wù)器的linux內(nèi)核優(yōu)化配置講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧

由于默認(rèn)的linux內(nèi)核參數(shù)考慮的是最通用場(chǎng)景,這明顯不符合用于支持高并發(fā)訪問(wèn)的Web服務(wù)器的定義,所以需要修改Linux內(nèi)核參數(shù),是的Nginx可以擁有更高的性能;

在優(yōu)化內(nèi)核時(shí),可以做的事情很多,不過(guò),我們通常會(huì)根據(jù)業(yè)務(wù)特點(diǎn)來(lái)進(jìn)行調(diào)整,當(dāng)Nginx作為靜態(tài)web內(nèi)容服務(wù)器、反向代理或者提供壓縮服務(wù)器的服務(wù)器時(shí),期內(nèi)核參數(shù)的調(diào)整都是不同的,這里針對(duì)最通用的、使Nginx支持更多并發(fā)請(qǐng)求的TCP網(wǎng)絡(luò)參數(shù)做簡(jiǎn)單的配置;

以下linux 系統(tǒng)內(nèi)核優(yōu)化配置均經(jīng)在線業(yè)務(wù)系統(tǒng)測(cè)試,并發(fā)10萬(wàn)左右服務(wù)器運(yùn)行狀態(tài)良好,用了一些時(shí)間整理,現(xiàn)和大家分享一下,如有那位高人看到配置上有問(wèn)題,請(qǐng)給與指出!

# Controls the use of TCP syncookies

#表示開(kāi)啟重用。允許將TIME-WAIT sockets重新用于新的TCP連接,默認(rèn)為0,表示關(guān)閉;
net.ipv4.tcp_syncookies = 1

#一個(gè)布爾類型的標(biāo)志,控制著當(dāng)有很多的連接請(qǐng)求時(shí)內(nèi)核的行為。啟用的話,如果服務(wù)超載,內(nèi)核將主動(dòng)地發(fā)送RST包。
net.ipv4.tcp_abort_on_overflow = 1

#表示系統(tǒng)同時(shí)保持TIME_WAIT的最大數(shù)量,如果超過(guò)這個(gè)數(shù)字,TIME_WAIT將立刻被清除并打印警告信息。
#默認(rèn)為180000,改為6000。對(duì)于Apache、Nginx等服務(wù)器,此項(xiàng)參數(shù)可以控制TIME_WAIT的最大數(shù)量,服務(wù)器被大量的TIME_WAIT拖死
net.ipv4.tcp_max_tw_buckets = 6000

#有選擇的應(yīng)答
net.ipv4.tcp_sack = 1

#該文件表示設(shè)置tcp/ip會(huì)話的滑動(dòng)窗口大小是否可變。參數(shù)值為布爾值,為1時(shí)表示可變,為0時(shí)表示不可變。tcp/ip通常使用的窗口最大可達(dá)到65535 字節(jié),對(duì)于高速網(wǎng)絡(luò).
#該值可能太小,這時(shí)候如果啟用了該功能,可以使tcp/ip滑動(dòng)窗口大小增大數(shù)個(gè)數(shù)量級(jí),從而提高數(shù)據(jù)傳輸?shù)哪芰Α?
net.ipv4.tcp_window_scaling = 1

#TCP接收緩沖區(qū)
net.ipv4.tcp_rmem = 4096    87380  4194304

#TCP發(fā)送緩沖區(qū)
net.ipv4.tcp_wmem = 4096    66384  4194304

# # Out of socket memory
net.ipv4.tcp_mem = 94500000 915000000 927000000

#該文件表示每個(gè)套接字所允許的最大緩沖區(qū)的大小。
net.core.optmem_max = 81920

#該文件指定了發(fā)送套接字緩沖區(qū)大小的缺省值(以字節(jié)為單位)。
net.core.wmem_default = 8388608

#指定了發(fā)送套接字緩沖區(qū)大小的最大值(以字節(jié)為單位)。
net.core.wmem_max = 16777216

#指定了接收套接字緩沖區(qū)大小的缺省值(以字節(jié)為單位)。
net.core.rmem_default = 8388608

#指定了接收套接字緩沖區(qū)大小的最大值(以字節(jié)為單位)。
net.core.rmem_max = 16777216

#表示SYN隊(duì)列的長(zhǎng)度,默認(rèn)為1024,加大隊(duì)列長(zhǎng)度為10200000,可以容納更多等待連接的網(wǎng)絡(luò)連接數(shù)。

net.ipv4.tcp_max_syn_backlog = 1020000

#每個(gè)網(wǎng)絡(luò)接口接收數(shù)據(jù)包的速率比內(nèi)核處理這些包的速率快時(shí),允許送到隊(duì)列的數(shù)據(jù)包的最大數(shù)目。
net.core.netdev_max_backlog = 862144

#web 應(yīng)用中l(wèi)isten 函數(shù)的backlog 默認(rèn)會(huì)給我們內(nèi)核參數(shù)的net.core.somaxconn 限制到128,而nginx 定義的NGX_LISTEN_BACKLOG 默認(rèn)為511,所以有必要調(diào)整這個(gè)值。
net.core.somaxconn = 262144

#系統(tǒng)中最多有多少個(gè)TCP 套接字不被關(guān)聯(lián)到任何一個(gè)用戶文件句柄上。如果超過(guò)這個(gè)數(shù)字,孤兒連接將即刻被復(fù)位并打印出警告信息。


#這個(gè)限制僅僅是為了防止簡(jiǎn)單的DoS 攻擊,不能過(guò)分依靠它或者人為地減小這個(gè)值,更應(yīng)該增加這個(gè)
net.ipv4.tcp_max_orphans = 327680

#時(shí)間戳可以避免序列號(hào)的卷繞。一個(gè)1Gbps 的鏈路肯定會(huì)遇到以前用過(guò)的序列號(hào)。時(shí)間戳能夠讓內(nèi)核接受這種“異?!钡臄?shù)據(jù)包。這里需要將其關(guān)掉。
net.ipv4.tcp_timestamps = 0

#為了打開(kāi)對(duì)端的連接,內(nèi)核需要發(fā)送一個(gè)SYN 并附帶一個(gè)回應(yīng)前面一個(gè)SYN 的ACK。也就是所謂三次握手中的第二次握手。這個(gè)設(shè)置決定了內(nèi)核放棄連接之前發(fā)送SYN+ACK 包的數(shù)量。
net.ipv4.tcp_synack_retries = 1

#在內(nèi)核放棄建立連接之前發(fā)送SYN 包的數(shù)量。www.dbjr.com.cn
net.ipv4.tcp_syn_retries = 1

#表示開(kāi)啟TCP連接中TIME-WAIT sockets的快速回收,默認(rèn)為0,表示關(guān)閉;
net.ipv4.tcp_tw_recycle = 1

#表示開(kāi)啟重用。允許將TIME-WAIT sockets重新用于新的TCP連接,默認(rèn)為0,表示關(guān)閉;
net.ipv4.tcp_tw_reuse = 1

#修改系統(tǒng)默認(rèn)的 TIMEOUT 時(shí)間。
net.ipv4.tcp_fin_timeout = 15

#表示當(dāng)keepalive起用的時(shí)候,TCP發(fā)送keepalive消息的頻度。缺省是2小時(shí),建議改為20分鐘。
net.ipv4.tcp_keepalive_time = 30

#表示用于向外連接的端口范圍。缺省情況下很小:32768到61000,改為10000到65000。(注意:這里不要將最低值設(shè)的太低,否則可能會(huì)占用掉正常的端口?。?
net.ipv4.ip_local_port_range = 1024  65000

#以下可能需要加載ip_conntrack模塊 modprobe ip_conntrack ,有文檔說(shuō)防火墻開(kāi)啟情況下此模塊失效

#縮短established的超時(shí)時(shí)間
net.netfilter.nf_conntrack_tcp_timeout_established = 180

#CONNTRACK_MAX 允許的最大跟蹤連接條目,是在內(nèi)核內(nèi)存中netfilter可以同時(shí)處理的“任務(wù)”(連接跟蹤條目)
net.netfilter.nf_conntrack_max = 1048576
net.nf_conntrack_max = 1048576

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • nginx強(qiáng)制使用https訪問(wèn)的方法(http跳轉(zhuǎn)到https)

    nginx強(qiáng)制使用https訪問(wèn)的方法(http跳轉(zhuǎn)到https)

    這篇文章主要介紹了nginx強(qiáng)制使用https訪問(wèn)的方法(http跳轉(zhuǎn)到https),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • nginx rewrite 偽靜態(tài)配置參數(shù)和使用例子

    nginx rewrite 偽靜態(tài)配置參數(shù)和使用例子

    nginx下偽靜態(tài)配置參數(shù)詳細(xì)說(shuō)明,使用nginx的朋友,nginx rewrite 偽靜態(tài)配置參數(shù)和使用例子 附正則使用說(shuō)明
    2010-07-07
  • nginx部署后css、js、圖片等樣式不加載問(wèn)題的兩種解決方案

    nginx部署后css、js、圖片等樣式不加載問(wèn)題的兩種解決方案

    這篇文章主要介紹了nginx部署后css、js、圖片等樣式不加載問(wèn)題的兩種解決方案,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-12-12
  • nginx如何開(kāi)通gzip壓縮傳輸文件

    nginx如何開(kāi)通gzip壓縮傳輸文件

    Gzip壓縮是一種有效提升網(wǎng)站性能的方法,通過(guò)減少傳輸數(shù)據(jù)量和提高傳輸速度,Nginx服務(wù)器支持Gzip壓縮,適合壓縮HTML、CSS、JavaScript、JSON和XML等文本文件,配置中需設(shè)置gzip_types指定壓縮文件類型,gzip_comp_level設(shè)置壓縮級(jí)別
    2024-09-09
  • nginx虛擬主機(jī)配置實(shí)例詳解

    nginx虛擬主機(jī)配置實(shí)例詳解

    這篇文章主要介紹了nginx虛擬主機(jī)配置實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • nginx中的健康檢查方案

    nginx中的健康檢查方案

    這篇文章主要介紹了nginx中的健康檢查方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • nginx中斜杠(‘/‘)的具體使用

    nginx中斜杠(‘/‘)的具體使用

    在Nginx配置的過(guò)程中,斜杠(/)經(jīng)常使用到,它們不僅可以區(qū)分不同的路徑,還有其他的作用,本文就詳細(xì)的介紹了nginx中斜杠(‘/‘)的具體使用,感興趣的可以了解一下,感興趣的可以了解一下
    2023-10-10
  • 如何配置nginx成功代理websocket

    如何配置nginx成功代理websocket

    配置Nginx作為WebSocket代理是一種常見(jiàn)的設(shè)置,以便在Nginx服務(wù)器上實(shí)現(xiàn)WebSocket連接的轉(zhuǎn)發(fā)和負(fù)載均衡,這篇文章主要介紹了配置nginx以成功代理websocket,需要的朋友可以參考下
    2024-02-02
  • Nginx查看當(dāng)前連接數(shù)的配置方法

    Nginx查看當(dāng)前連接數(shù)的配置方法

    在開(kāi)發(fā)過(guò)程中有時(shí)候我們需要查看Nginx的當(dāng)前連接數(shù),方便調(diào)整一些參數(shù)配置和性能調(diào)優(yōu),在Nginx中,你可以通過(guò)幾種方式來(lái)查看當(dāng)前的連接數(shù),感興趣的朋友一起看看吧
    2024-08-08
  • Nginx解決Http慢攻擊(Slow HTTP Attack)的方法

    Nginx解決Http慢攻擊(Slow HTTP Attack)的方法

    緩慢的HTTP拒絕服務(wù)攻擊是一種專門(mén)針對(duì)于Web的應(yīng)用層拒絕服務(wù)攻擊,本文給大家介紹了Nginx解決Http慢攻擊(Slow HTTP Attack)的方法,需要的朋友可以參考下
    2024-02-02

最新評(píng)論