当前位置:  操作系统/服务器>linux
本页文章导读:
    ▪nginx与apache在Rewrite规则方面的区别      1. Nginx Rewrite规则相关指令 Nginx Rewrite规则相关指令有if、rewrite、set、return、break等,其中rewrite是最关键的指令。 一个简单的Nginx Rewrite规则语法如下:   代码如下: rewrite ^/b/(.*)\.html /play.php?v.........
    ▪nginx通过限制IP请求数以防止CC攻击的方法介绍      本文介绍的内容适用于nginx服务器,如果需要通过自带防火墙限制请参考iptables防止CC攻击的文章。 编辑配置文件,在http段添加:   代码如下:  limit_req_zone  $binary_remote_addr  zone=req:10m   rat.........
    ▪nginx发布静态文件后图片显示不全      部署nginx时,通过mount方式挂NFS文件后,发现大图片在浏览器显示时不完整,原因在于nginx中启用了sendfile。 1、sendfile系统调用,文件数据被copy至内核缓冲区 2、再从内核缓冲区copy至内核中soc.........

[1]nginx与apache在Rewrite规则方面的区别
    来源: 互联网  发布时间: 2013-12-24

1. Nginx Rewrite规则相关指令
Nginx Rewrite规则相关指令有if、rewrite、set、return、break等,其中rewrite是最关键的指令。
一个简单的Nginx Rewrite规则语法如下:
 

代码如下:
rewrite ^/b/(.*)\.html /play.php?video=$1 break;

如果加上if语句,示例如下:
 

代码如下:
if (!-f $request_filename)
{ rewrite ^/img/(.*)$ /site/$host/images/$1 last;      }

2. Nginx与Apache的Rewrite规则实例对比
简单的Nginx和Apache 重写规则区别不大,基本上能够完全兼容。
Apache Rewrite 规则:
 

代码如下:
RewriteRule ^/(mianshi|xianjing)/$ /zl/index.php?name=$1 [L]
RewriteRule ^/ceshi/$ /zl/ceshi.php [L]
RewriteRule ^/(mianshi)_([a-zA-Z]+)/$ /zl/index.php?name=$1_$2 [L] RewriteRule ^/pingce([0-9]*)/$ /zl/pingce.php?id=$1 [L]

Nginx Rewrite 规则:
 

代码如下:
rewrite ^/(mianshi|xianjing)/$ /zl/index.php?name=$1 last;
rewrite ^/ceshi/$ /zl/ceshi.php last;
rewrite ^/(mianshi)_([a-zA-Z]+)/$ /zl/index.php?name=$1_$2 last;
rewrite ^/pingce([0-9]*)/$ /zl/pingce.php?id=$1 last;

不难发现Apache的Rewrite规则改为Nginx的Rewrite规则挺简单的,如果改完规则,使用"nginx -t"命令检查发现nginx.conf配置文件有语法错误,那么可以尝试给条件加上引号。例如一下的Nginx Rewrite规则会报语法错误:
rewrite  ^/([0-9]{5}).html$ /x.jsp?id=$1  last;加上引号就正确了:  
rewrite  “^/([0-9]{5}).html$” /x.jsp?id=$1  last;

Apache与Nginx的Rewrite规则在URL跳转时有细微的区别:
Apache Rewrite 规则:
 

代码如下:
RewriteRule  ^/html/tagindex/([a-zA-Z]+)/.*$ /$1/ [R=301,L]

Nginx Rewrite 规则:
 

代码如下:
rewrite  ^/html/tagindex/([a-zA-Z]+)/.*$ http://$host/$1/  permanent;

以上示例中,我们注意到,Nginx Rewrite 规则的置换串中增加了“http://$host”,这是在Nginx中要求的。
   
另外,Apache与Nginx的Rewrite规则在变量名称方面也有区别,例如:
Apache Rewrite 规则:
 

代码如下:
RewriteRule ^/user/login/$ /user/login.php?login=1&forward=http://%{HTTP_HOST}  [L]

Nginx Rewrite 规则:
rewrite  ^/user/login/$ /user/login.php?login=1&forward=http://$host  last;
Apache与Nginx Rewrite 规则的一些功能相同或类似的指令、标记对应关系:
Apache的RewriteCond指令对应Nginx的if指令;
Apache的RewriteRule指令对应Nginx的rewrite指令;
Apache的[R]标记对应Nginx的redirect标记;
Apache的[P]标记对应Nginx的last标记;
Apache的[R,L]标记对应Nginx的redirect标记;
Apache的[P,L]标记对应Nginx的last标记;
Apache的[PT,L]标记对应Nginx的last标记;

允许指定的域名访问本站,其他域名一律跳转到http://www.aaa.com:
 
Apache Rewrite 规则:
 

代码如下:
RewriteCond %{HTTP_HOST}    ^(.*?)\.domain\.com$
RewriteCond %{HTTP_HOST}    !^qita\.domain\.com$ RewriteCond %{DOCUMENT_ROOT}/market/%1/index.htm -f
RewriteRule ^/wu/$ /market/%1/index.htm [L]

