nginx內建模块使用
nginx內建模块使用
标签(空格分隔): nginx
© 版权声明:本文为博主原创文章,转载请注明出处
本文内容仅为个人理解,不保证完全正确
1. 內建模块的引入
安装nginx,只安装了核心模块,其他非核心模块都没有引入。因此当需要使用某个內建模块时需重新进行配置
1.1 查看安装信息
nginx -V # 查看安装信息,需要nginx配置到环境变量中,或者需要指定路径/home/*/nginx/sbin/nginx -
1.2 重新指定配置信息
假设以添加http_stub_status_module模块为例
用
nginx -V
查看以前的配置信息将新模块的信息追加到后面,然后重新配置。注意是追加不是覆盖。比如原本的配置信息为
./configure --prefix=/home/nginx/nginx
,那么添加http_stub_status_module后的配置信息为./configure --prefix=/home/nginx/nginx --with-http_stub_status_module
执行
make
命令,不能执行make install
命令,否则会重新安装的备份sbin目录下的nginx文件
mv ngnix ngnix.bak
将解压目录下objs目录下重新生成的nginx文件复制到安装目录的sbin目录下
cp /home/nginx/nginx-1.12.2/objs/nginx /home/nginx/nginx/sbin
重新加载nginx
nginx -s reload -c /home/nginx/nginx/conf/nginx.conf
。有时重新加载nginx不能加载新模块,此时可以用kill关闭nginx,然后重启启动即可
cd /home/nginx/nginx-1.12.2/ # 切换到解压后的nginx目录下
./configure --prefix=/home/nginx/nginx --with-http_stub_status_module # 重新指定配置信息
make # 重新编译
cp /home/nginx/nginx/sbin/nginx /home/nginx/nginx/sbin/nginx.bak # 备份
cp /home/nginx/nginx-1.12.2/objs/nginx /home/nginx/nginx/sbin # 复制
nginx -s reload -c /home/nginx/nginx/conf/nginx.conf # 重新加载nginx
2. 內建模块的使用
2.1 http_stub_status_module
作用:展示nginx的一些状态信息
配置:
Syntax: stub_status;
Default: -;
Context: server、location
样例:
location /mystatus {
stub_status; # 查看nginx的一些状态信息
}
说明: 配置完成后,重新加载nginx,然后访问根据配置的名称进行访问即可查看nginx的状态信息
访问方式:http://nginx_ip:nginx_port/mystatus
字段说明:
Active connections: 2
server accepts handled requests
5 5 23
Reading: 0 Writing: 1 Waiting: 1
其中Active connections:表示活跃的连接数
accepts:表示接收的握手的数量
handled:表示处理的数量。handled和accepts需要相等,表示没有丢失连接
requests:表示总的请求数
Reading:读取客户端的连接数
Writing:响应数据到客户端的数量
Waiting:开启keep-alive的情况下,等于Active connections-(Reading + Writing),表示nginx已经处理完正在等待下一次请求的驻留连接
2.2 http_random_index_module
作用:该模块的作用是随机显示主页
配置:
Syntax: random_index on|off;
Default: random_index off;
Context: location
样例:
location / {
#root html;
#index index.html index.htm;
root /home/nginx/Code; # 主页目录
random_index on; # 在主页目录下随机选择一个主页
}
说明:配置完成后,重新加载nginx,然后多次访问主页,此时nginx会自动从主页目录下随机选择一个html加载,但是不会加载隐藏文件
访问方式:http://nginx_ip:nginx_port/
2.3 http_sub_module
作用:将返回的内容进行HTTP内容替换
配置:
- Syntax: sub_filter string replacement;
主要用于替换字符串
Default: -;
Context: http,server,location- Syntax: sub_filter_last_modified on|off;
校验服务端的内容是否有变更,有就返回最新内容,主要用于缓存
Default: sub_filter_last_modified off;
Context: http,server,location- Syntax: sub_filter_once on|off;
是否只替换第一个,默认是on;off则替换所有的
Default: sub_filter_once on;
Context: http,server,location
样例:
location / {
root /home/nginx/Code;
index index.html;
sub_filter 'imooc' 'IMOOC';
sub_filter_once off;
}
说明:配置完成后,重新加载nginx,然后访问主页,此时会替换主页中所有的imooc为IMOOC
访问方式:http://nginx_ip:nginx_port/
2.4 limit_conn_module
作用:连接频率限制
配置:
- Syntax: limit_conn_zone key zone=name:size
存储连接状态,key存储键值,name唯一标识,size存储大小
Default: -;
Context: http- Syntax: limit_conn zone number;
zone对应limit_conn_zone中的name,number并发限制数
Default: -;
Context: http,server,location
样例:
http {
limit_conn_zone $binary_remote_addr zone=conn_zone:1m;
server {
location / {
root /home/nginx/Code;
index index.html;
limit_conn conn_zone 1;
}
}
}
说明:配置完成后,重新加载nginx,然后使用ab进行测试。此时一个ip只能同一时刻只能建立一个连接
2.5 limit_req_module
作用:请求频率限制
配置:
- Syntax: limit_req_zone key zone=name:size rate=rate;
存储请求状态,key存储键值,name唯一标识,size存储大小,rate请求速率限制(条/s)
Default: -;
Context: http- Syntax: limit_req zone=name [burst=number] [nodelay];
name对应limit_req_zone中的name,burst表示延迟请求,number表示个数,即有number个请求会延迟到下一秒处理,nodelay表示剩余的都是立刻处理
Default: —;
Context: http,server,location
样例:
http {
limit_req_zone $binary_remote_addr zone=req_zone:1m rate=1r/s;
server {
location / {
root /home/nginx/Code;
index index.html;
#limit_req zone=req_zone;
#limit_req zone=req_zone burst=3 nodelay;
limit_req zone=req_zone burst=3;
}
}
}
说明:配置完成后,重新加载nginx,然后使用ab进行压力测试
配置说明:
limit_req zone=req_zone; 表明严格按照rate设置的速率处理请求,多余的请求直接舍弃
limit_req zone=req_zone burst=3 nodelay; 表明按照rate设置的速率处理请求,同时设置一个大小为3的缓存队列,当请求到来时可以爆发出一个峰值处理能力,处理缓存中的请求,其他的请求舍弃。
limit_req zone=req_zone burst=3; 表明按照rate设置的速率处理请求,同时设置一个大小为3的缓存队列,在缓存队列中的请求会等待慢慢处理,超过rate处理能力和缓存队列长度的请求直接舍弃。有延迟
参考:http://blog.csdn.net/hellow__world/article/details/78658041
2.6 http_access_module
作用:限制某些IP地址的客户端访问
配置:
- Syntax: allow address|CIDR|unix:|all;
address:IP地址 CIDR:网段 unix:主要用于socket消息 all:允许所有的
Default: -;
Context: http,server,location,limit_except- Syntax: deny address|CIDR|unix:|all;
address:IP地址 CIDR:网段 unix:主要用于socket消息 all:阻止所有的
Default: -;
Context: http,server,location,limit_except
样例:
location ~ ^/index {
root /home/nginx/Code;
deny 192.168.56.1; # 阻止192.168.56.1的IP访问
allow all; # 允许其他所有的IP访问
index index.html index.htm;
}
location ~ ^/index {
root /home/nginx/Code;
allow 192.168.56.1; # 只允许192.168.56.1的IP访问
deny all; # 阻止其他所有的IP访问
index index.html index.htm;
}
说明:配置完成后,重新加载nginx,使用不同的IP进行访问
局限性:如果是通过代理访问,这样IP控制就会失效。
解决方案:
方法一:采用别的HTTP头信息控制访问,如HTTP_X_FORWARD_FOR。(HTTP_X_FORWARD_FOR只是一个规范,可能没有,也可能被修改)
方法二:采用geo模块控制
方法三:通过HTTP自定义变量传递
2.7 http_auth_basic_module
作用:基本身份验证
配置:
- Syntax: auth_basic string | off # string:验证失败时提示的信息
Default: auth_basic off;
Context: http,server,location,limit_except- Syntax: auth_basic_user_file file; # file:验证文件路径
Default: -;
Context: http,server,location,limit_except
样例:
location / {
root /home/nginx/Code;
index index.html index.htm;
auth_basic "Auth access test!input your password!";
auth_basic_user_file /home/nginx/nginx/conf/conf.d/auth/auth_conf;
}
说明:auth_conf文件使用htpasswd生成,若未安装,可先使用yum -y install httpd-tools
进行安装,然后用htpasswd -c ./auth_conf username
按提示生成文件,重新加载nginx
局限性:用户信息依赖文件方式、操作管理机械,效率低下
解决方案:
方法一:Nginx结合LUA实现高效验证
方法二:Nginx和LDAP打通,利用nginx-auth-ldap模块
更好的MarkDown体验:https://www.zybuluo.com/chy282/note/1042841
nginx內建模块使用的更多相关文章
- python內建模块之datetime
from:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143193755 ...
- Python 的內建模块
>>> import __builtin__>>> dir(__builtin__)['ArithmeticError', 'AssertionError', 'A ...
- python快速学习-常用內建模块
- python学习(十五) 内建模块学习
介绍python的几个內建模块,原文链接 1 python的时间模块datetime 取现在时间 from datetime import datetime now = datetime.now() ...
- Nginx SPDY Pagespeed模块编译——加速网站载入
在看<Web性能权威指南>的时候,看到了SPDY这货,于是便开始折腾起了这个了,也顺便把pagespeed加了进去. Nginx SPDY 引自百科~~ SPDY(读作“SPeeDY”)是 ...
- Python3 内建模块 hashlib、itertools、HTMLParser、urllib
Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制 ...
- nginx源代码分析--模块分类
ngx-modules Nginx 基本的模块大致能够分为四类: handler – 协同完毕client请求的处理.产生响应数据.比方模块, ngx_http_rewrite_module, ngx ...
- Nginx开发HTTP模块入门
Nginx开发HTTP模块入门 我们以一个最简单的Hello World模块为例,学习Nginx的模块编写.假设我们的模块在nginx配置文件中的指令名称为hello_world,那我们就可以在ngi ...
- Python学习进程(8)字符串內建函数
Python字符串內建函数实现了string模块的大部分方法,并包括了对Unicode编码方式的支持. (1)capitalize(): 将字符串的第一个字母变成大写,其他字母变小写. ...
随机推荐
- vue.js 2的表单控件
静下心,抄一段sample,以后可以快点到这里来抄...: <!DOCTYPE html> <html> <head> <meta charset=" ...
- 基于SpringMVC的上传文件实现
基于SpringMVC的上传文件实现 1.项目源码 源码地址:upload 2.关键代码 @RequestMapping("/upload2") public void datal ...
- 中矿大 C 石头剪刀布【决策DP*待看/codeforces原题】
时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 32768K,其他语言65536K64bit IO Format: %lld 题目描述 齐齐和司机正在玩剪刀石头布,不过他俩有些玩腻了,所 ...
- 通过命令行上传代码到GitHub
自工作以来,本人第一次使用GitHub.下面是将本地的项目上传到GitHub的过程.上传代码的前提是:1.已注册GitHub账号:2.本地已安装Git. 第一步:远程Git仓库 进入本地的项目的根目录 ...
- 「kuangbin带你飞」专题十九 矩阵
layout: post title: 「kuangbin带你飞」专题十九 矩阵 author: "luowentaoaa" catalog: true tags: mathjax ...
- SQL 增删改查 复习
首先创建两张表 CREATE TABLE Teacher ( Id ,) NOT NULL PRIMARY KEY, Name ) NOT NULL, ); CREATE TABLE Student ...
- UVA 103 Stacking Boxes n维最长上升子序列
题目链接:UVA - 103 题意:现有k个箱子,每个箱子可以用n维向量表示.如果一个箱子的n维向量均比另一个箱子的n维向量大,那么它们可以套接在一起,每个箱子的n维向量可以互相交换值,如箱子(2,6 ...
- IIS7.5 部署WCF项目问题集锦
HTTP 错误 500.19 - Internal Server Error 描述:配置错误: 不能在此路径中使用此配置节.如果在父级别上锁定了该节,便会出现这种情况.锁定是默认设置的 (overri ...
- mysql的三大范式
关系数据库的几种设计范式介绍: 第一范式:确保每列的原子性(强调的是列的原子性,即列不能够再分成其他几列). 如果每列(或者每个属性)都是不可再分的最小数据单元(也称为最小的原子单元),则满足第一范式 ...
- scala,import test._ ; import test.{ClassA,ClassB}
在scala中,*不是通配符,下斜杠“_”才是通配符.因此当使用某个package所有的类时,直接使用:import test._:使用某几个时,直接使用:import test.{ClassA,Cl ...