真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何深度優(yōu)化Apache-創(chuàng)新互聯(lián)

如何深度優(yōu)化Apache,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

創(chuàng)新互聯(lián)公司是一家專注于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),五臺(tái)網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:五臺(tái)等地區(qū)。五臺(tái)做網(wǎng)站價(jià)格咨詢:13518219792

一、Apache的gzip(deflate)功能

gzip可以極大的加速網(wǎng)站,使用gzip功能有時(shí)壓縮比率高到80%以上,最少都有40%以上,所以說(shuō)gzip功能是非常強(qiáng)大的,還是不錯(cuò)的。

在Apache2之后的版本,模塊名不叫g(shù)zip,而叫mod_deflate

未使用gzip時(shí),網(wǎng)頁(yè)中傳輸文件的過(guò)程,如圖:
如何深度優(yōu)化Apache

使用gzip時(shí),網(wǎng)頁(yè)中傳輸文件的過(guò)程,如圖:
如何深度優(yōu)化Apache

本次博文案例環(huán)境,可以參考博文:Apache的安裝部署及工作模式詳解

如果要使用gzip(deflate)的功能,一定要打開兩個(gè)模塊:

LoadModule deflate_module  modules/mod_deflate.so
//模塊的作用:對(duì)傳輸?shù)娇蛻舳说拇a進(jìn)行g(shù)zip壓縮
LoadModule headers_module modules/mod_headers.so
//模塊的作用:告訴客戶端的瀏覽器,傳輸?shù)奈募褂昧薵zip壓縮。如果不開啟的話,則無(wú)法正常顯示網(wǎng)頁(yè)內(nèi)容
[root@localhost ~]# apachectl -M | grep deflate
//檢查mod_deflate模塊是否安裝,如果沒(méi)有任何返回信息則表示沒(méi)有安裝

安裝方法有兩種:

  • 編譯時(shí)添加“--enable-deflate”選項(xiàng)即可安裝;

  • 使用DSO方式進(jìn)行安裝;

本身Apache已經(jīng)安裝完成,所以這里就是用DSO方式進(jìn)行安裝了

[root@localhost ~]# cd /usr/src/httpd-2.4.23/modules/filters/
//切換到Apache源碼包mod_deflate所在的目錄下
[root@localhost filters]#  /usr/local/http-2.4.23/bin/apxs -c -i -a mod_deflate.c
//使用apxs命令進(jìn)行安裝

apxs命令參數(shù)的解釋:

  • -i:表示需要執(zhí)行安裝操作,以安裝一個(gè)或多個(gè)動(dòng)態(tài)共享對(duì)象到服務(wù)器的modules目錄中;

  • -a:表示會(huì)自動(dòng)增加一個(gè) LoadModule 行到 httpd.conf 文件中,以啟用此模塊,或者,如果 此行已經(jīng)存在,則啟用之;

  • -c:表示需要執(zhí)行編譯操作。

在安裝過(guò)程中會(huì)出現(xiàn)這樣的錯(cuò)誤信息,如圖:
如何深度優(yōu)化Apache
這樣的錯(cuò)誤信息即表示缺少zlib-devel的安裝包,使用“yum -y install zlib-devel”即可,再次重新安裝mod_deflate模塊!

[root@localhost filters]# ll /usr/local/http-2.4.23/modules/mod_deflate.so 
-rwxr-xr-x. 1 root root 98160 11月 22 18:53 /usr/local/http-2.4.23/modules/mod_deflate.so
//確認(rèn)文件已經(jīng)存在

檢查Apache主配置文件出現(xiàn)以下情況:

[root@localhost ~]# apachectl -t
httpd: Syntax error on line 104 of /usr/local/http-2.4.23/conf/httpd.conf: Cannot load modules/mod_deflate.so into server: /usr/local/http-2.4.23/modules/mod_deflate.so: undefined symbol: inflate

解決方法:

需要在Apache主配置文件的 LoadModule deflate_module modules/mod_deflate.so 這行的上一行添加LoadFile /usr/local/zlib/lib/libz.so
即可,如圖:
如何深度優(yōu)化Apache

