Nginx虚拟主机及常用服务模块详解

目录

 

一、Nginx虚拟主机

二、Nginxri日志

三Nginx常用模块

四、访问信息详解


一、Nginx虚拟主机

在nginx上可以配置多个server,每个server即一个虚拟主机,当nginx接收到请求,获取该请求中的host请求头,将host值与多个server的server_name进行匹配,由匹配成功的那个server来处理请求,然后将请求转发到server中指定不同的服务器。不同的server可以指定不同的tomcat或其它服务器,由服务器来处理请求。当只有一个服务器,所有的请求转发到同一个端口;当有多个服务器时,这些服务器对应的监听不同的端口,则请求根据配置转发到指定的端口,虚拟主机的作用真正发挥。

1、虚拟主机方式

1.基于多IP的方式

2.基于多端口的方式

3.基于多域名的方式

2、基于多IP的方式

①网卡添加子IP

[root@web01 ~]# ifconfig eth0:1 10.0.0.3/24

②第一个配置文件

[root@web01 ~]# cat /etc/nginx/conf.d/game.conf
server {
    listen 10.0.0.7:80;
    server_name localhost;

    location / {
    root /code/tuixiangzi;
    index index.html;
    }
 }

③第二个配置文件

[root@web01 ~]# cat /etc/nginx/conf.d/gametwo.conf
server {
    listen 10.0.0.3:80;
    server_name localhost;

    location / {
    root /code/tank;
    index index.html;
    }
}

④检查配置

