1. Nginx 经典美文
1.0.1. nginx 常用命令
nginx -c /etc/nginx/nginx.conf #nginx启动,conf 可以自己指定或者删除
nginx -s stop #停止nginx
nginx -s quit #停止nginx
nginx -s reload #nginx重载配置
nginx -t #检查配置文件是否正确
如果将整个配置文件的结构简化一下,大概就是这样:
main块
event块{
#定义nginx的事件模型,不可或缺。
}
http块 { #http服务器的必要块。
server块 { #定义虚拟主机的块。
if块 {}
location块 { #定义uri规则的块,可以使用正则表达式。
if块 {} #RewriteCond的重新规则条件的功能。
}
}
}
2. nginx 限制ip访问
server {
listen 80;
server_name xx.xx.xx.xx;
location / {
root html/blog;
index.index.php index.html index.htm;
allow 127.0.0.1/24;
allow 192.168.0.0/16;
allow 10.10.0.0;
deny all;
}
//deny 一定要加一个ip,否则调转到403。
//对于allow的ip段,允许访问的段位从小到大排列。
//24,代表子网掩码:255.255.255.0
//16,代表子网掩码:255.255.0.0
//8,代表子网掩码:255.0.0.0
也可以通过文件的形式include进来 1.首先建立一个用于屏蔽IP的配置文件,放在nginx的conf目录下面, 这里以iplist为例,iplist内容可以是是:
deny 192.168.1.11;
deny 192.168.1.123;
deny 10.0.1.0/24;
2、在nginx的配置文件 nginx.conf 中加入 include iplist,以便这个配置文件能够被加载。
server {
listen 80;
server_name localhost;
location / {
include iplist;
proxy_pass http://local_tomcat;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forworded-For $proxy_add_x_forwarded_for;
}
}
3、重新加载nginx的配置 nginx -s reload,即可生效。
3. 开启gzip 压缩性能优化
gzip on; #开启压缩
gzip_static on; #告诉nginx在压缩资源之前,先查找是否有预先gzip处理过的资源。这要求你预先压缩你的文件(在这个例子中被注释掉了),从而允许你使用最高压缩比,这样nginx就不用再压缩这些文件了
gzip_min_length 1k; #允许压缩页面的最小字节数
gzip_disable "msie6"; #为指定的客户端禁用gzip功能
gzip_http_version 1.1; #压缩版本
gzip_vary on; #支持前端的缓存服务器缓存经过gzip压缩的页面。
gzip_comp_level 6; #指定压缩等级,其值从1到9,数字越大,压缩率越高,越消耗CPU,负载也越高.设置为4,这是一个比较折中的设置.
gzip_proxied any; #允许或者禁止压缩基于请求和响应的响应流。我们设置为any,意味着将会压缩所有的请求。
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript text/x-js; #支持的压缩类型
4. nginx图片及目录防盗链
什么是防盗链系统
防盗链系统就是防范盗链的系统,防止别人通过一些技术手段绕过本站的资源展示页面,盗用本站的资源,让绕开本站资源展示页面的资源链接失效。实施防盗链系统后,因为屏蔽了那些盗链的间接资源请求,从而可以大大减轻服务器及带宽的压力,也正如此,越来越多的站点都开始实施防盗链技术。
Nginx的防盗链主要使用的是referer模块。
语法:valid_referers none | blocked | server_names |
说明:当在HTTP请求头中有Referer字段,则变量$invalid_referer将会设置为空字符串,否则$invalid_referer将会设置为1. 匹配时不区分大小写
none:表示请求头中没有Referer字段。 blocked:表示请求头中有Referer字段,但是该字段的值已经被防火墙或者是代理服务器删除了,不是以"http://"或者是"https://"开头 server_names:请求头的Referer字段包含其中一个server name。 string:表示任意的字符串。可以是一个server name或者是server name和URI的结合,可以使用在server name的开头和结尾可以使用*。并且不会检查Referer字段的服务器的端口号。 也可以使用正则表达式进行匹配,如果要使用正则表达式,则第一个符号必须是"~",并且表达式匹配的内容应该是"http://"或者是"https://"以后的内容。
配置示例
location ~ \.(png|jpg|jpeg|gif)$ {
valid_referers none blocked server_names *.kakaogift.cn *.kakaogift.com;
if ($invalid_referer) {
return 403;
}
}
5. nginx 负载均衡 load balance
nginx的upstream目前支持4种方式的分配
1)、
轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、
weight 指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
3)、
ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
4)、
fair(第三方) 按后端服务器的响应时间来分配请求,响应时间短的优先分配。
#server参数
#weight=number ;服务器的权重,在默认情况下是1。
#max_conns=number ;限制与代理服务器的最大并发连接数。 默认值为零,意味着没有限制
#max_fails=number ;最大失败数,与服务器进行通信失败的次数,服务器将被视为不可用。缺省情况下,尝试失败的次数被设置为1。
#fail_timeout=time ;最大超时,与服务器通信不可用的时间段,服务器将被视为不可用。默认情况下,参数被设置为10秒。
#backup ;标志着服务器作为备份服务器。当主服务器不可用时将启用
#down ;将服务器标记为永久不可用
#resolve ;监视对应于服务器的域名的IP地址的变化,自动修改上游配置而不需要重新启动
#route=string ;设置服务器的路由名称
#service=name ;启用DNS SRV记录解析和设置服务名称
#slow_start=time ;慢启动,即服务器可用后到提供服务的这段时间,默认为0,表示禁用,不能用于hash和ip_hash负载均衡方法
upstream backend {
ip_hash; //支持round robin, least_conn,ip_hash
server backend1.example.com weight=5;
server backend2.example.com down; //down只在ip_hash时有效,表示该server down时,发请求给下一个server
server backend3.example.com max_fails=3 fail_timeout=30s; //
server 192.0.0.1 backup;
}
server {
location / {
proxy_pass http://backend;
}
}
6. nginx 配置expires缓存实现性能优化
expires功能就是允许通过nginx配置文件控制http的expires和cache-control响应头的内容。告送浏览器是否缓存和缓存多长时间。
(1).根据文件扩展名进行判断
location ~ .*\.(gif | jpg | jpeg | png | nmp | swf)$ {
expires 365d;
}
(2).缓存某个特定的文件
location ~(robots.txt) {
expires 7d;
break;
}
7. nginx 日志相关优化
1).配置日志切割脚本
vim cut_nginx_log.sh
#!/bin/bash
cd /opt/application/nginx/nginx/logs && \ /bin/mv blog_access.log blog_access_$(date +%F -d -1day).log
/opt/application/ngnix/nginx/sbin/nginx -s reload
crontab -e
00 00 * * * /bin/sh /usr/local/cut_nginx_log.sh >/dev/null 2>&1
2).不记录不需要的访问日志 如果日志写入太频繁,会占用大量的磁盘I/O,从而降低了服务器的性能
location ~ .*\.(js | css | gif | jpg | jpeg | png | nmp | swf)$ {
access_log off ;
}
8. Rewrite规则
location = / {
# 精确匹配 / ,主机名后面不能带任何字符串
[ configuration A ]
}
location / {
# 因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求
# 但是正则和最长字符串会优先匹配
[ configuration B ]
}
location /documents/ {
# 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
# 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
[ configuration C ]
}
location ~ /documents/Abc {
# 匹配任何以 /documents/Abc 开头的地址,匹配符合以后,还要继续往下搜索
# 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
[ configuration CC ]
}
location ^~ /images/ {
# 匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条。
[ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
# 匹配所有以 gif,jpg或jpeg 结尾的请求
# 然而,所有请求 /images/ 下的图片会被 config D 处理,因为 ^~ 到达不了这一条正则
[ configuration E ]
}
location /images/ {
# 字符匹配到 /images/,继续往下,会发现 ^~ 存在
[ configuration F ]
}
location /images/abc {
# 最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在
# F与G的放置顺序是没有关系的
[ configuration G ]
}
location ~ /images/abc/ {
# 只有去掉 config D 才有效:先最长匹配 config G 开头的地址,继续往下搜索,匹配到这一条正则,采用
[ configuration H ]
}
location ~* /js/.*/\.js
已=开头表示精确匹配 如 A 中只匹配根目录结尾的请求,后面不能带任何字符串。 ^~ 开头表示uri以某个常规字符串开头,不是正则匹配 ~ 开头表示区分大小写的正则匹配; ~* 开头表示不区分大小写的正则匹配 / 通用匹配, 如果没有其它匹配,任何请求都会匹配到
so,实战项目一般这样
所以实际使用中,个人觉得至少有三个匹配规则定义,如下:
#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理,官网如是说。
#这里是直接转发给后端应用服务器了,也可以是一个静态首页
# 第一个必选规则
location = / {
proxy_pass http://tomcat:8080/index
}
# 第二个必选规则是处理静态文件请求,这是nginx作为http服务器的强项
# 有两种配置模式,目录匹配或后缀匹配,任选其一或搭配使用
location ^~ /static/ {
root /webroot/static/;
}
location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
root /webroot/res/;
}
#第三个规则就是通用规则,用来转发动态请求到后端应用服务器
#非静态文件请求就默认是动态请求,自己根据实际把握
#毕竟目前的一些框架的流行,带.php,.jsp后缀的情况很少了
location / {
proxy_pass http://tomcat:8080/
}
9. 优雅的显示错误页面
server {
......
error_page 500 501 502 503 504 xxx.html #https://err.tmall.com/error2.html
error_page 400 403 404 405 408 410 411 412 413 414 415 https://err.tmall.com/error1.html
......
}
10. 模块(心跳检查)nginx_upstream_check_module
1.下载模块包 wget https://github.com/yaoweibin/nginx_upstream_check_module/archive/v0.3.0.tar.gz
2.解压 tar -zxf v0.3.0.tar.gz
3.添加补丁 patch -p1 < ../nginx_upstream_check_module-master/check_1.5.12+.patch
4.配置nginx ./configure --add-module=/opt/nginx_upstream_check_module-0.3.0
5.编译安装 make && make install
6.查看安装信息 nginx -V
upstream default_upstream{
keepalive 60;
server 127.0.0.1:8080 max_fails=0 fail_timeout=30s weight=20;
check interval=1000 rise=3 fall=2 timeout=3000 type=http default_down=false;
check_http_send "GET / HTTP/1.0\r\n\r\n";
check_http_expect_alive http_2xx;
}
#测试地址,不一定要配置
location /nstatus {
check_status;
access_log off;
allow all;
#deny all;
}
11. 最后记录一些常用的默认配置,不需要修改就行
error_log logs/error.log warn;
指定error_log的日志文件为logs/error.log并设置记录级别为warning。
events {
use epoll; #为什么nginx比apache快,epoll起到了比较关键的作用
worker_connections 20480;
}
设定事件模型使用epoll,每个worker进程可用的最大连接数是20480。
root /home/admin/cai/htdocs;
设置静态文件所在地,也就是网站根目录。
sendfile on;
打开会使用sendfile系统调用,用来发送静态文件,节省了文件在用户空间和内核空间拷贝的消耗。
tcp_nopush on;
打开后,会使TCP在发送数据时进行缓存,提高传输效率,但是会增加客户端响应时间。
keepalive_timeout 15s;
keepalive_requests 100;
设置keepalive连接的超时时间为15s,并且每处理100个请求以后就关闭链接。
server_tokens off;
关闭后,nginx在错误页面和响应的Server头中不会携带版本号信息。