由於該配置也使用location板塊,因此本節可結合日誌管理一塊兒配置:php
[root@1 ~]# vim /usr/local/nginx/conf/vhost/test.com.conf …… location ~* ^.+\.(gif|jpg|png|swf|flv|rar|zip|doc|pdf|gz|bz2|jpeg|bmp|xls)$ { expires 7d; valid_referers none blocked server_names *.test.com ; #定義referer白名單 if ($invalid_referer) { return 403; #if函數的意思是:若是不是白名單內的域名,返回值:403 } access_log off; } …… [root@1 ~]# /usr/local/nginx/sbin/nginx -t nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful [root@1 ~]# /usr/local/nginx/sbin/nginx -s reload
說明: 「location ~* ^.+」在此0「 * 」的做用是後面匹配的內容不區分大小寫。html
[root@1 ~]# curl -e "http://www.baidu.com/1.txt" -x127.0.0.1:80 -I test.com/baidu.png HTTP/1.1 403 Forbidden Server: nginx/1.12.1 Date: Mon, 14 Aug 2017 06:22:36 GMT Content-Type: text/html Content-Length: 169 Connection: keep-alive
即,使用非白名單內的referer進行訪問,被拒絕!!!linux
需求:訪問/admin/目錄的請求,只容許幾個指定IP經過,配置以下:nginx
[root@1 ~]# vim /usr/local/nginx/conf/vhost/test.com.conf …… location /admin/ { allow 192.168.8.132; allow 127.0.0.1; deny all; #設置IP白名單 } …… [root@1 ~]# /usr/local/nginx/sbin/nginx -t nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful [root@1 ~]# /usr/local/nginx/sbin/nginx -s reload
建立上面指定的目錄:web
[root@1 ~]# mkdir /data/wwwroot/test.com/admin [root@1 ~]# echo 「test,test」>/data/wwwroot/test.com/admin/1.html
[root@1 ~]# curl -x127.0.0.1:80 test.com/admin/1.html 「test,test」 [root@1 ~]# curl -x192.168.8.132:80 test.com/admin/1.html 「test,test」
location ~ .*(abc|image)/.*\.php$ { deny all; }
if ($http_user_agent ~ 'Spider/3.0|YoudaoBot|Tomato') { return 403; }
說明: deny all和return 403效果同樣vim
核心配置:服務器
vim /usr/local/nginx/conf/vhost/test.com.conf …… location ~ \.php$ { include fastcgi_params; #fastcgi_pass 127.0.0.1:9000 fastcgi_pass unix:/tmp/php-fcgi.sock; ##fastcgi_pass兩種監聽格式,可是要保證Nginx和php-fpm中格式一致 fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /data/wwwroot/test.com$fastcgi_script_name; } ……
注: 在此注意兩點,fastcgi_pass有兩種格式,可是不管使用哪一種格式都有保證Nginx和php-fpm中格式一致,不然會報錯502;fastcgi _param SCRIPT _FILENAME所在行的路徑要和root路徑一致!網絡
Nginx代理是一種反向代理。反向代理(Reverse Proxy)方式是指以代理服務器來接受Internet上的鏈接請求,而後將請求轉發給內部網絡上的服務器;並將從服務器上獲得的結果返回給Internet上請求鏈接的客戶端,此時代理服務器對外就表現爲一個服務器。app
Nginx代理是在一臺代理服務器中自定義一個域名,該域名指向一個IP,而後將用戶的請求經過這臺代理服務器訪問指定的IP所對應的web服務器。curl
graph LR 用戶-->代理服務器 代理服務器-->用戶 代理服務器-->web服務器 web服務器-->代理服務器
進入虛擬主機目錄:
[root@1 ~]# cd /usr/local/nginx/conf/vhost/
[root@1 vhost]# vim proxy.conf server { listen 80; server_name ask.apelearn.com; #定義域名(通常和被代理ip的域名保持一致) location / { proxy_pass http://121.201.9.155/; #指定被代理(被訪問)的IP(web服務器IP) proxy_set_header Host $host; #$host指的是代理服務器的servername(也是被代理IP的域名) proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }
說明: 由於該虛擬主機只用做代理服務器,不須要訪問本地文件,因此不須要設置根目錄。
[root@1 vhost]# curl -x127.0.0.1:80 ask.apelearn.com/robots.txt <html> <head><title>404 Not Found</title></head> <body bgcolor="white"> <center><h1>404 Not Found</h1></center> <hr><center>nginx/1.12.1</center> </body> </html>
[root@1 vhost]# /usr/local/nginx/sbin/nginx -t nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful [root@adailinux vhost]# /usr/local/nginx/sbin/nginx -s reload [root@1 vhost]# curl -x127.0.0.1:80 ask.apelearn.com/robots.txt # # robots.txt for MiWen # User-agent: * Disallow: /?/admin/ Disallow: /?/people/ Disallow: /?/question/ Disallow: /account/ Disallow: /app/ Disallow: /cache/