nginx常用模块介绍

ngx_http_access_module模块的配置(基于IP的访问控制)

  1. allow address | CIDR | unix: | all;
  2. deny address | CIDR | unix: | all;

a)         应用上下文:http, server, location, limit_except

b)         eg:

location / {

deny  192.168.1.1;

allow 192.168.1.0/24;

allow 10.1.1.0/16;

allow 2001:0db8::/32;

deny  all;

}

ngx_http_auth_basic_module模块的配置(basic认证)

  1. auth_basic string | off;

使用http basic认证协议对用户进行认证;读取auth_basic_user_file 指定文件

string:用来向用户展示一些提示信息,告诉用户为什么认证

off:代表不急于http basic进行加密

  1. auth_basic_user_file file;

实现用户认证的账号文件;

a)         文件格式:

name:password:comment

eg:name1:password1

name2:password2:comment

b)         密码格式:

htpasswd:使用此命令生成加密文件

eg:

location /admin/ {

auth_basic "Admin Area";

auth_basic_user_file /etc/nginx/.ngxhtpasswd;

}

ngx_http_stub_status_module模块配置

  1. stub_status;

用于输出Nginx的状态信息,通过指定的uri(http://ip:port/status)访问状态页面;

a)         页面信息如下

Active connections: 291

server accepts handled requests

16630948 16630948 31070465

Reading: 6 Writing: 179 Waiting: 106

b)         详解

Active connections:当前活动的客户端连接数;

accepts:已经接受的客户端连接总数量;

handled:已经处理过后客户端连接总数量;

requests:客户端的总的请求数量;

Readking:正在读取的客户端请求的数量;

Writing:正向其发送响应报文的连接数量;

Waiting:等待其发出请求的空闲连接数量;

ngx_http_referer_module模块配置

基于请求报文中的Referer首部的值做访问控制

  1. valid_referers  none | blocked | server_names | string ...;

a)         定义合法的referer数据,可以包含  none | blocked | server_names | string ...;中的一个或多个

none:请求报文不存在referer首部;

blocked:请求报文中存在referer首部,但其没有有效值,或其值非以http://或https://开头;

server_names:其值为一个主机名;例如server_names   *.example.com

arbitrary string:直接字符串,可以使用*通配符;

regular expression:以~起始的正则表达式;

b)         内置变量:$invalid_referer(所有不能符合valid_referer指定定义的引用请求均为不合法引用)

c)         eg:

valid_referers   none   blocked   server_names   *.example.com   example.*     www.example.org/galleries/   ~\.google\.;

if ($invalid_referer) {

return  403;

}

ngx_http_log_module模块的配置(访问日志)

  1. log_format  name  string  ...

定义日志格式及其名称;日志格式一般通过调用内置变量来定义;

默认:access_log logs/access.log combined;

  1. access_log path [format [buffer=size] [gzip[=level]] [flush=time] [if=condition]];

access_log off;

访问日志文件路径,格式名称以及缓存大小、压缩比和刷写时间间隔;建议定义缓冲以提升性能;

  1. open_log_file_cache max=N [inactive=time] [min_uses=N] [valid=time];

open_log_file_cache off;

ngx_http_ssl_module模块配置

  1. ssl on | off

控制启用或禁止ssl

  1. ssl_certificate file;

当前虚拟主机使用的证书文件路径;

  1. ssl_certificate_key file;

当前虚拟主机使用的证书文件中的公钥配对的私钥文件;

补充:生成私钥方法

(umask 077;openssl genrsa -out ssl/nginx.key 1024)

生成证书

openssl req -new -key nginx.key -out nginx.csr -days 365

  1. ssl_ciphers ciphers;

指明由nginx使用的加密算法,可以是OpenSSL库中所支持各加密套件;

使用 openssl ciphers 命令查看支持的加密算法

  1. ssl_protocols [SSLv2] [SSLv3] [TLSv1] [TLSv1.1] [TLSv1.2];

指明会话使用的ssl协议版本,默认为后三个;

注意SSLv2版本已经被证明是不安全的,建议不要使用

  1. ssl_session_cache off | none | [builtin[:size]] [shared:name:size];

指明ssl会话缓存机制;

off:绝对禁用ssl会话缓存

none:禁用ssl会话缓存

builtin:使用OpenSSL内置的ssl会话缓存机制,此机制为各worker私有;缺陷是有时候客户的几次会话可能会分别发送给不同worker进程,这样会导致会话缓存命中率不高

shared:与builtin不同之处在于,各worker之间使用一个共享的缓存;

name:缓存空间的名称;

size:缓存空间大小;每1M空间大约可缓存4000个会话

eg:ssl_session_cache  builtin:1000 shared:SSL:10m;

  1. ssl_session_timeout time;

ssl会话超时时长默认5分钟;即ssl session cache中的缓存有效时长;

