本文介绍了几个Nginx常用模块的使用方法。
ngx_http_ssi_module
官方说明文档:
http://nginx.org/en/docs/http/ngx_http_ssi_module.html
要点:
-
在 http, server, location, if in location 等上下文中启用 ssi:
ssi on;
-
在html源文件中包含其他文件:
<!--# include file="/footer.html" -->
-
编辑footer.html文件,达到自己的效果;
-
reload nginx 配置即可生效;
扩展:
在官方文档中有很多配置和命令,根据自己需要选用即可。
http_ssl_module
配置选项:加入 ssl 模块
./configure \
--with-http_ssl_module
make
cp -f objs/nginx /usr/local/nginx/sbin/nginx
生成证书
可以通过以下步骤生成一个简单的证书:
首先,进入你想创建证书和私钥的目录,例如:
$ cd /usr/local/nginx/conf
创建服务器私钥,命令会让你输入一个口令:
$ openssl genrsa -des3 -out server.key 1024
创建签名请求的证书(CSR):
$ openssl req -new -key server.key -out server.csr
在加载SSL支持的Nginx并使用上述私钥时除去必须的口令:
$ cp server.key server.key.org
$ openssl rsa -in server.key.org -out server.key
配置nginx
最后标记证书使用上述私钥和CSR:
$ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
修改Nginx配置文件,让其包含新标记的证书和私钥:
server {
server_name localhost;
listen 443 ssl;
ssl_certificate /usr/local/nginx/conf/server.crt;
ssl_certificate_key /usr/local/nginx/conf/server.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers AES128-SHA:AES256-SHA:RC4-SHA:DES-CBC3-SHA:RC4-MD5;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
keepalive_timeout 70;
}
重启nginx。
http_image_filter_module
安装 ImageFilter 模块依赖的库
apt-get install libgd2-xpm-dev
编译与安装
./configure \
--with-http_image_filter_module
make
cp -f objs/nginx /usr/local/nginx/sbin/nginx
配置
location ^~ /images/ {
root html;
image_filter resize 100 100;
}
访问 /images/bg001.jpg
即可得到压缩后的照片。
第三方模块:Foot Filter
寻找模块
这里有很多第三方模块:
https://www.nginx.com/resources/wiki/modules/index.html
我们从中挑选一个看似功能简单的来使用一下:Foot Filter
https://github.com/shennongmin/nginx-http-footer-filter
Footer Filter 下载、编译、安装以及使用
参考:https://github.com/shennongmin/nginx-http-footer-filter/blob/master/README.md
编译前Nginx配置选项
./configure \
--with-http_image_filter_module \
--with-http_ssl_module \
--add-module=/root/nginx-http-footer-filter
make
cp -f objs/nginx /usr/local/nginx/sbin/nginx
配置 Footer Filter
location / {
## Using the $date_gmt variable from the SSI module (prints a
## UNIX timestamp).
footer "<!-- $date_gmt -->";
index index.html;
}
引入 Tengine
官方:
http://tengine.taobao.org/
简介
Tengine是由淘宝网发起的Web服务器项目。它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能
和特性。Tengine的性能和稳定性已经在大型的网站如淘宝网,天猫商城等得到了很好的检验。它的最终目标是打
造一个高效、稳定、安全、易用的Web平台。
从2011年12月开始,Tengine成为一个开源项目,Tengine团队在积极地开发和维护着它。Tengine团队的核心成员
来自于淘宝、搜狗等互联网企业。Tengine是社区合作的成果,我们欢迎大家参与其中,贡献自己的力量。
特性
- 继承Nginx-1.6.2的所有特性,兼容Nginx的配置;
- 动态模块加载(DSO)支持。加入一个模块不再需要重新编译整个Tengine;
- 支持SO_REUSEPORT选项,建连性能提升为官方nginx的三倍;
- 同时支持HTTP v2协议和SPDY v3协议,可同时使用两种协议;
- 流式上传到HTTP后端服务器或FastCGI服务器,大量减少机器的I/O压力;
- 更加强大的负载均衡能力,包括一致性hash模块、会话保持模块,还可以对后端的服务器进行主动健康检查,根 - 据服务器状态自动上线下线,以及动态解析upstream中出现的域名;
- 输入过滤器机制支持。通过使用这种机制Web应用防火墙的编写更为方便;
- 支持设置proxy、memcached、fastcgi、scgi、uwsgi在后端失败时的重试次数
- 动态脚本语言Lua支持。扩展功能非常高效简单;
- 支持管道(pipe)和syslog(本地和远端)形式的日志以及日志抽样;
- 支持按指定关键字(域名,url等)收集Tengine运行状态;
- 组合多个CSS、JavaScript文件的访问请求变成一个请求;
- 自动去除空白字符和注释从而减小页面的体积
- 自动根据CPU数目设置进程个数和绑定CPU亲缘性;
- 监控系统的负载和资源占用从而对系统进行保护;
- 显示对运维人员更友好的出错信息,便于定位出错机器;
- 更强大的防攻击(访问速度限制)模块;
- 更方便的命令行参数,如列出编译的模块列表、支持的指令等;
- 可以根据访问文件类型设置过期时间;
- ……
网友评论