新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > Linux網(wǎng)站架構(gòu)系列之a(chǎn)pache----調(diào)優(yōu)篇

Linux網(wǎng)站架構(gòu)系列之a(chǎn)pache----調(diào)優(yōu)篇

作者: 時間:2016-10-08 來源:網(wǎng)絡(luò) 收藏

ExpiresByType image/png access plus 12 months

EXpiresByType application/x-shockwave-flash access plus 12 months

EXpiresByType application/x-javascript access plus 12 months

ExpiresByType video/x-flv access plus 12 months

以上三種配置任何一種配置之后,對apache服務(wù)器進(jìn)行優(yōu)化重啟,然后用火狐或者google游覽器的YSlow插件進(jìn)行緩存效果查看。

擴展:expires模塊的語法

上面已經(jīng)的操作就是實現(xiàn)apache的緩存功能。其中,expires后面的參數(shù)你也可以根據(jù)需求自行更改,緩存時間也是一樣可以更改的。

這里我對expires的模塊語法進(jìn)行一些細(xì)說

expires模塊用到了ExpiresDefault和EXpiresByType兩個指令,下面是這兩個指令的語法。

ExpiresDefault “ [plus] {}*”

EXpiresByType type/encoding [plus] {}

其中的參數(shù)有3個:access,now(等價于‘access’),modification

plus關(guān)鍵字是可選的。

必須是整數(shù),確??梢詀toi()所接收。(atoi可以把字符串轉(zhuǎn)換成長整型數(shù))

參數(shù)類型:years,months,weeks,days,hours,minutes,seconds

下面用幾個例子帶大家理解下

例如:下面3個指令都表示文檔默認(rèn)的有效期是一個月

ExpiresDefault access plus 1 month

ExpiresDefault access plus 4 weeks

ExpiresDefault access plus 30 days

有效期可以通過增加“”子句進(jìn)一步調(diào)整

ExpiresByType text/html access plus 1 month 15 days 2 hours

ExpiresByType image/gif modification plus 5 hours 3 minutes

注意:如果你使用基于最后修改日期的設(shè)置,“Expires”頭將不會被添加到那些并非來自于硬盤文件的內(nèi)容,這是因為這些內(nèi)容并不存在“最后修改時間”的屬性。

基準(zhǔn)時刻可以是源文件的最后修改時刻或者客戶端對源文件的訪問時刻,至于使用那一個則由指定。“M”表示源文件的最后修改時刻,“A”表示客戶端對源文件的訪問時刻,需要注意的是和seconds之間沒有空格。

這兩個基準(zhǔn)的差別是很微妙的。如果使用“M”,所有當(dāng)前緩存中的文檔副本都將在同一時刻過期,這個可能對定期更新的URL(比如位于同一位置的每周通告)很有好處。如果使用“A”,則每個客戶端所得到的有效期是不一樣的,這個可能對那些幾乎不更新的圖片很有好處,特別是對于一組都引用相同圖片的相關(guān)文檔。

緩存優(yōu)化對企業(yè)來說是至關(guān)重要了的,不同的公司類型,緩存的類型和時間又各不相同,大家具體可以用YSlow對淘寶,京東,新浪,谷歌等站點進(jìn)行測試,看看他們的緩存時間是多少,并思考下為什么那樣設(shè)置。

雖然緩存的設(shè)置有如下優(yōu)點

1.縮短服務(wù)的響應(yīng)時間

2.減輕服務(wù)器負(fù)擔(dān)

3.減少網(wǎng)絡(luò)帶寬使用量,降低企業(yè)成本

但是他的缺點也是顯而易見的,由于使用了緩存設(shè)置,導(dǎo)致被緩存的內(nèi)容更新了,但是客戶看到的卻還是舊的。

如何解決被緩存文件及時更新這個問題呢?

第一種:縮短緩存時間例如:1天,不徹底犧牲性能

第二種:對緩存的對象改名。

九、啟用worker模式,提升并發(fā)數(shù)(可以達(dá)到2000-5000)

apache有兩個模式,默認(rèn)的模式是prefork模式。那么我們?yōu)槭裁匆褂脀orker模式呢?這兩種模式又有什么區(qū)別呢?

1、prefork模式

prefork使用的是多個子進(jìn)程,而每個子進(jìn)程只有一個線程,每個進(jìn)程在某個確定的時間只能維持一個連接。

工作原理:控制進(jìn)程最初建立若干個子進(jìn)程,為了不在請求到來時再生成子進(jìn)程,所以要根據(jù)需求不斷的創(chuàng)建新的子進(jìn)程,最大可以達(dá)到每秒32個直到滿足需求為止。

安裝方法:在編譯的過程中,加入?yún)?shù)--with-mpm=frefork,不加也可以,因為默認(rèn)的話,會采用prefork模式。

優(yōu)點:效率高,穩(wěn)定,安全。對于線程調(diào)試?yán)щy的平臺來說,調(diào)試更加容易些。

缺點:與worker模式相比消耗資源多。

配置參數(shù)說明:

StartServers 5 #最初建立的子進(jìn)程

MinSpareServers 5 #最小空閑進(jìn)程數(shù),如果空閑的進(jìn)程小于設(shè)定值,Apache會自動建立進(jìn)程,如果服務(wù)器并發(fā)及負(fù)載大的話,可以考慮加大。

MaxSpareServers 10 #最大空閑進(jìn)程數(shù),如果空閑的進(jìn)程大于設(shè)定值,Apache會自動kill掉多余的進(jìn)程,如果服務(wù)器負(fù)載大的話,可以考慮加大。

MaxClients 150 #設(shè)定的是apache可以同時處理的請求,是對apache性能影響最大的參數(shù),就是apache可以同時處理的請求數(shù),就是說,如果有150個用戶在訪問,那么第151個用戶就要等之前的訪問結(jié)束后才能訪問。

MaxRequestsPerChild 0 #每個子進(jìn)程可處理的請求數(shù),每個子進(jìn)程在處理了“MaxRequestsPerChild”個請求后將自動銷毀。0以為著無限,即子進(jìn)程永不銷毀。雖然缺省設(shè)為0可以使每個子進(jìn)程處理更多的請求,但如果設(shè)置成非0值也有兩點重要的好處。(1)可防止意外的內(nèi)存泄露(2)在服務(wù)器負(fù)載下載的時候會自動減少子進(jìn)程數(shù)。

生產(chǎn)環(huán)境配置實例1:

StartServers 10

MinSpareServers 10

MaxSpareServers 15

ServerLimit 2000

MaxClients 1000

MaxRequestsPerChild 5000

2、worker模式

worker模式是apche2.x新引進(jìn)來的模式,是線程與進(jìn)程的結(jié)合,在worker模式下會有多個子進(jìn)程,每個子進(jìn)程又會有多個線程。每個線程在某個確定的時間只能維持一個連接。

工作原理:由主控制進(jìn)程生成若干個子進(jìn)程,而每個子進(jìn)程中又包含固定的線程數(shù),各個線程獨立處理請求,同樣為了不在請求到來時再生成線程,在配置文件中設(shè)置了最小和最大的空閑線程數(shù)及所有子進(jìn)程中的線程總數(shù),如果現(xiàn)有子進(jìn)程中的線程總數(shù)不能滿足并發(fā)及負(fù)載,控制進(jìn)程將派生新的子進(jìn)程。



關(guān)鍵詞:

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