文档章节

nginx模块nginx-http-footer-filter(淘宝开发)

小运
 小运
发布于 2013/08/26 10:20
字数 1467
阅读 6007
收藏 231

      nginx-http-footer-filter想必大家都觉得很陌生,那我们就来认识一下它吧,这是淘宝开发的nginx模块. 它用于nginx在响应请求文件底部追加内容. 今天抽空研究下这个插件,希望对大家有所帮助。为什么发现了这个插件,因为这几天公司需要在所有shtml文件后面追加一个js代码用来做统计(之前统计 代码没加齐全),在寻求解决方法的过程中找到了它认识了它最后喜欢上了它,你可能以为我用这个插件去实现了我要的功能,其实在认识他之前我用shell脚 本替换齐全了. 不过我还是决定研究测试一下nginx-http-footer-filter,或许以后的需求上能有帮助,更或许能帮上其他需要帮助的人.进入正题吧.

1. nginx-http-footer-filter到底是做什么的?

说白了,就是在请求的页面底部插入你要插入的代码。

2. 我们能用nginx-http-footer-filter来做什么?

1、统一追加js代码用于统计(我是这么想的)
2、底部追加响应这个请求的realsver(后端真实服务器)信息,便于系统管理员排查故障.
3、你管理着数量庞大的虚拟主机,在所有web后面追加你的广告代码,黑链什么的(很无耻)
4、举一反三吧,自己想想能用来做什么吧.

淘宝用它来做什么?

打开淘宝首页,查看他源代码,拖到最下面,内容如下:

<!--city: fuzhou-->
<!--province: unknown-->
<!--hostname: -->
<!--hostname: home1.cn199-->

我们可以很清晰的看到,这边有省和地区还有主机名,也就是淘宝真实服务器的主机名,处理我这个请求的主机名为home1.cn199, city取到了fuzhou,provinece省份没取到,估计是它Geo的问题
或者随便打开一个商品页面, 查看源代码,如下:

</html>
<script type="text/javascript">TShop.initFoot({});</script>

可以看到他这边给这页面追加了一个js代码,淘宝开发这个模块的用意想必大家都明白了,集思广益,或许大家还有更好的用处.

3. 怎么安nginx-http-footer-filter

3.1 下载地址:

https://github.com/alibaba/nginx-http-footer-filter/tree/1.2.2


3.2 安装nginx-footer模块

之前已经安装过nginx,所以我选择覆盖nginx文件。

# cd /usr/local/src/
# wget https://codeload.github.com/alibaba/nginx-http-footer-filter/zip/1.2.2
# unzip 1.2.2

# http://nginx.org/download/nginx-1.4.1.tar.gz
# tar -xzvf nginx-1.4.1.tar.gz
# cd nginx-1.4.1
# ./configure --prefix=/usr/local/nginx-1.4.1 \
--with-http_stub_status_module --with-http_realip_module \
--add-module=../nginx-http-footer-filter-1.2.2
# make
# mv /usr/local/nginx-1.4.1/sbin/nginx /usr/local/nginx-1.4.1/sbin/old_nginx
# mv objs/nginx /usr/local/nginx-1.4.1/sbin/
# /usr/local/nginx-1.4.1/sbin/nginx -s stop
# /usr/local/nginx-1.4.1/sbin/nginx

3.3 验证模块是否安装成功

# /usr/local/nginx-1.4.1/sbin/nginx -V
nginx version: nginx/1.4.1
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC)
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx-1.4.1 
--with-http_stub_status_module 
--with-http_realip_module  
--add-module=../nginx-http-footer-filter-1.2.2

4. 怎么使用nginx-http-footer-filter模块


4.1 配置location

在location中使用footer "你的内容" 即可.看如下配置

