一、Nginx简介与部署
(1)简介:
Nginx (engine x) 是一个高性能的HTTP(解决C10k的问题)和 反向代理服务器,也是一个IMAP/POP3/SMTP服务器。
(2)部署Nginx-Yum源
1.进入nginx官网找到下载,下载Stable version(最新稳定版,生产环境建议使用的版本)
2.下完之后回到主页面找到documentation(文档),点进去然后点击install nginx(安装nginx),点进去之后点击packas(包),往下拉看到这个界面:
data:image/s3,"s3://crabby-images/fc195/fc195ca135434bb30640846f3f57a888cc6e5b40" alt=""
3.进入到 cd /etc/yum.repores.d/ 里面,创建一个nginx.repo的文件,把上面官网第二个箭头指的内容加入到nginx,repo文件内保存退出。
4.使用yum安装上epel源:
data:image/s3,"s3://crabby-images/e959d/e959d3dde347b62c47703ad582486200a15f3bf6" alt=""
安装完成epel源之后安装nginx:
data:image/s3,"s3://crabby-images/b26b8/b26b8d0e2869e64a90d71147674e588f3c0161cb" alt=""
安装完成之后:
systemctl stop firewalld #临时关闭防火墙
setenforce 0 #临时关闭selinux
systemctl start nginx #启动nginx
启动之后,就可以在浏览器里访问页面了。
二、Nginx配置文件
在命令终端执行rpm -ql nginx 就会显示所有配置文件:
data:image/s3,"s3://crabby-images/01185/01185fd3d4daaa319d6500aa919dcd9bf406483b" alt=""
三、Nginx编译参数
在命令终端执行nginx -V 就会显示所有模块:
data:image/s3,"s3://crabby-images/05c20/05c20412e4f68c177b3eaa42d9772c879621b108" alt=""
data:image/s3,"s3://crabby-images/18f6f/18f6fa99214fd47202b56755ed4d833cc79e323c" alt=""
data:image/s3,"s3://crabby-images/af670/af6705b9ba66dafe7754684ab8e9b686f1137d6a" alt=""
data:image/s3,"s3://crabby-images/dae90/dae90a089106fe0f222ed7c5b2a5831f06b042d0" alt=""
四、Nginx基本配置文件信息
vim /etc/nginx/nginx.conf 进入到主配置文件中:
data:image/s3,"s3://crabby-images/9b403/9b403368b4769a323ba495d3707410577c80564a" alt=""
vim /etc/nginx/conf.d/defaulet.conf 进入到子配置文件:
data:image/s3,"s3://crabby-images/51643/51643f09bc949376c6e829d0b2c11c497e05c0e9" alt=""
五、Nginx日志log
(1)日志配置
相关指令:
ngx_http_log_module #日志模块名称
log_format #日志格式
access_log #访问日志
error_log #错误日志
open_log_file_cache #日志缓存
log_format :
data:image/s3,"s3://crabby-images/299f3/299f3a40ff420fc31a45fb773e488fd0a56628b2" alt=""
data:image/s3,"s3://crabby-images/0f4d1/0f4d19a699ff812a3192b900c1fbdadf96571e24" alt=""
data:image/s3,"s3://crabby-images/6f953/6f953fd505315ca3c7b35db102f17307b99dd568" alt=""
access_log:
data:image/s3,"s3://crabby-images/7de45/7de452cf493ff6b0da85d42512c43323a51695f6" alt=""
(2)日志分析
统计2017年九月五日八点到九点的pv量:
data:image/s3,"s3://crabby-images/5ff4d/5ff4dea9888360536942db734afa02a6ab24120f" alt=""
统计2017年9月5日 一天内访问最多的10个IP(ip top10):
data:image/s3,"s3://crabby-images/ccc96/ccc9664ea0659f0c2ec7061ed70c441561f766c6" alt=""
统计2017年9月5日 每个URL访问内容总大小($body_bytes_sent):
data:image/s3,"s3://crabby-images/a78f8/a78f858308e1c5181252c19d7079e7ea823435dc" alt=""
统计2017年9月5日 IP访问状态码为404及出现次数($status):
data:image/s3,"s3://crabby-images/f26c6/f26c62d60d399d1f5505dbaa1d6f8b0cab5fbda8" alt=""
统计前一分钟的PV量:
data:image/s3,"s3://crabby-images/467a4/467a4ef055f3468e122f7f6b2000d94c98e4291c" alt=""
六、Nginx Web模块
1.连接状态模块 stub_status_module
目的:展示用户和nginx链接数量等信息
(1)查询模块是否已经安装
# nginx -V 2>&1 | grep stub_status
(2)启动状态模块
配置状态模块:
# vim /etc/nginx/conf.d/default.conf
在server框架内添加如下内容:
# location /nginx_status {
stub_status;
allow all;
}
保存退出,重启服务
#systemctl restart nginx
访问页面就会显示:
data:image/s3,"s3://crabby-images/982a5/982a56e42a6ca276397d0c1361806fc0e6327f50" alt=""
data:image/s3,"s3://crabby-images/0e9a9/0e9a97b36ab37146a6487bb5a04a4a47f81dfb8e" alt=""
2.随机主页模块 random_index_module
目的:将主页设置成随机页面,是一种微调更新机制
启动随机主页:
创建主页目录:# mkdir /wangning
创建随即多个主页:# mkdir /wangning/{wannging.html ,wangning1.html ,wannging2.html,wangning3.html}
不同的页面里面都输入不同的内容
配置启动模块 # vim /etc/nginx/conf.d/default.conf
# server{
location / {
#root /usr/share/nginx/html;
#index index.html index.htm;
root /app;
random_index on;
}
}
完成之后 重启服务 刷新页面观察变化
3.替换模块 sub_module
目的:网页内容替换 如果我们用模板生成网站的时候,因为疏漏或者别的原因造成代码不如意,但是此时因为文件数量巨大,不方便全部重新生成,那么这个时候我们就可以用此模块来暂时实现纠错。另一方面,我们也可以利用这个实现服务器端文字过滤的效果。
启动替换1:
# vim /etc/nginx/conf.d/default.conf
# sub_filter nginx 'wangning';
# sub_filter_once off;
# location / {
#root /usr/share/nginx/html;
#index index.html index.htm;
# }
注意是在server模块里面添加 刷新页面观察变化 注意sub_filter_once off; 这是全局替换 如果改成sub_filter_once on;就会只改变一处内容
data:image/s3,"s3://crabby-images/b1f30/b1f3084b4e8873ba83dcee1ba909f209571b9ba3" alt=""
启动替换模块2
首先准备替换的java脚本: #vim /usr/share/nginx/html/hellowangning.js
# function Hello() {alert("Hello WangNing")}
然后,在主页body标签里面插入按钮 #vim /usr/share/nginx/html/index.html
#<input type="button" onclick="Hello()" value="say hellp" />
启动替换:# vim /etc/nginx/nginx.conf
#sub_filter </head> '</head><script type="text/javascript" src="hellowangning.js"></script>';
#sub_filter_once off;
重启服务,观察页面
data:image/s3,"s3://crabby-images/523ed/523ed46b674bed474da800aa1d4f8062f331ee30" alt=""
4.防盗链功能
1.首先搭建两个网站 wangning.com wangning1.com ,在wangning.com网站主页中添加一张图片:#<img src='1.jpg' />
2.在wangning1.com主页中添加主页一的地址<img src='http://wangning.com网站的域名或者地址/1.jpg' /> ,盗用wangning.com 的链接
3.访问两个网站的主页就会都显示图片
data:image/s3,"s3://crabby-images/6d306/6d30687b6872f95b41965cfb95107cd2653fb3e1" alt=""
4.访问wangning1.com的日志发现日志正常,然而访问wangning.com的日志观察referer字段发现被盗链了
5.在wangning.com网站中添加防盗链功能:
#vi /etc/nginx/conf.d/wangning.conf
#location / {
# root /wangning.com;
# index index.html index.html
# valid_referers none blocked *.wangning.com;
# if ($invalid_referer) {
# return 403;
# }
#}
启用之后,重启服务
再次访问wangning1.com发现盗链失败
data:image/s3,"s3://crabby-images/a4f66/a4f668aef3bbe376451093962a4738f7cacfd3bd" alt=""
七.Nginx访问限制
目的:服务器经常会遇恶意的攻击使得服务器的流量异常负载过大带宽浪费等,从而影响业务,所以要限制用户的连接次数并发次数
模块:ngx_http_limit_conn_module ngx_http_limit_req_module
启动限制:vi /etc/nginx/nginx.conf
#http {
#limit_conn_zone $binary_remote_addr zone=conn_zone:10m;
#}
#server {
#location / {
# ...
#limit_conn conn_zone 1;
#}
#}
重启服务并测试:yum -y install httpd-tools
#ab -n 100 -c 10 http://wangning.com/
data:image/s3,"s3://crabby-images/926ea/926ea4cc8ab6a04d2fe38387f8acc47ad7783641" alt=""
模块二:ngx_http_limit_req_module
启动限制:vi/etc/nginx/nginx.conf
# http {
# limit_req_zone $binary_remote_addr zone=req_zone:10m rate=1r/s; 定
# server {
# location / {
# root /usr/share/nginx/html;
# index index.html index.htm;
# limit_req zone=req_zone; 引用
#limit_req zone=req_zone burst=5;
#limit_req zone=req_zone burst=5 nodelay;
# }
# }
#}
data:image/s3,"s3://crabby-images/fb8ed/fb8ed9e9116b5f60291dd2f151e0450e014d5908" alt=""
八.Nginx访问控制
目的:就是控制某些恶意主机不让其访问,或者允许哪些主机让其访问
模块:ngx_http_access_module
启动访问控制:vim /etc/nginx/conf.d/default.conf
# server {
# allow 10.18.45.65;
# allow 10.18.45.181;
# deny all;
# }
重启服务并测试,发现除了允许的主机可以访问其余的主机都不能访问了:
data:image/s3,"s3://crabby-images/eeca2/eeca20ff5aff4b4c67bd37f046844726b671ace2" alt=""
若有问题咨询欢迎大家联系我:
邮箱:Wangmouren1997@163.com
QQ:1586787265
网友评论