[root@web01 ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

⑤重启访问

[root@web01 ~]# systemctl restart nginx

http://10.0.0.7/
http://10.0.0.3/

3、基于多域名的方式

①第一个配置文件

[root@web01 ~]# cat /etc/nginx/conf.d/game.conf
server {
    listen 80;
    server_name www.tuixiangzi.com;

    location / {
        root /code/tuixiangzi;
        index index.html;
    }
}

②第二个配置值文件

[root@web01 ~]# cat /etc/nginx/conf.d/gametwo.conf
server {
    listen 80;
    server_name www.tank.com;

    location / {
        root /code/tank;
        index index.html;
    }

 }

③检查配置

[root@web01 ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

④重启服务

[root@web01 ~]# systemctl restart nginx

⑤配置本地hosts访问

#修改windows的hosts文件
C:\Windows\System32\drivers\etc\hosts
10.0.0.7 www.tuixiangzi.com www.tank.com

#访问
http://www.tuixiangzi.com/
http://www.tank.com/

4、日志配置

①第一个配置

[root@web01 ~]# cat /etc/nginx/conf.d/game.conf 
server {
    listen 80;
    server_name www.tuixiangzi.com;

    access_log /var/log/nginx/www.tuixiangzi.com.log main;

    location / {
    root /code/tuixiangzi;
    index index.html;
    }
}

②第二个配置

[root@web01 ~]# cat /etc/nginx/conf.d/gametwo.conf 
server {
    listen 80;
    server_name www.tank.com;

    access_log /var/log/nginx/www.tank.com.log main;

    location / {
    root /code/tank;
    index index.html;
    }
}

5、重启访问测试

[root@web01 ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 ~]# systemctl restart nginx

[root@web01 ~]# ll /var/log/nginx/
total 136
-rw-r-----. 1 nginx adm  103660 Nov 27 09:31 access.log
-rw-r-----. 1 nginx adm   21972 Nov 27 09:36 error.log
-rw-r--r--. 1 root  root    666 Nov 27 09:36 www.tank.com.log
-rw-r--r--. 1 root  root    190 Nov 27 09:36 www.tuixiangzi.com.log

二、Nginxri日志

Nginx有非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志。日志格式通过log_format命令定义ges

1.log_fromat语法

Syntax:    log_format name [escape=default|json|none] string ...;
Default:    log_format combined "...";
Context:    http

2.默认日志格式

     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
                      
10.0.0.1 - - [27/Nov/2020:09:36:08 +0800] "GET /images/tank.ico HTTP/1.1" 200 25214 "http://www.tank.com/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36" "-"

10.0.0.1 - - [2020-11-27T10:13:58+08:00] "GET /images/modewin/help0.png HTTP/1.1" 200 27947 "http://www.tank.com/css/tank.css" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36" "-"

3.日志常用变量

$remote_addr          # 记录客户端IP地址
$remote_user          # 记录客户端用户名
$time_local              # 记录通用的本地时间
$time_iso8601         # 记录ISO8601标准格式下的本地时间
$request                   # 记录请求的方法以及请求的http协议
$status                      # 记录请求状态码(用于定位错误信息)
$body_bytes_sent    # 发送给客户端的资源字节数,不包括响应头的大小
$bytes_sent               # 发送给客户端的总字节数
$msec                        # 日志写入时间。单位为秒,精度是毫秒。
$http_referer              # 记录从哪个页面链接访问过来的
$http_user_agent      # 记录客户端浏览器相关信息
$http_x_forwarded_for #记录经过的所有服务器的IP地址
$X-Real-IP                 #记录起始的客户端IP地址和上一层客户端的IP地址
$request_length         # 请求的长度(包括请求行, 请求头和请求正文)。
$request_time            # 请求花费的时间,单位为秒,精度毫秒
# 注:如果Nginx位于负载均衡器,nginx反向代理之后, web服务器无法直接获取到客 户端真实的IP地址。
# $remote_addr获取的是反向代理的IP地址。 反向代理服务器在转发请求的http头信息中,
# 增加X-Forwarded-For信息,用来记录客户端IP地址和客户端请求的服务器地址。

4.nginx日志切割

[root@web01 ~]# vim /etc/logrotate.d/nginx 
#指定要切割的日志
/var/log/nginx/*.log {
       #每天切割日志
        daily
        #忽略日志丢失
        missingok
        #日志保留时间 52天
        rotate 52
        #日志压缩
        compress
        #延时压缩
        delaycompress
        #不切割空日志
        not if empty
        #切割好的日志权限
        create 640 nginx adm
        #开始执行脚本
        sharedscripts
        #标注脚本内容
        postrotate
                #判断nginx启动
                if [ -f /var/run/nginx.pid ]; then
                        #重新生成一个access.log
                        kill -USR1 `cat /var/run/nginx.pid`
                fi
        #脚本执行完毕
        endscript
}

三Nginx常用模块

一.目录索引模块

# ngx_http_autoindex_module

ngx_http_autoindex_module模块处理以斜杠字符('/')结尾的请求,并生成目录列表。

当ngx_http_index_module模块找不到索引文件时,通常会将请求传递给ngx_http_autoindex_module模块。

1.语法

Syntax:    autoindex on | off;
Default:    autoindex off;
Context:    http, server, location

2.配置

[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;

    location / {
        root /code/autoindex;
        autoindex on;
    }
}

3.访问网站正常,如download跳转目录页面

[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;

    location / {
        root /code/autoindex;
        index index.html;
    }

    location /download {
        root /code/autoindex;
        autoindex on;
    }
}

#创建站点目录
[root@web01 ~]# mkdir /code/autoindex/download -p
[root@web01 ~]# echo "测试autoindex模块" > /code/autoindex/index.html

#访问
http://www.autoindex.com/        为主站
http://www.autoindex.com/download/        为下载文件的目录

4.常用参数优化

#显示文件字节大小,默认是显示字节大小,配置为off之后,显示具体大小 M/G/K
Syntax:    autoindex_exact_size on | off;
Default:    autoindex_exact_size on;
Context:    http, server, location

#显示文件的修改的具体时间,默认显示的时间与真实时间相差8小时,所以配置 on
Syntax:    autoindex_localtime on | off;
Default:    autoindex_localtime off;
Context:    http, server, location

5.完整配置

[root@web01 ~]# cat /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;

    location / {
    root /code/autoindex;
    index index.html;
    }

    location /download {
    root /code/autoindex;
    autoindex on;
    autoindex_exact_size off;
    autoindex_localtime on;
    }
}

二、Nginx访问控制模块

#ngx_http_access_module

1.语法

#允许访问的语法
Syntax:    allow address | all;
Default:    —
Context:    http, server, location, limit_except

#拒绝访问的语法
Syntax:    deny address | all;
Default:    —
Context:    http, server, location, limit_except

#如果配置允许,则也要配置拒绝;配置拒绝可以单独配置

2.配置访问控制示例

拒绝指定的IP,其余的全部允许 。       也可配置允许指定的IP,其余的全部拒绝

[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;

    location / {
        root /code/autoindex;
        index index.html;
    }

    location /download {
        root /code/autoindex;
        autoindex on;
        autoindex_exact_size off;
        autoindex_localtime on;
        deny 10.0.0.1;
        allow all;
    }
}

3.nginx访问认证模块

#开启的登录认证,没有卵用
Syntax:    auth_basic string | off;
Default:    auth_basic off;
Context:    http, server, location, limit_except

#指定登录用的用户名密码文件
Syntax:    auth_basic_user_file file;
Default:    —
Context:    http, server, location, limit_except

创建密码文件

#创建密码文件需要用到 htpasswd
[root@web01 ~]# htpasswd -c /etc/nginx/auth_basic lhd
New password: 
Re-type new password: 
Adding password for user lhd

#添加一个登录用户
[root@web01 ~]# htpasswd /etc/nginx/auth_basic egon
New password: 
Re-type new password: 
Adding password for user egon

#密码文件内容
[root@web01 ~]# cat /etc/nginx/auth_basic
lhd:$apr1$A7d4BWYe$HzlIA7pjdMHBDJPuLBkvd/
egon:$apr1$psp0M3A5$601t7Am1BG3uINvuBVbFV0

 

配置访问登录

[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;
    access_log /var/log/nginx/www.autoindex.com.log main;

    location / {
        root /code/autoindex;
        index index.html;
    }

    location /download {
        root /code/autoindex;
        autoindex on;
        autoindex_exact_size off;
        autoindex_localtime on;
        auth_basic "性感荷官在线发牌!!!";
        auth_basic_user_file /etc/nginx/auth_basic;
    }
}

4.nginx状态监控模块

# ngx_http_stub_status_module

ngx_http_stub_status_module模块提供对nginx基本状态信息的访问。
默认情况下不构建此模块,应使用--with-http_stub_status_module配置参数启用它

 

#语法

Syntax:    stub_status;
Default:    —
Context:    server, location

 

#配置

[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf 
server {
    listen 80;
    server_name www.autoindex.com;
    charset utf8;
    access_log /var/log/nginx/www.autoindex.com.log main;

    location / {
        root /code/autoindex;
        index index.html;
    }

    location /download {
        root /code/autoindex;
        autoindex on;
        autoindex_exact_size off;
        autoindex_localtime on;
        auth_basic "性感荷官在线发牌!!!";
        auth_basic_user_file /etc/nginx/auth_basic;
    }

    location = /basic_status {
        stub_status;
    }
}

四、访问信息详解

#访问 http://www.autoindex.com/basic_status

#nginx七种状态
Active connections: 2 
server accepts handled requests
         2         2         2 
Reading: 0 Writing: 1 Waiting: 1

Active connections        #活跃的连接数
accepts                    #TCP连接总数
handled                    #成功的TCP连接数
requests                #成功的请求数
Reading                    #读取的请求头
Writing                    #响应
Waiting                    #等待的请求数,开启了keepalive

# 注意, 一次TCP的连接,可以发起多次http的请求, 如下参数可配置进行验证
keepalive_timeout  0;   # 类似于关闭长连接
keepalive_timeout  65;  # 65s没有活动则断开连接

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值