Nginx服务配置及相关模块

目录

一.Nginx配置文件

1.1.主配置文件解析

1.2.子配置文件启用

二.子配置文件使用

2.1.创建虚拟主机实验

2.2.基于端口虚拟主机实验

三.Nginx模块

3.1.access模块

3.2.自定义错误页面

3.3.状态页开启


一.Nginx配置文件

1.1.主配置文件解析

①yum安装主配置文件位置:/etc/nginx/nginx.conf

②编译安装主配置文件位置:/编译安装路径/conf/nginx.conf

   nginx主配置文件:nginx.conf详解
worker_processes  1;
#全局配置本机可运行多少个master进程,根据本机cpu数量设置数量,可设置为auto按cpu核数自动化调整
events {
#events事件处理模块
    worker_connections  1024;
#每个worker子进程可以处理多少个请求即可以打开多少个文件
}
http {
#http模块,web服务器与网页有关配置写在此模块中
    include       mime.types;
#mime.type中规定了那些文件是给用户查看的,若文件类型不在此文件中则是下载文件。
    default_type  application/octet-stream;
#默认支持文件类型
    sendfile        on;
#开启文件传输
    keepalive_timeout  65;
#长连接超时时间,单位为秒
    server {
#http模块中的server模块,主要配置监听端口,虚拟主机,dns域名等
        listen       80;
#监听所有ip的80端口
        server_name  localhost;
#主机名为本机,可虚拟域名
    location / {
#http模块下的location模块
            root   html;
#此location的根目录位置
            index  index.html index.htm;
#配置默认寻找文件,先寻找index.html若无此文件则找index.htm
        }
        error_page   500 502 503 504  /50x.html;
#500、502等错误界面跳转访问指定的/下的50x.html页面
        location = /50x.html {
#定义此location为精确匹配,必须是50x.html才能访问此页面
            root   html;
        }
}
}

1.2.子配置文件启用

#启用子配置文件
#在主配置文件http模块的末尾添加。
include   /apps/nginx/conf.d/*.conf;
#注意/apps/nginx/conf.d此文件夹需要存在,若不存在需要先建立好,*.conf表示在此文件夹下所有以.conf结尾的都是子配置文件。
systemctl restart nginx.service
#重启服务后即可

二.子配置文件使用

2.1.创建虚拟主机实验

①创建子配置文件,指定虚拟主机域名为www.kgc.com,指定此虚拟主机根目录为/data/nginx/pc,网页显示内容为“当时只道是寻常”。

    systemctl stop firewalld
    setenforce 0
    #关闭防火墙和selinux
    mkdir -pv /data/nginx/pc
    #递归创建/data/nginx/pc文件夹并显示过程
    echo "当时只道是寻常">/data/nginx/pc/index.html
    #创建index.html文件内容为“当时只道是寻常”
    cd /apps/nginx/conf.d
    #进入指定的子配置文件路径
    vim  test.conf
    #创建子配置文件,文件内容如下:
    server{
    listen 80;
    #监听所有主机的80端口
    server_name www.kgc.com;
    #创建虚拟主机域名为www.kgc.com
    root  /data/nginx/pc;
    #指定此server模块的根目录为/data/nginx/pc,注意指定的目录要存在
    }

②配置修改完成后使用命令测试配置文件修改是否有错误,首先将nginx脚本拷贝到/usr/sbin下即可变成外部命令使用,然后使用nginx  -t检查所有配置文件。

[root@wngying nginx]#cd sbin/   #进入nginx脚本存在的文件夹
[root@wngying sbin]#ls
nginx     #将nginx脚本拷贝到/usr/sbin下成为外部命令
[root@wngying sbin]#cp nginx /usr/sbin/
cp: overwrite 'usr/sbin/nginx'? y  #此提示为本机原本拷贝过一次,第一次操作无提示
[root@wngying sbin]#nginx -t #nginx -t 检查配置文件是否正常 ok和successful是正常提示
nginx: the configuration file /apps/nginx/conf/nginx.conf syntax ls ok
nginx: configuration file /apps/nginx/conf/nginx.conf test ls successful
[root@wngying sbin]#

③配置文件检查正常后重新加载配置文件:使用  nginx  -s reload热加载配置文件。

④在测试机的/etc/hosts文件下添加nginx服务器的ip和域名。注意不添加此步骤无法访问域名!!

    systemctl stop firewalld
    setenforce 0
    #关闭防火墙和selinu
    vim /etc/hosts
    #编辑hosts文件,添加内容如下
    192.168.47.102  www.kgc.com
    #注意不添加此步骤无法访问域名

⑤使用curl测试访问www.kgc.com内容是否为自己的定制的内容。

[root@wangying ~]#curl www.kgc.com
当时只道是寻常
[root@wangying ~]#curl www.kgc.com
当时只道是寻常                            #内容为设置的index.html文件内容

2.2.基于端口虚拟主机实验

①修改子配置文件中的80端口为8080。

    server{
    listen 8800;
    #监听所有主机的8080端口
    server_name www.kgc.com;
    #创建虚拟主机域名为www.kgc.com
    root  /data/nginx/pc;
    #指定此server模块的根目录为/data/nginx/pc,注意指定的目录要存在
    }

②修改完成后检测配置文件然后重新加载。

    nginx -t                        #检测配置文件修改是否正确
    nginx -s reload            #重新加载配置文件

③另外一台机器测试curl www.kgc.com:8080。

[root@wangying ~]#curl www.kgc.com:8080
当时只道是寻常

三.Nginx模块

3.1.access模块

①access模块默认是安装的无论是yum安装还是编译安装,不安装此模块需要在编译安装时添加--without-http_access_module。

②access模块有allow和deny俩个动作,allow是允许那些ip访问,deny是拒绝那些ip。默认是黑名单,拒绝谁才不能通过,不拒绝全部允许通过。

③设置拒绝192.168.47.101;

    server {
            listen 80;
            server_name www.kgc.com;
            deny 192.168.47.101/24;
    #拒绝192.168.47.102地址访问此网页
            root /data/nginx/pc/;
     
    }

④在其他2台pc的/etc/hosts文件中添加 192.168.47.102 www.kgc.com,然后访问。

3.2.自定义错误页面

① 子配置文件中添加配置如果报错404则跳转到/data/nginx/html/pc/40x.html

    server {
       listen 80;
       server_name www.kgc.com;
       error_page 404 /40x.html;
    #配置报错404则跳转到/根目录下的40x.html文件中
       location / {
            root /data/nginx/html/pc;
     }
    }

②在 /data/nginx/html/pc目录下创建40x.html文件内容为“此页面为报错404跳转到此”。

③在机器上访问一个www.kgc.com/afasf不存在的文件则跳转到了指定的错误显示页面。

[root@wangying ~]#curl www.kgc.com/afsdsafd
此页面为报错404跳转到此

3.3.状态页开启

    server {
       listen 80;
       server_name www.kgc.com;
       location /status {
       root /data/nginx/html/pc;
       stub_status;
    #开启状态页
     }
    }

[root@wangying ~]#curl www.kgc.com/status
Active connections: 1
server accepts handled requests
 20 20 20
Reading: 0 Writing: 1 Waiting: 0
[root@wangying ~]#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值