nginx-(三)基本模块1的更多相关文章

  1. nginx 增加 lua模块

    Nginx中的stub_status模块主要用于查看Nginx的一些状态信息. 本模块默认是不会编译进Nginx的,如果你要使用该模块,则要在编译安装Nginx时指定: ./configure –wi ...

  2. Nginx访问限制模块limit_conn_zone 和limit_req_zone配置使用

    nginx可以通过limit_conn_zone 和limit_req_zone两个组件来对客户端访问目录和文件的访问频率和次数进行限制,另外还可以善用进行服务安全加固,两个模块都能够对客户端访问进行 ...

  3. nginx 的第三方模块ngx_http_accesskey_module 来实现下载文件的防盗链步骤(linux系统下)

    nginx 的第三方模块ngx_http_accesskey_module 来实现下载文件的防盗链步骤(linux系统下),安装Nginx和HttpAccessKeyModule模块(参考LNMP环境 ...

  4. nginx內建模块使用

    目录 nginx內建模块使用 1. 內建模块的引入 1.1 查看安装信息 1.2 重新指定配置信息 2. 內建模块的使用 2.1 http_stub_status_module 2.2 http_ra ...

  5. nginx的ngx_http_geoip2模块以精准禁止特定地区IP访问

    要求:对网站的信息,比如某个访问节点不想国内或者国外的用户使用,禁止国内或者国外或者精确到某个城市的那种情况. 解决方式:1.Cloudfalre来实现禁止特定国家的ip访问,比较简单,但是需要mon ...

  6. Nginx 常用基础模块

    目录 Nginx 常用基础模块 Nginx日志管理 nginx日志切割 Nginx目录索引 Nginx状态监控 Nginx访问控制 Nginx访问限制 Nginx 请求限制配置实战 Nginx Loc ...

  7. Nginx 的过滤模块是干啥用的?

    上一篇文章我写了 Nginx 的 11 个阶段,很多人都说太长了.这是出于文章完整性的考虑的,11 个阶段嘛,一次性说完就完事了.今天这篇文章比较短,看完没问题. 过滤模块的位置 之前我们介绍了 Ng ...

  8. Nginx使用SSL模块配置https

    背景 开发微信小程序,需要https域名,因此使用Nginx的SSL模块配置https 步骤 一.去域名管理商(如腾讯云.阿里云等)申请CA证书 二.在Nginx中配置,一般情况下域名管理商会提供配置 ...

  9. 附002.Nginx代理相关模块解析

    一 ngx_http_proxy_module模块 1.1 proxy_pass配置 proxy_pass URL; Context: location, if in location, limit_ ...

  10. nginx 的常用模块

    nginx的常用模块 ngx_http_index_module Syntax: index file ...; Default: index index.html; Context: http, s ...

随机推荐

  1. The command ("dfs.browser.action.delete") is undefined 解决Hadoop Eclipse插件报错

    Hadoop Eclipse插件 报错. 使用 hadoop-eclipse-kepler-plugin-2.2.0.jar 如下所示 Error Log 强迫症看了 受不了 The command ...

  2. 接口 IEnumerable

    C#提供了可供类继承的接口,在此解释一下经常遇到的IEnumerable,在此首相解释一下接口,如下例所示: /// <summary> /// 简述Interface的用法 /// &l ...

  3. SpringBoot整合MybatisPlus3.X之自定义Mapper(十)

    pom.xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId& ...

  4. vsftpd超实用技巧详解

    简介: vsftpd是"very secure FTP daemon"的缩写,是一个完全免费的.开放源代码的ftp服务器软件. 工作原理: vsftpd使用ftp协议,该协议属于应 ...

  5. 在虚拟机上的关于Apache(阿帕奇)(3)基于IP访问网站

    这篇随笔是基于IP访问网站,和后面两篇文章基于域名和基于端口一起练习效果更好 基于IP(记得下载httpd服务) 首先使用nmtui命令为网卡添加多个ip地址  输入命令:nmtui  进入下面这个界 ...

  6. 【建站02】WordPress主题设置

    大家好,我是帝哥.相信很多朋友看了我上一篇文章的介绍之后已经可以搭建自己的个人网站了,但是网站的功能和美观程度都还是有所欠缺的,现在呢,再给大家大概的介绍一些如何美化自己的网站,当然了,这个过程也是很 ...

  7. Junit使用方法

    Junit使用方法 步骤: 定义 一个测试类(测试用例) 建议 测试类名:被测试类名+Test 包名:xxx.xxx.xxx.test 测试方法 建议: 方法名:test测试的方法名 返回值: voi ...

  8. js调用浏览器“打印”与“打印预览”

    用到html <object>标签,具体做法如下: 1.在html文档任意位置添加<object>标签: <div style="border: 1px sol ...

  9. vue 选择图片(限定大小)上传到服务器

    FormData:  https://developer.mozilla.org/zh-CN/docs/Web/API/FormData/Using_FormData_Objects  成果: htm ...

  10. 破解微擎安装,免费搭建微擎,免费破解微擎,微擎破解版本,最新版本V2.1.2,一键安装!!

    ​ 微擎是一款基于WEB2.0(PHP+Mysql)技术架构,免费开源的公众平台管理系统,一款致力于将小程序和公众号商业化.智慧化.场景化的自助引擎.微擎提供公众号.微信小程序.支付宝小程序.百度熊掌 ...