[root@localhost ~]# apachectl -t
Syntax OK                  //檢查其配置文件沒(méi)有錯(cuò)誤
[root@localhost ~]# apachectl restart         
//重新啟動(dòng)Apache服務(wù)

接下來(lái)修改Apache主配置文件,使其開啟gzip壓縮傳輸功能:

LoadModule deflate_module  modules/mod_deflate.so
//這個(gè)模塊的作用:對(duì)傳輸?shù)娇蛻舳说拇a進(jìn)行g(shù)zip壓縮
LoadModule headers_module modules/mod_headers.so
//這個(gè)模塊的作用:告訴客戶端的瀏覽器,傳輸?shù)奈募褂昧薵zip壓縮。如果不開啟的話,則無(wú)法正常顯示網(wǎng)頁(yè)內(nèi)容
//查看Apache主配置文件必須保證這兩個(gè)模塊已經(jīng)被啟用

在Apache主配置文件中(個(gè)人建議在末尾)添加如下內(nèi)容:

           //表示需要啟用mod_deflate模塊
DeflateCompressionLevel 9        //壓縮程度的等級(jí)
SetOutputFilter DEFLATE           //設(shè)置輸出過(guò)濾器,對(duì)輸出啟用壓縮功能
AddOutputFilterByType DEFLATE text/*          //設(shè)置對(duì)文件是文本格式的進(jìn)行壓縮
SetEnvIfNoCase Reques t_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary      
//設(shè)置不對(duì)后綴為 gif,jpg,jpeg,png 的圖片文件進(jìn)行壓縮。?:表示不會(huì)捕獲 ( )里內(nèi)容了 


//以下內(nèi)容是設(shè)置日志輸出
DeflateFilterNote Input input_info                //聲明輸入流的 byte 數(shù)量 
DeflateFilterNote Output output_info           //聲明輸出流的 byte 數(shù)量 
DeflateFilterNote Ratio ratio_info                //聲明壓縮的百分比 
LogFormat '"%r" %{output_info}n/%{input_info}n (%{ratio_info}n%%)' deflate           //聲明日志格式 
CustomLog logs/deflate_log.log deflate          //指定日志的存放路徑

考慮到粘貼復(fù)制的問(wèn)題,這里附上Apache文件中添加的內(nèi)容(不帶注釋)


DeflateCompressionLevel 9
SetOutputFilter DEFLATE
AddOutputFilterByType DEFLATE text/*
SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary


DeflateFilterNote Input input_info
DeflateFilterNote Output output_info
DeflateFilterNote Ratio ratio_info
LogFormat '"%r" %{output_info}n/%{input_info}n (%{ratio_info}n%%)' deflate
CustomLog logs/deflate_log.log deflate

修改完成之后,重新啟用Apache服務(wù),并使用瀏覽器進(jìn)行測(cè)試(使用F12開啟開發(fā)者模式,并使用F5進(jìn)行刷新),如圖:
如何深度優(yōu)化Apache

[root@localhost ~]# cat /usr/local/http-2.4.23/logs/deflate_log.log
//查看deflate的日志(日志路徑在配置文件中已經(jīng)定義)
"GET / HTTP/1.1" -/- (-%)
"GET /favicon.ico HTTP/1.1" -/- (-%)
"GET / HTTP/1.1" -/- (-%)
"GET / HTTP/1.1" 76/4725 (1%)
"GET / HTTP/1.1" 76/4725 (1%)   //可以看出壓縮比例達(dá)到了99%
"-" -/- (-%)

注意:圖片是不需要被壓縮的,flash的swf文件也是不用壓縮的(這兩個(gè)東西壓縮之后會(huì)出現(xiàn)意想不到的效果)

二、Apache的緩存設(shè)置

Apache的緩存設(shè)置主要依賴于 mod_expires 模塊 ,啟用模塊后,可以減少20%~30%左右的重復(fù)請(qǐng)求,讓重復(fù)的用戶請(qǐng)求結(jié)果都緩存在本地。注意更新快的文件不要這么做。

mod_expires模塊控制服務(wù)器應(yīng)答時(shí)的 Expires 頭內(nèi)容和 Cache-Control 頭的 max-age 指令。有效期 (expiration date)可以設(shè)置為相對(duì)于源文件的最后修改時(shí)刻或者客戶端的訪問(wèn)時(shí)刻。

未啟用 mod_expires模塊expire緩存的效果:
如何深度優(yōu)化Apache

啟用mod_expires模塊expire緩存,方法如下:

LoadModule expires_module modules/mod_expires.so 
//查看Apache的主配置文件,必要要保證這個(gè)模塊被啟用

然后在Apache主配置文件末尾添加以下內(nèi)容:

             //表示啟用expires模塊
ExpiresActive On                             //啟用expires功能
ExpiresByType text/html "access plus 2 minute"         
//設(shè)置后綴為html的文本文件保存時(shí)間為兩分鐘
ExpiresByType image/jpeg "access plus 1 mouth"        
//設(shè)置后綴為jpeg的圖片信息保存時(shí)間為一個(gè)月
ExpiresDefault "now plus 0 minute"
//其他默認(rèn)沒(méi)有被定義的不進(jìn)行緩存

不帶注釋的配置文件:


ExpiresActive On
ExpiresByType text/html "access plus 2 minute"
ExpiresByType image/jpeg "access plus 1 mouth"
ExpiresDefault "now plus 0 minute"

測(cè)試效果如下:
如何深度優(yōu)化Apache
如何深度優(yōu)化Apache

緩存機(jī)制的配置格式:

ExpiresByType type/encoding " [plus] {}"
ExpiresDefault " [plus] {}"

1、其中是下列之一:
access(相對(duì)于客戶端訪問(wèn)的時(shí)間)
now(相當(dāng)于access)
modification(相對(duì)于最后一次修改源文件后的緩存時(shí)間)
2、該plus關(guān)鍵字是可選的。num 應(yīng)該是整數(shù)值,并且type是以下之一:
years
months
weeks
days
hours
minutes
seconds

也可以使用以下格式來(lái)定義緩存機(jī)制:

ExpiresByType image/jpeg A2592000   //表示圖片的緩存是1個(gè)月
ExpiresByType text/html M604800    //表示HTML文檔的有效期是最后修改時(shí)刻后的一星期
//"M"表示源文件的最后修改時(shí)刻,"A"表示客戶端對(duì)源文件的訪問(wèn)時(shí)刻。后面的時(shí)間則以秒計(jì) 算。

具體介紹可以參考官方文檔

三、Apache禁止目錄遍歷

訪問(wèn)Apache時(shí),默認(rèn)訪問(wèn)的時(shí)Apache網(wǎng)頁(yè)根目錄下的index.html,如何這個(gè)文件不存在的話,就會(huì)出現(xiàn)以下情況:
如何深度優(yōu)化Apache
為了防止出現(xiàn)以上情況需要修改Apache的配置文件:
如何深度優(yōu)化Apache
重新啟動(dòng)服務(wù)之后,就會(huì)出現(xiàn)這種情況:
如何深度優(yōu)化Apache

四、Apache隱藏版本目錄

不進(jìn)行修改,默認(rèn)的版本信息:
如何深度優(yōu)化Apache
這樣輕易的出現(xiàn)在互聯(lián)網(wǎng)上,顯然是不安全的??梢酝ㄟ^(guò)以下操作進(jìn)行優(yōu)化處理,方法如下:

在Apache主配置文件中啟用 httpd-default.conf 
Include conf/extra/httpd-default.conf 
//去除之前的#號(hào)
[root@localhost ~]# vim /usr/local/http-2.4.23/conf/extra/httpd-default.conf 
//找到
ServerTokens Full 
ServerSignature On
//修改為以下內(nèi)容
ServerTokens Prod
ServerSignature Off

重新啟動(dòng)服務(wù)之后,再次進(jìn)行查看:
如何深度優(yōu)化Apache

如果需要徹底的改變版本之類的信息,那么需要在編譯之前,修改源碼包下 include 目錄下的 ap_release.h 。

[root@localhost ~]# vim /usr/src/httpd-2.4.23/include/ap_release.h 
//這是本人的解壓路徑,各位根據(jù)實(shí)際情況
//修改的內(nèi)容如下:
#define AP_SERVER_BASEVENDOR "Apache Software Foundation" //服務(wù)的供應(yīng)商名稱
#define AP_SERVER_BASEPROJECT "Apache HTTP Server"  //服務(wù)的項(xiàng)目名稱
#define AP_SERVER_BASEPRODUCT "Apache" //服務(wù)的產(chǎn)品名
#define AP_SERVER_MAJORVERSION_NUMBER 2 //主要版本號(hào)
#define AP_SERVER_MINORVERSION_NUMBER 4 //小版本號(hào)
#define AP_SERVER_PATCHLEVEL_NUMBER 23 //補(bǔ)丁級(jí)別
#define AP_SERVER_DEVBUILD_BOOLEAN 0 
//上述行無(wú)需將行首的“#”號(hào)刪除

根據(jù)注釋修改成自己想要的,編譯安裝即可!

五、Apache日志分割

隨著網(wǎng)站的訪問(wèn)量越來(lái)越大,產(chǎn)生的日志文件也就會(huì)越來(lái)越大,如果不對(duì)日志進(jìn)行分隔處理,日志文件會(huì)越存越大,不易備份,而且只能一次性將Apache的日志全部刪除,這樣就會(huì)丟失很多對(duì)網(wǎng)站寶貴的信息,因此管理好這些海量的日志對(duì)網(wǎng)站來(lái)說(shuō)十分重要。

對(duì)日志進(jìn)行分隔處理可以通過(guò)以下兩種方法:

方法 1:使用 rotatelogs(apache 自帶的工具)每隔一天記錄一個(gè)日志
修改Apache的主配置文件,更改內(nèi)容如下:
//找到以下兩行,進(jìn)行注釋:
ErrorLog logs/error_log 
CustomLog logs/access_log common 
//然后最好在CustomLog "logs/access_log" common配置的下一行添加如下內(nèi)容(以下內(nèi)容不可以直接復(fù)制,請(qǐng)看下面的解釋):
ErrorLog "|/usr/local/http-2.4.23/bin/rotatelogs -l logs/error_%Y-%m-%d.log 86400"
CustomLog "|/usr/local/http-2.4.23/bin/rotatelogs -l logs/access_%Y-%m-%d.log 86400" combined
//這里是要填寫rotatelogs工具的絕對(duì)路徑

在上面添加的內(nèi)容中,86400為輪轉(zhuǎn)的時(shí)間,單位是秒(也就是一天生成一個(gè)日志文件)。

[root@localhost ~]# systemctl restart httpd
//重啟Apache服務(wù)
[root@localhost ~]# ls /usr/local/http-2.4.23/logs/
access_2019-11-23.log  access_log  error_2019-11-23.log  error_log  httpd.pid
//查看日志文件,第一次可能只會(huì)出現(xiàn)錯(cuò)誤日志,訪問(wèn)一下,訪問(wèn)日志即可產(chǎn)生

這樣就已經(jīng)實(shí)現(xiàn)了日志按天進(jìn)行分割存放!

由于 apache 自帶的日志輪詢工具 rotatelogs,據(jù)說(shuō)在進(jìn)行日志切割時(shí)容易丟日志,因此我們通常使用 cronolog (也就是方法2)進(jìn)行日志輪詢。

方法2:使用cronolog為每一天建立一個(gè)新的日志
同樣也是在Apache的主配置文件中注釋掉以下兩行:
ErrorLog "logs/error_log"
CustomLog "logs/access_log" common

下載cronolog源碼包

[root@localhost ~]# tar zxf cronolog-1.6.2.tar.gz -C /usr/src
[root@localhost ~]# cd /usr/src/cronolog-1.6.2/
[root@localhost cronolog-1.6.2]#  ./configure && make && make install
//解壓之后進(jìn)行編譯安裝
[root@localhost ~]# vim /usr/local/http-2.4.23/conf/httpd.conf 
//編輯Apache的主配置文件
//將方法1中寫入的日志切割配置項(xiàng)刪除,寫入下面的兩行配置
    CustomLog "|/usr/local/sbin/cronolog logs/access-%Y-%m-%d.log" combined
    ErrorLog "|/usr/local/sbin/cronolog logs/error-%Y-%m-%d.log"
//同樣這里寫的也是cronolog工具的絕對(duì)路徑
為了更好的進(jìn)行測(cè)試,建議將原本的日志文件進(jìn)行刪除、移動(dòng)操作
[root@localhost ~]# rm -rf /usr/local/http-2.4.23/logs/*log
[root@localhost ~]# ls /usr/local/http-2.4.23/logs/
httpd.pid
[root@localhost ~]# ls /usr/local/http-2.4.23/logs/
access-2019-11-23.log  error-2019-11-23.log  httpd.pid
//測(cè)試訪問(wèn)一下,訪問(wèn)日志和錯(cuò)誤日志即可產(chǎn)生

這樣就已經(jīng)實(shí)現(xiàn)了日志按天進(jìn)行分割存放!

如果 Apache 中有多個(gè)虛擬主機(jī),最好每個(gè)虛擬主機(jī)中放置一個(gè)這樣的代碼,并將日志文件名改成不同的名字。

如果網(wǎng)站的訪問(wèn)實(shí)在太大,也可以進(jìn)行按小時(shí)分隔,方法如下:
基于第二種方法實(shí)現(xiàn):

[root@localhost ~]# vim /usr/local/http-2.4.23/conf/httpd.conf 
//將原本的兩行配置內(nèi)容修改如下:
    CustomLog "|/usr/local/sbin/cronolog logs/access-%Y-%m-%d.log.%H" combined
    ErrorLog "|/usr/local/sbin/cronolog logs/error-%Y-%m-%d.log.%H"
//就是在原本的配置上添加了“%H”表示按小時(shí)進(jìn)行分隔
[root@localhost ~]# systemctl restart httpd
//重啟Apache服務(wù)

自行進(jìn)行測(cè)試訪問(wèn),接下來(lái)查看日志文件,如圖:
如何深度優(yōu)化Apache

生產(chǎn)環(huán)境下,常用方法:

按天輪詢:
CustomLog "|/usr/local/sbin/cronolog logs/access_www_%Y%m%d.log" combined 
按小時(shí)輪詢:
CustomLog "|/usr/local/sbin/cronolog logs /access_www_ %Y%m%d%H.log" combined

注意: 這兩個(gè)管道日志文件程序還有一點(diǎn)不同之處是使用 cronolog 時(shí)如果日志是放在某個(gè)不存 在的路徑則會(huì)自動(dòng)創(chuàng)建目錄,而使用 rotatelogs 時(shí)不能自動(dòng)創(chuàng)建,這一點(diǎn)要特別注意 !

六、配置防盜鏈

有時(shí)候會(huì)突然發(fā)現(xiàn)網(wǎng)站的訪問(wèn)量越來(lái)越,千萬(wàn)不要高興的太早,很有可能是被別人盜鏈了。打個(gè)比方說(shuō):你自己搭建了一個(gè)視頻網(wǎng)站,然后別人將他網(wǎng)站上的視頻的地址重定向到你的服務(wù)器上。這樣你的網(wǎng)站訪問(wèn)量就會(huì)越來(lái)越大,消耗的資源也就越來(lái)越多!如何避免這種可能的發(fā)生,那么就需要使用防盜鏈。

方法1:使用rewrite模塊實(shí)現(xiàn)
首先要確認(rèn)Apache的rewrite module模塊已經(jīng)安裝,可用:
[root@localhost ~]# apachectl -M | grep rewrite
 rewrite_module (shared)

接下來(lái)編寫Apache的主配置文件

[root@localhost ~]# vim /usr/local/http-2.4.23/conf/httpd.conf
LoadModule rewrite_module modules/mod_rewrite.so          //找到這一行,默認(rèn)是注釋的,將#號(hào)刪除即可
……………………
                //以下內(nèi)容必須寫在網(wǎng)站的根目錄下
    RewriteEngine On
    RewriteCond %{HTTP_REFERER} !^$
    RewriteCond %{HTTP_REFERER} !^http://192.168.1.1/.*$ [NC]
    RewriteRule .*\.(gif|jpg|swf)$ http://192.168.1.1/about/error.png [R,NC,L]

添加的內(nèi)容相關(guān)解釋:

  • RewriteEngine On       //啟用rewrite(地址重定向)功能,必須填寫;

  • RewriteCond %{HTTP_REFERER} !^$      //允許用戶在瀏覽器直接測(cè)試訪問(wèn)

  • RewriteCond %{HTTP_REFERER} !^http://192.168.1.1/.*$ [NC]      //允許通過(guò)192.168.1.1的地址進(jìn)行訪問(wèn)

  • RewriteRule .*.(gif|jpg|swf)$ http://192.168.1.1/about/error.png [R,NC,L]   //將不滿足以上策略的、后綴名為gif、jpg、swf的文件全部重定向到網(wǎng)頁(yè)根目錄的about目錄中的error.png,要相當(dāng)注意,about目錄下的error.png文件存在,不然,警告信息和圖片將無(wú)法在對(duì)方網(wǎng)站上顯示。

詳細(xì)介紹如圖:
如何深度優(yōu)化Apache
如何深度優(yōu)化Apache
注意:測(cè)試時(shí)要清除瀏覽器緩存
下面進(jìn)行測(cè)試:
實(shí)驗(yàn)環(huán)境有192.168.1.1(A)網(wǎng)站服務(wù)器和192.168.1.2(B)網(wǎng)站服務(wù)器,配置如下:
A服務(wù)器:

[root@localhost ~]# apachectl -M | grep rewrite
 rewrite_module (shared)
[root@localhost ~]# vim /usr/local/http-2.4.23/conf/httpd.conf
LoadModule rewrite_module modules/mod_rewrite.so          //找到這一行,默認(rèn)是注釋的,將#號(hào)刪除即可
……………………
                //以下內(nèi)容必須寫在網(wǎng)站的根目錄下
    RewriteEngine On
    RewriteCond %{HTTP_REFERER} !^$
    RewriteCond %{HTTP_REFERER} !^http://192.168.1.1/.*$ [NC]
    RewriteRule .*\.(gif|jpg|swf)$ http://192.168.1.1/about/error.png [R,NC,L]

[root@localhost ~]# ll /usr/local/http-2.4.23/htdocs/
總用量 64
drwxr-xr-x. 2 root root    23 11月 25 14:45 about
-rw-r--r--. 1 root root 60108 11月 24 10:02 access.jpg              //確保文件存在
-rw-r--r--. 1 root root    45 6月  12 2007 index.html
[root@localhost ~]# ll /usr/local/http-2.4.23/htdocs/about
總用量 236
-rw-r--r--. 1 root root 240595 11月 24 10:01 error.png                 //確保文件存在

[root@localhost ~]# apachectl restart              //重新啟動(dòng)httpd服務(wù)器

B服務(wù)器:

[root@localhost ~]# yum -y install httpd
//為了方便 起見,使用yum的方式安裝httpd服務(wù)
[root@localhost ~]# vim /var/www/html/index.html
鏈接
//手動(dòng)安裝的httpd的主頁(yè)文件做一個(gè)超鏈接連接到A服務(wù)器的根目錄下的access.jpg
//訪問(wèn)時(shí)會(huì)出現(xiàn)一個(gè)鏈接的超鏈接

這樣當(dāng)客戶端訪問(wèn)B服務(wù)器時(shí)就會(huì)查看到error.png(訪問(wèn)的本意是訪問(wèn)access.jpg)
如何深度優(yōu)化Apache
如何深度優(yōu)化Apache

也可以讓客戶端的鏈接過(guò)來(lái)的時(shí)候訪問(wèn)到錯(cuò)誤頁(yè)面,方法如下:
修改A服務(wù)器的配置文件:

[root@localhost ~]# vim /usr/local/http-2.4.23/conf/httpd.conf 
……………………                      //省略部分內(nèi)容
    RewriteEngine On
    RewriteCond %{HTTP_REFERER} !^$
    RewriteCond %{HTTP_REFERER} !^http://192.168.1.1/.*$ [NC]
    #RewriteRule .*\.(gif|jpg|swf)$ http://192.168.1.1/about/error.png [R,NC,L]                 //將這條進(jìn)行注釋 
    RewriteRule .*\.(gif|jpg|png)$ - [F]                      //(強(qiáng)制 URL 為被禁止的 forbidden),強(qiáng)制當(dāng)前 URL 為被禁止的,即,立即反饋一 個(gè) HTTP 響應(yīng)代碼 403(被禁止的)
[root@localhost ~]# systemctl restart httpd
//重新啟動(dòng)httpd服務(wù)

再次訪問(wèn)就會(huì)出現(xiàn)這樣的情況:
注意清除瀏覽器緩存
如何深度優(yōu)化Apache
如何深度優(yōu)化Apache

這樣就證明了防盜鏈的作用!

方法 2:通過(guò)判斷瀏覽器頭信息來(lái)阻止請(qǐng)求

也就是利用 SetEnvIfNoCase 和 access。 這個(gè)方法可以通過(guò)阻止某些機(jī)器人或蜘蛛爬蟲抓取你的網(wǎng)站來(lái)節(jié)省你的帶寬流量。 語(yǔ)法: SetEnvIfNoCase attribute regex [!]env-variable[=value] [[!]env-variable[=value]] ... SetEnvIfNoCase 當(dāng)滿足某個(gè)條件時(shí),為變量賦值,即根據(jù)客戶端請(qǐng)求屬性設(shè)置環(huán)境變量。 注:Referer :指明了請(qǐng)求當(dāng)前資源原始資源的 URL,使用 referer 是可以防盜鏈 然后在找到自己網(wǎng)站對(duì)應(yīng)的配置的地方(如在主配置文件中或虛擬主機(jī)
中),加入下列代碼:

SetEnvIfNoCase Referer "^$" local_ref 
SetEnvIfNoCase Referer"^http://www.benet.com/.*$" local_ref
SetEnvIfNoCase Referer"^http://benet.com/.*$"local_ref

通過(guò)判斷referer變量的值,來(lái)判斷圖片或資源的引用是否合法,只有在根據(jù)配置符合設(shè)定需求范圍內(nèi)的referer,這樣的網(wǎng)站內(nèi)容,才能調(diào)用訪問(wèn)指定的資源內(nèi)容,從而實(shí)現(xiàn)了資源被網(wǎng)站盜鏈的目的。需要注意的是:是所有的用戶代理(瀏覽器)都會(huì)設(shè)置referer變量,而且有的還可以手工修改erferer,referer是可以被偽造的,上面的配置只是一種簡(jiǎn)單的防護(hù)手段。應(yīng)付一般的盜鏈足矣。
當(dāng)網(wǎng)站被盜鏈,一般可以采取以下措施:
對(duì)本站的圖片、視頻、音頻等文件標(biāo)上自己的站名品牌或者相關(guān)水印;
設(shè)置防火墻,從源頭IP進(jìn)行控制
設(shè)置防盜鏈(根據(jù)referer機(jī)制)
網(wǎng)站被非法盜鏈?zhǔn)褂?,?huì)導(dǎo)致網(wǎng)站帶寬成本加大以及服務(wù)器壓力加大,嚴(yán)重時(shí)會(huì)導(dǎo)致巨額的網(wǎng)站及正常用戶訪問(wèn)受到影響。

看完上述內(nèi)容,你們掌握如何深度優(yōu)化Apache的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


網(wǎng)站名稱:如何深度優(yōu)化Apache-創(chuàng)新互聯(lián)
當(dāng)前路徑:http://weahome.cn/article/dhpejh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部