server {
        listen       173.255.219.122:80;
        server_name  test.ttlsa.com;
        access_log  /data/logs/nginx/test.ttlsa.com.access.log  main;

        index index.html index.php index.html;
        root /data/site/test.ttlsa.com;
        location / {
           footer "<!-- $date_gmt -->";
           index index.html;
        }

        location =/html/2252.css {
           footer_types text/css;
           footer "/* host: $server_name - $date_local */";
}

4.2 测试nginx-footer效果

# cat 2252.shtml
<html>
    <head>
    <title>test</title>
    </head>
    <body>
        this is webpage
    </body>
</html>

访问站点test.ttlsa.com/html/2252.shtml

nginx追加底部代码nginx追加底部代码

如图,我们可以看到文件最底部加上了<!-- 1376063369 -->,怎么变成了时间撮了,因为我这边是ssi的语法,如果你不知道什么是ssi,那么请参考文章什么是ssi.

他仅仅是在文件的最后一行追加,而不是<body>里面.这点大家要注意了.

4.3 再来测试一下css文件

# cat 2242.css
# this is css file

如下是访问结果:
# this is css file
/* host: test.ttlsa.com - 1376064324 */

看图:

nginx footer追加底部代码cssnginx footer追加底部代码css

5. 我能写多个footer指令吗?

不行,以下我写了两个footer

location / {
    footer "12312321321";
    footer "<!-- $date_gmt -->";
    index index.html;
}

如下测试,提示footer指令重复了

# /usr/local/nginx-1.4.1/sbin/nginx -t
nginx: [emerg] "footer" directive is duplicate in /usr/local/nginx-1.4.1/conf/vhost/test.ttlsa.com.conf:13
nginx: configuration file /usr/local/nginx-1.4.1/conf/nginx.conf test failed

6. 只能用ssi变量吗?

当然不是,随便你写,可以是ssi指令,也可以是nginx变量,也可以是任何无意义的字符串
如下:
footer "12312321321";
footer "<!--12312321321-->";
footer "<!--$remote_addr-->";

比如我想知道这个页面是哪台web服务器处理的,那么我在底部插入主机名即可.这样,有500错误,我便可以马上定位到具体的服务器了

footer "<!--$hostname-->";

返回结果如下:

nginx footer 追加底部代码nginx变量hostnamenginx footer 追加底部代码nginx变量hostname

7. 服务器返回500,404,403等错误, 是否还会追加内容到底部

会,如果不追加,就无法通过返回的页面得知哪台web出现故障,这明显就不符合作者的初衷了,有些同学可能觉得我在后端设置一个header不就可以了,为什么还要去装一个插件,麻烦不麻烦?不信你试试404,500这些错误头部能不能看到。况且你面对的用户都是小白们,难道让他提交错误的时候,问他你看下你的http头部的某值是多少,别人傻眼了。现在你只要说,哥们,网页保存下来传给我。

配置如下:

location / {
    return 500;
    footer "<!--$hostname-->";
}

结果如下:

nginx footer追加底部代码500错误nginx footer追加底部代码500错误

8. 模块指令说明:

footer模块非常简单,就只有两个指令,具体说明如下
footer字符串
默认值: ``
配置段: http, server, location
这个定义了将什么内容追加到文件内容的底部

footer_types MIME类型
默认值: footer_types: text/html
配置段: http, server, location
定义被追加底部文件的MIME返回类型,默认值是text/html

 我原文: nginx模块nginx-http-footer-filter

链接失效点我:http://www.ttlsa.com/html/2252.html

© 著作权归作者所有

小运
粉丝 102
博文 761
码字总数 659803
作品 0
福州
系统管理员
私信 提问
加载中

评论(16)

d
dongyue
呵呵,赞一下,淘宝的分享精神,虽然是个很容易实现的小模块。
shudu
shudu

引用来自“叶园”的评论

引用来自“shudu”的评论

写得很赞!
我又要给tengine打一下广告啦,tengine里除了footer模块,还有好多好用的功能等着大家来发现。推荐使用哦 :D

tengine对内存要求高不高啊?

不高,这点上和nginx一样。
叶园
叶园

引用来自“shudu”的评论

写得很赞!
我又要给tengine打一下广告啦,tengine里除了footer模块,还有好多好用的功能等着大家来发现。推荐使用哦 :D

tengine对内存要求高不高啊?
shudu
shudu
写得很赞!
我又要给tengine打一下广告啦,tengine里除了footer模块,还有好多好用的功能等着大家来发现。推荐使用哦 :D
我不说话
我不说话
不知道有鸟用!汗~~~~
grail
grail
这个好!
cgcgbcbc
cgcgbcbc
赞,收
如来神掌
如来神掌
牛X啊,学习了!
一行
一行
这个确实不错,很适合我们公司现在的场景。
熊猫与猫无关
熊猫与猫无关
我能想到的用途有点无耻,反向代理替换别人网页广告联盟的ID
Nginx学习之九:实践学习指南

Nginx基础 1. nginx安装 2. nginx 编译参数详解 3. nginx安装配置+清缓存模块安装 4. nginx+PHP 5.5 5. nginx配置虚拟主机 6. nginx location配置 7. nginx root&alias文件路径配置 8. ngxht...

boonya
2014/07/09
320
0
Nginx系列教程:nginx_substitutions_filter模块

nginxsubstitutionsfilter 请注意:此模块不是Nginx源的分布,可点击此链接找到安装说明, http://wiki.nginx.org/NginxHttpSubsModule#Installation 。 概述 nginxsubstitutionsfilter 是一...

mickelfeng
2012/12/28
555
0
安装nginx并为nginx添加sysguard模块

如果nginx被攻击或者访问量突然变大,nginx会因为负载变高或者内存不够用导致服务器宕机,最终导致站点无法访问。解决方法是利用淘宝开发的模块nginx-http-sysguard,主要用于当负载和内存达...

itzhongxin
2017/08/02
0
0
生产环境上nginx 不覆盖添加lua模块

需求如下: 需要在nginx配置文件中判断请求中是否带某参数变量,nginx配置本身没有此判断功能。 网上查找资料,可以在nginx中添加lua模块,使用lua的脚本去判断。比较靠谱的文章:CentOS系统...

-悟空-
2015/06/11
1K
2
Nginx负载均衡中后端节点服务器健康检查的操作梳理

正常情况下,nginx做反向代理,如果后端节点服务器宕掉的话,nginx默认是不能把这台realserver踢出upstream负载集群的,所以还会有请求转发到后端的这台realserver上面,这样势必造成网站访问...

吞吞吐吐的
2017/09/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Giraph源码分析(八)—— 统计每个SuperStep中参与计算的顶点数目

作者|白松 目的:科研中,需要分析在每次迭代过程中参与计算的顶点数目,来进一步优化系统。比如,在SSSP的compute()方法最后一行,都会把当前顶点voteToHalt,即变为InActive状态。所以每次...

数澜科技
今天
4
0
Xss过滤器(Java)

问题 最近旧的系统,遇到Xss安全问题。这个系统采用用的是spring mvc的maven工程。 解决 maven依赖配置 <properties><easapi.version>2.2.0.0</easapi.version></properties><dependenci......

亚林瓜子
今天
10
0
Navicat 快捷键

操作 结果 ctrl+q 打开查询窗口 ctrl+/ 注释sql语句 ctrl+shift +/ 解除注释 ctrl+r 运行查询窗口的sql语句 ctrl+shift+r 只运行选中的sql语句 F6 打开一个mysql命令行窗口 ctrl+l 删除一行 ...

低至一折起
今天
9
0
Set 和 Map

Set 1:基本概念 类数组对象, 内部元素唯一 let set = new Set([1, 2, 3, 2, 1]); console.log(set); // Set(3){ 1, 2, 3 } [...set]; // [1, 2, 3] 接收数组或迭代器对象 ...

凌兮洛
今天
4
0
PyTorch入门笔记一

张量 引入pytorch,生成一个随机的5x3张量 >>> from __future__ import print_function>>> import torch>>> x = torch.rand(5, 3)>>> print(x)tensor([[0.5555, 0.7301, 0.5655],......

仪山湖
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部