Linux 运维 11月28日 笔记 12.13-12.16

目录 

一、Nginx防盗链
二、Nginx访问控制
三、Nginx解析php相关配置
四、Nginx代理

扩展
502问题汇总 http://ask.apelearn.com/question/9109
location优先级 http://blog.lishiming.net/?p=100

Nginx防盗链

vi /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 ;

    if ($invalid_referer) {

        return 403;

    }

    access_log off;

}

-t && -reload

测试

curl -e "http://www.baidu.com/1.txt" -x127.0.0.1:80 -I test.com/1.gif

7159357d2744a5a932498edeeb8adffcc65.jpg

 

Nginx访问控制

需求:访问/admin/目录的请求,只允许某几个IP访问,配置如下:

vi /usr/local/nginx/conf/vhost/test.com.conf

location /admin/

{

    allow 192.168.78.128;

    allow 127.0.0.1;

    deny all;

}

只要匹配,就不再做其他匹配

mkdir /data/wwwroot/test.com/admin/

echo “test,test”>/data/wwwroot/test.com/admin/1.html

-t && -s reload

测试

curl -x127.0.0.1:80 test.com/admin/1.html -I

0521039e017b1e2b6c280944b963ed03bc2.jpg

curl -x192.168.31.129:80 test.com/admin/1.html -I

8f680983f15a62a13818611cf43ea6a5630.jpg

查看log

e8d85b8ac0e8a252f26f4ab469ecc956fc5.jpg

可以匹配正则  

location ~ .*(upload|image)/.*\.php$

{

        deny all;

}

(禁止解析PHP)

测试

mkdir /data/wwwroot/test.com/upload

echo "1111" > /data/wwwroot/test.com/upload/1.php

curl  -x127.0.0.1:80 test.com/upload/1.php

2f553cbbf65f2d168b2e18cc2a31f7fe124.jpg

根据user_agent限制

if ($http_user_agent ~ 'Spider/3.0|YoudaoBot|Tomato')    ~*忽略大小写

{

      return 403;

}

deny all和return 403效果一样

做一个隐藏的网站,禁掉蜘蛛

测试

curl -A "Tomatoasdlkfjsdlf" -x127.0.0.1:80 test.com/upload/1.txt -I

415c7ac9b8c5f0e7712fa6924e93973ec8d.jpg

 

Nginx解析php相关配置

配置如下:

location ~ \.php$

    {

        include fastcgi_params;

        fastcgi_pass unix:/tmp/php-fcgi.sock;

        fastcgi_index index.php;

        fastcgi_param SCRIPT_FILENAME /data/wwwroot/test.com$fastcgi_script_name;

    }

fastcgi_pass 用来指定php-fpm监听的地址或者socket

修改 fastcgi_pass unix:/tmp/php-fcgi.sock;  为fastcgi_pass unix:/tmp/php-cgi.sock

curl -x127.0.0.1:80 test.com/3.php

9ecfef185a6d4d74412e475ad46c4460d23.jpg

出现502错误

查看nginx_error log

tail /usr/local/nginx/logs/nginx_error.log

10de001ed4e2b44447340c45d4a735fd7bd.jpg

查看php-fpm配置文件

cat /usr/local/php-fpm/etc/php-fpm.conf

8ae987e4512a02f8beeaa97642355319511.jpg

nginx和php-fpm要对应

SCRIPT_FILENAME /data/wwwroot/test.com 要和root对应起来

548905f454bc566a5fde08cc348e1a91366.jpg

listen.mode = 666 不配置 默认440

a94dcd6da7bd447587f40bfe4745cb68c04.jpg

重启php-fpm

/etc/init.d/php-fpm reload or /etc/init.d/php-fpm restart

b9231bac1379ac9f8ad9ec30db13e0c0b23.jpg

6b037ab0091c6490f3ee77b294c0c2eef5a.jpg

php-rpm进程耗尽也会出现502

 

Nginx代理

3f4974b4b35fc523f635ff38386e3dbe07b.jpg

cd /usr/local/nginx/conf/vhost

vim proxy.conf //加入如下内容

server

{

    listen 80;

    server_name ask.apelearn.com;

    location /

    {

        proxy_pass      http://223.94.95.10/;

        proxy_set_header Host   $host;              $host就是sever name

        proxy_set_header X-Real-IP      $remote_addr;

        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    }

}

 

3b387925ddd746241955fc4ef9b74203c4e.jpg

0272953844a91f6873e9deabae48528b498.jpg

 

 

转载于:https://my.oschina.net/u/3959701/blog/2962759

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值