Nginx的if指令不支持嵌套,也不支持AND、OR等多条件匹配,相比于Apache的RewriteCond,显得麻烦一些,但是,我们可以通过下一页的Nginx配置写法来实现这个示例:
Nginx Rewrite 规则:
 

代码如下:

if ($host ~* ^(.*?)\.domain\.com$)   
{
set $var_wupin_city $1;   
set $var_wupin ‘1′;   
}   

if ($host ~* ^qita\.domain\.com$)
{
set $var_wupin ‘0′;   
}
 
if (!-f $document_root/market/$var_wupin_city/index.htm)   
{
set $var_wupin ‘0′;   
}

if($var_wupin ~ ‘1′)   
{
rewrite ^/wu/$ /market/$var_wupin_city/index.htm last;   
}
 

备注:
rewrite ^/serach/(.*).html  http://www.xxx.com/search.action?keywords=$1 last;
访问http://www.xxx.com/search/mp3.html,浏览器url重定向为http://www.xxx.com/search.action?keywords=mp3


    
[2]nginx通过限制IP请求数以防止CC攻击的方法介绍
    来源: 互联网  发布时间: 2013-12-24

本文介绍的内容适用于nginx服务器,如果需要通过自带防火墙限制请参考iptables防止CC攻击的文章。
编辑配置文件,在http段添加:
 

代码如下:
 limit_req_zone  $binary_remote_addr  zone=req:10m   rate=2r/s;

#定义会话存储区,名字为reg,每秒1个请求
 
在server中添加:
 

代码如下:
location /path/ #限制的目录
{
limit_req_zone   zone=reg  burst=2; #突发最高每秒5个请求数
}

    
[3]nginx发布静态文件后图片显示不全
    来源: 互联网  发布时间: 2013-12-24

部署nginx时,通过mount方式挂NFS文件后,发现大图片在浏览器显示时不完整,原因在于nginx中启用了sendfile。
1、sendfile系统调用,文件数据被copy至内核缓冲区
2、再从内核缓冲区copy至内核中socket相关的缓冲区
3、最后再socket相关的缓冲区copy到协议引擎

相较传统read/write方式,2.1版本内核引进的sendfile已经减少了内核缓冲区到user缓冲区,再由user缓冲区到socket相关缓冲区的文件copy,而在内核版本2.4之后,文件描述符结果被改变,sendfile实现了更简单的方式,系统调用方式仍然一样,细节与2.1版本的不同之处在于,当文件数据被复制到内核缓冲区时,不再将所有数据copy到socket相关的缓冲区,而是仅仅将记录数据位置和长度相关的数据保存到socket相关的缓存,而实际数据将由DMA模块直接发送到协议引擎,再次减少了一次copy操作。

遇到的问题是,图片只显示了上面的一半。

对于一个通过网络挂载了NFS文件系统的root /webroot(比如:NFS或SMB),内核可能无法可靠的通过自己的缓冲区服务于网络文件。

因此,如果出现以上情况,建议禁用sendfile吧。

或许大家有更好的办法,欢迎进入官方QQ群:161228069 进行交流。


    
最新技术文章:
▪linux系统中的列出敏感用户的脚本代码
▪a10 config backup for aXAPI
▪一键备份gitolite服务器的Shell脚本
▪nagios 分发文件实现代码
▪阿里云云服务器Linux系统更新yum源Shell脚本
▪一个监控LINUX目录和文件变化的Shell脚本分享
▪Linux下实现SSH免密码登录和实现秘钥的管理、...
▪Shell正则表达式之grep、sed、awk实操笔记
▪3个备份系统文件并邮件发送的Shell脚本分享
▪CentOS 6.3下给PHP添加mssql扩展模块教程
▪监控网站是否可以正常打开的Shell脚本分享
▪shell脚本编程之if语句学习笔记
▪shell脚本编程之循环语句学习笔记
▪shell脚本编程之case语句学习笔记
▪Shell脚本实现的阳历转农历代码分享
▪Shell脚本实现复制文件到多台服务器的代码分...
▪Shell脚本实现批量下载网络图片代码分享
▪Shell脚本实现检测文件是否被修改过代码分享
▪Shell脚本数组用法小结
▪Shell脚本批量重命名文件后缀的3种实现
▪C语言实现的ls命令源码分享
▪Linux下查找后门程序 CentOS 查后门程序的shell脚...
▪Shell 函数参数
▪linux shell 自定义函数方法(定义、返回值、变...
▪Shell实现判断进程是否存在并重新启动脚本分...
▪Shell脚本break和continue命令简明教程
▪Shell脚本函数定义和函数参数
▪让代码整洁、过程清晰的BASH Shell编程技巧
▪shell常用重定向实例讲解
▪awk中RS、ORS、FS、OFS的区别和联系小结
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3