Nginx网站服务(你想要的都在这)

本文详细介绍了Nginx服务的基础,包括其性能特点、安装配置、系统服务添加、配置文件解析以及访问控制策略。重点讲解了如何检查HTTP_STUB_STATUS模块,设置访问状态统计,并提供了基于授权和客户端IP的访问控制方法。
摘要由CSDN通过智能技术生成

一、Nginx服务基础

■Nginx是一款性能、轻量级Web服务软件

■稳定性高

■系统资源消耗低

■对HTTP并发连接的处理能力高:单台物理服务器可支持30000~50000个并发请求

♦编译安装Nginx服务

1、关闭防火墙,将安装nginx所需要的包传到/opt目录下

systemctl stop firewalld.service

setenforce 0
systemctl stop httpd.service

 2、安装依赖包

yum -y install prce-devel zlib-devel gcc gcc-c++ make
#nginx的配置及运行需要及运行需要pcre、zlib等软件包的支持,需要其提供相应和库头文件

 3、创建运行用户、组(Nginx 服务程序默认以为nobody身份运行,建议为其创建专门的用户账号,以便更准确控制其访问权限)

 4、编译安装Nginx

①解压nginx压缩包

 

 ②启动configure文件

 ③编译安装

 ④做个软链接

  ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

 

 ⑤启动nginx

 5、添加Nginx系统服务

方法一:创建系统服务脚本

①创建一个脚本文件

#!/bin/bash
#chkconfig 35 99 20
#Ngnix server script
 
COM="/usr/local/nginx/sbin/nginx"
PID="/usr/local/nginx/logs/nginx.pid"
 
case "$1" in
start)
   $COM
;;
stop)
   kill -s QUIT $(cat $PID)
;;
restart)
   $0 stop
   $0 start
;;
reload)
   kill -s HUP $(cat $PID)
;;
*)
   echo "Usage:$0 {start|stop|restart|reload}"
   exit 1
esac
exit 0

②赋予权限 并添加到系统服务内

 chmod +x /etc/init.d/nginx

 chkconfig --add nginx 

 ③启动nginx系统服务

 6、了解nginx服务的主配置文件 vim /usr/local/nginx/conf/nginx.conf

全局配置

#user  nobody;                          #运行用户,若编译时未指定则默认为 nobody
worker_processes  1;                    #工作进程数量,可配置成服务器内核数 * 2,如果网站访问量不大,一般设为1就够用了
#error_log  logs/error.log;             #错误日志文件的位置
#pid        logs/nginx.pid;             #PID 文件的位置

I/O事件配置

events {
    use epoll;                          #使用epoll模型,2.6及以上版本的系统内核,建议使用epoll模型以提高性能
    worker_connections  4096;           #每个进程处理4096个连接

如提高每个进程的连接数还需执行"ulimit -n 65535"命令临时修改本地每个进程可以同时打开的最大文件数。
在Linux平台上, 在进行高并发TCP连接处理时, 最高的并发数量都要受到系统对用户 单—一进程同时可打开文件数量的限制(这是因为系统为每个TCP连接都要创建一个socket句柄,每个socket句柄同时也是一个文件句柄)。
可使用ulimit -a命令查看系统允许当前用户进程打开的文件数限制

HTTP配置

                                                                            ##日志格式设定
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';
 
    #access_log  logs/access.log  main;                                        #日志格式设定
     
    sendfile        on;                                                ##支持文件发送(下载)
    ##此选项允许或禁止使用socket的TCP cORK的选项(发送数据包前先缓存数据),此选项仅在使用sendfile的时候使用
    #tcp_nopush     on;
    ##连接保持超时时间,单位是秒
    #keepalive_timeout  0;
    keepalive_timeout  65;
     
    #gzip  on;                                                              ##gzip模块设置,设置是否开启gzip压缩输出
     
server {
        listen       80;                                        ##监听地址及端口
        server_name  www.clj.com;                                       ##站点域名,可以有多个,用空格隔开
 
        #charset utf-8;                                         #网页的默认字符集
 
        #access_log  logs/host.access.log  main;       
 
        location / {                                            ##根目录配置
            root   html;                                        ##网站根目录的位置/usr/local/nginx/html
            index  index.html index.htm;                                        ##默认首页文件名
        }
 
        #error_page  404              /404.html;
 
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;                              ##内部错误的反馈页面
        location = /50x.html {                                ##错误页面配置
            root   html;
        }

日志格式设定∶
$remote_addr与$http x forwarded for用以记录客户端的ip地址;
$remote user∶ 用来记录客户端用户名称;
$time local∶ 用来记录访问时间与时区;$request∶用来记录请求的url与http协议;
$status∶ 用来记录请求状态;成功是200,
$body bytes sent ∶ 记录发送给客户端文件主体内容大小;
$http referer∶ 用来记录从哪个页面链接访问过来的;
$http user agent∶记录客户浏览器的相关信息;

通常web服务器放在反向代理的后面,这样就不能获取到客户的IP地址了,通过Sremote_add拿到的IP地址是反向代理服务器的iP地址。反向代理服务器在转发请求的http头信息中,可以增加x_forwarded_for信息,用以记录原有客户端的IP地址和原来客户端的请求的服务器地址。

location常见配置指令, root、alias、proxy_ pass
root (根路径配置)∶ 请求ww.clj.com/test/1.jpg,会返回文件/usr/local/nginx/html/test/1.jpg
alias (别名配置)∶请求www.clj.com/test/1.jpg,会返回文件/usr/local/nginx/html/1.jpg
proxy_pass (反向代理配置)∶
proxy_pass http://127.0.0.1:8080/; ------------- 会转发请求到http∶//127.0.0.1∶8080/1.jpg
proxy_pass http://127.0.0.1:8080; --------------会转发请求到http∶//127.0.0.1∶8080/test/1.jpg

访问状态统计配置:

1.1.先使用命令/usr/local/nginx/ sbin/nginx -V查看E安装的Nginx 是否包含HTTP_STUB_STATUS模块

1.2.修改 nginx.conf 配置文件,指定访问位置并添加 stub_status 配置(修改之前进行备份)

2.2  修改nginx.conf 配置文件,指定访问位置并添加stub_status 配置 (记得提前备份下配置文件)

 

 3、重启服务并访问网页

也可以以curl http://192.168.50.10/status进行awk和if语句进行监控

 

二、Nginx访问控制

基于授权访问控制

1、生成用户密码认证文件

①安装tool软件  htpasswd -c /usr/local/nginx/pass.db ly

②创建用于及密码设置  htpasswd -c /usr/local/nginx/pass.db wqx

 

 ③修改配置文件

 ④重启服务进行网页访问

 2、基于客户端访问控制

访问控制规则如下:

• deny IP/IP段: 拒绝某个IP或IP段的客户端访问

• allow IP/IP 段: 允许某个IP或IP段的客户端访问

•  规则从上往下执行,如匹配则停止,不再往下匹配

①修改配置文件

 这里要加;   不然会出错,网页无法访问

 ②重启服务访问网页

用被限制的客户端访问

 用没有限制的客户端访问

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值