2018.9.18日,预习笔记,LNMP架构(二)

笔记目录

  1. Nginx默认虚拟主机
  2. Nginx用户认证
  3. Nginx域名重定向
  4. Nginx访问日志
  5. Nginx日志切割
  6. 静态文件不记录日志和过期时间
  7. Nginx防盗链
  8. Nginx访问控制
  9. Nginx解析PHP相关配置
  10. Nginx代理
  11. 扩展:

nginx.conf 配置详解 

https://coding.net/u/aminglinux/p/nginx/git/tree/master/3z

nginx rewrite四种flag 

http://unixman.blog.51cto.com/10163040/1711943 

https://coding.net/u/aminglinux/p/nginx/git/blob/master/rewrite/break.md 

502问题汇总 http://ask.apelearn.com/question/9109 

location优先级 https://coding.net/u/aminglinux/p/nginx/git/blob/master/location/priority.md 

https://coding.net/u/aminglinux/p/nginx/git/blob/master/location/priority.md

 

一.Nginx默认虚拟主机

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • vim /usr/local/nginx/conf/nginx.conf //增加
  •  include vhost/*.conf  这是要添加的内容

2018.9.18日,预习笔记,LNMP架构(二)

  • mkdir /usr/local/nginx/conf/vhost  创建目录
  • cd !$ 进入目录下
  • vim default.conf //编辑文件,加入如下内容

server

{    

listen 80 default_server;  // 定义它的监听端口,有这个标记的就是默认虚拟主机    

server_name aaa.com;    域名

index index.html index.htm index.php;    指定索引页

root /data/wwwroot/default; 指定网址位置

}  

  • mkdir -p /data/wwwroot/default/  创建目录
  • cd !$ 进入目录下
  • echo “This is a default  site.”>/data/wwwroot/default/index.html 创建一个index.html文件并写入一些内容
  •  /usr/local/nginx/sbin/nginx -t 检查一下
  •  /usr/local/nginx/sbin/nginx -s reload  重新加载一下配置文件
  • curl localhost  测试访问一下

2018.9.18日,预习笔记,LNMP架构(二)

  • curl -x127.0.0.1:80 123.com 指定一个域名,测试访问一下

2018.9.18日,预习笔记,LNMP架构(二)

  • 不管访问什么域名,只要解析指向到这个服务器,都会访问到该站点,这就是默认虚拟主机

 

二.Nginx用户认证

2018.9.18日,预习笔记,LNMP架构(二)

2018.9.18日,预习笔记,LNMP架构(二)

示例一:用户认证

  • vim /usr/local/nginx/conf/vhost/test.com.conf//创建一个虚拟主机,写入如下内容

server

{    

listen 80;

server_name test.com;    

index index.html index.htm index.php;    

root /data/wwwroot/test.com;    

location  /    

{        

auth_basic              "Auth";         用户认证的名字

auth_basic_user_file   /usr/local/nginx/conf/htpasswd; 用户名密码文件

}

}  

  • yum install -y httpd  yum安装httpd,使用htpasswd工具
  • htpasswd -c /usr/local/nginx/conf/htpasswd aming 生成用户密码,-c是生成的意思,如果生成第二个则不需要用-c,不然会重置
  • /usr/local/nginx/sbin/nginx -t 检查语法是否有错误
  • /usr/local/nginx/sbin/nginx -s reload //测试配置并重新加载配置文件
  • mkdir /data/wwwroot/test.com 创建目录
  •  echo “test.com”>/data/wwwroot/test.com/index.html 建立一个html文件
  •  curl -x127.0.0.1:80 test.com -I//状态码为401说明需要验证  2018.9.18日,预习笔记,LNMP架构(二)
  • curl -uaming:passwd -x127.0.0.1:80 test.com 访问状态码变为200  

2018.9.18日,预习笔记,LNMP架构(二)

  • 编辑windows的hosts文件,然后在浏览器中访问test.com会有输入用户、密码的弹窗  

示例二:针对目录的用户认证

  • vi test.com.conf 编辑文件,做如下更改

location  /admin/    

{        

auth_basic              "Auth";        

auth_basic_user_file   /usr/local/nginx/conf/htpasswd;

}

  • 用curl 测试

2018.9.18日,预习笔记,LNMP架构(二)

  • 新建一个测试html文件,并测试一下

2018.9.18日,预习笔记,LNMP架构(二)

示例三:针对php做限制,如下更改

  • vi test.com.conf 编辑文件

2018.9.18日,预习笔记,LNMP架构(二)

 

 

三.Nginx域名重定向

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • 更改test.com.conf 编辑文件:

server ,如下

{    

listen 80;    

server_name test.com test1.com test2.com;  配置域名,而且可以配置多个域名

index index.html index.htm index.php;    

root /data/wwwroot/test.com;    

if ($host != 'test.com' )

{        

rewrite  ^/(.*)$  http://test.com/$1  permanent;    指定调整到哪个域名下,permanent指定301状态码

   }

}  

  • server_name后面支持写多个域名,这里要和httpd的做一个对比  permanent为永久重定向,状态码为301,如果写redirect则为302
  • 检查语法并重新加载配置文件

2018.9.18日,预习笔记,LNMP架构(二)

  • curl 测试一下,任意域名都会重定向到指定域名下

2018.9.18日,预习笔记,LNMP架构(二)

 

四.Nginx访问日志

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • 日志格式  
  • vim /usr/local/nginx/conf/nginx.conf //搜索log_format

$remote_addr

客户端IP(公网IP)

$http_x_forwarded_for

代理服务器的IP

$time_local

服务器本地时间

$host

访问主机名(域名)

$request_uri

访问的url地址

$status

状态码

$http_referer

referer

$http_user_agent

user_agent

 

  • 除了在主配置文件nginx.conf里定义日志格式外,还需要在虚拟主机配置文件中增加
  • vim test.com.conf
  • access_log /tmp/1.log combined_realip;

2018.9.18日,预习笔记,LNMP架构(二)

  •  这里的combined_realip就是在nginx.conf中定义的日志格式名字  
  • -t && -s reload 检查语法并重新加载配置文件
  • curl -x127.0.0.1:80 test.com -I  测试

2018.9.18日,预习笔记,LNMP架构(二)

  • cat /tmp/1.log 查看日志文件

2018.9.18日,预习笔记,LNMP架构(二)

 

五.Nginx日志切割

2018.9.18日,预习笔记,LNMP架构(二)

示例一:因为Nginx不自带日志切割工具,所以自定义脚本借用

  • 自定义shell 脚本  
  • vim /usr/local/sbin/nginx_log_rotate.sh//写入如下内容

#! /bin/bash

## 假设nginx的日志存放路径为/data/logs/

d=`date -d "-1 day" +%Y%m%d`   生成昨天的日期

logdir="/data/logs"   定义存放位置

nginx_pid="/usr/local/nginx/logs/nginx.pid" 定义位置,找他的pid

cd $logdir 进入目录下

for log in `ls *.log`  做个for循环

do    

   mv $log $log-$d   做一个改名操作

done

/bin/kill -HUP `cat $nginx_pid`  重新加载一下,生成新的日志文件

  • 执行一下这个脚本来看看效果,执行过程

2018.9.18日,预习笔记,LNMP架构(二)

  • ls /tmp/ 看一下

2018.9.18日,预习笔记,LNMP架构(二)

  • 在做一个任务计划  ,每天0.0分执行该脚本
  • crontab -e 编辑如下

0 0 * * * /bin/bash /usr/local/sbin/nginx_log_rotate.sh

 

六.静态文件不记录日志和过期时间

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • vi test.com.conf
  • 配置如下

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$    

{          

expires      7d;          定义过期时间

access_log off;    关闭日志记录

}

location ~ .*\.(js|css)$    

{          

expires      12h;          

access_log off;    

}

  • -t &&reload 检测语法,并重新加载一下配置文件

2018.9.18日,预习笔记,LNMP架构(二)

  • 测试,先创建两个以图片结尾的文件

cd /data/wwwroot/test.com

vim 1.gif

vim 2.js

  • curl测试一下

2018.9.18日,预习笔记,LNMP架构(二)

  • 查看日志是否记录

2018.9.18日,预习笔记,LNMP架构(二)

  • 测试过期时间

2018.9.18日,预习笔记,LNMP架构(二)

 

七.Nginx防盗链

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • 配置如下,可以和上面的配置结合起来
  • vi /usr/local/nginx/conf/vhost/test.com.conf

location ~* ^.+\.(gif|jpg|png|swf|flv|rar|zip|doc|pdf|gz|bz2|jpeg|bmp|xls)$

{    

expires 7d;    

valid_referers none blocked server_names  *.test.com ; 定义白名单    

if ($invalid_referer) {         如果不是白名单,返回403

return 403;    

   }    

access_log off;

}

  • 配置完成如图

2018.9.18日,预习笔记,LNMP架构(二)

  • -t && reload 检测语法并重新加载配置文件

2018.9.18日,预习笔记,LNMP架构(二)

  • 用curl 测试一下,-e 指定

2018.9.18日,预习笔记,LNMP架构(二)

 

八.Nginx访问控制

2018.9.18日,预习笔记,LNMP架构(二)

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • 需求:访问/admin/目录的请求,只允许某几个IP访问,配置如下:
  • vi /usr/local/nginx/conf/vhost/test.com.conf

location /admin/

{    

allow 192.168.133.1;    

allow 127.0.0.1;    

deny all;

}  

  • mkdir /data/wwwroot/test.com/admin/  
  • echo “test,test”>/data/wwwroot/test.com/admin/1.html  
  • -t && -s reload  检查语法并重新加载配置文件
  • 测试:
  • curl -x127.0.0.1:80 test.com/admin/1.html -I  

2018.9.18日,预习笔记,LNMP架构(二)

  • curl -x192.168.133.130:80 test.com/admin/1.html -I

2018.9.18日,预习笔记,LNMP架构(二)

  • curl -x 192.168.142.128:80 test.com/admin/

2018.9.18日,预习笔记,LNMP架构(二)

 

示例二:禁止解析php

  • 可以匹配正则
  • vi /usr/local/nginx/conf/vhost/test.com.conf

location ~ .*(abc|image)/.*\.php$

{        

deny all;

}

  • -t && reload 检测语法,并重新加载配置文件

2018.9.18日,预习笔记,LNMP架构(二)

  • 用curl测试一下

2018.9.18日,预习笔记,LNMP架构(二)

 

示例三:根据user-agent限制

  • vi /usr/local/nginx/conf/vhost/test.com.conf

if ($http_user_agent ~ 'Spider/3.0|YoudaoBot|Tomato')

{      

return 403;

}  

  • deny all和return 403效果一样
  • -t && reload 检测语法,并重新加载配置文件

2018.9.18日,预习笔记,LNMP架构(二)

  • 用curl 检测一下

2018.9.18日,预习笔记,LNMP架构(二)

  • 如果想忽略大小写,就如下在~ 后添加一个*号就行了

2018.9.18日,预习笔记,LNMP架构(二)

 

 

九.Nginx解析PHP相关配置

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • vi /usr/local/nginx/conf/vhost/test.com.conf
  • 配置如下:

location ~ \.php$    

{        

include fastcgi_params;        

fastcgi_pass unix:/tmp/php-fcgi.sock;        

fastcgi_index index.php;        

fastcgi_param SCRIPT_FILENAME

/data/wwwroot/test.com$fastcgi_script_name;    

}

  •  fastcgi_pass 用来指定php-fpm监听的地址或者socket
  •  

示例二:502解决方法

  •  

 

 

 

十.Nginx代理

2018.9.18日,预习笔记,LNMP架构(二)

示例一:

  • cd /usr/local/nginx/conf/vhost  进入目录下
  • vim proxy.conf //加入如下内容

server

{    

listen 80;    

server_name ask.apelearn.com;     定义一个域名

location /    

{        

proxy_pass      http://121.201.9.155/;         配置真实IP

proxy_set_header Host   $host;       要访问的域名 

proxy_set_header X-Real-IP      $remote_addr;   指定ip的 

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;    

   }

}

  • /use/local/nginx/sbin/nginx -t  检测语法错误
  • /use/local/nginx/sbin/nginx -s reload 重新加载一下配置文件
  • curl 测试一下,访问成功,通过本地地址访问到远程的网址

2018.9.18日,预习笔记,LNMP架构(二)

 

十一.扩展

nginx.conf 配置详解 

https://coding.net/u/aminglinux/p/nginx/git/tree/master/3z

nginx rewrite四种flag 

http://unixman.blog.51cto.com/10163040/1711943 

https://coding.net/u/aminglinux/p/nginx/git/blob/master/rewrite/break.md 

502问题汇总 http://ask.apelearn.com/question/9109 

location优先级 https://coding.net/u/aminglinux/p/nginx/git/blob/master/location/priority.md 

转载于:https://my.oschina.net/u/3912766/blog/2056298