前言

上篇博文详解了通过在主配置文件Nginx.conf中引入conf.d目录中的独立配置文件来配置server块的方式来配置不同IP的虚拟主机。本篇博文将使用两种方式来配置基于不同域名的虚拟主机。

通过编辑主配置文件来配置基于不同域名的虚拟主机

编辑主配置文件Nginx.conf来配置基于域名的虚拟主机步骤如下:

  1. 准备两个不同域名对应站点的站点目录及测试页面。
用于测试的域名为:
a.iopiop.top
b.iopiop.top

所以在 /var/www/html目录下创建两个名为 /a.iopiop.top /b.iopiop.top的目录

1695712869772.png

在两个目录中加入对应的测试页面

1695718259395.png

  1. 修改主配置文件
  • 配置 a.iopiop.top
server {
        #监听端口号IPv4
        listen       80;
        #监听端口号IPv6
      # listen       [::]:81;
        #主机名 (IP)
        server_name  a.iopiop.top;
        #站点根目录(网站程序存放目录)
        root         /var/www/html/a.iopiop.top;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
    }  
  • 配置 b.iopiop.top
server {
        #监听端口号IPv4
        listen       80;
        #监听端口号IPv6
      # listen       [::]:81;
        #主机名 (IP)
        server_name  b.iopiop.top;
        #站点根目录(网站程序存放目录)
        root         /var/www/html/b.iopiop.top;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
    }  
  • 检查配置是否合法

1695720235860.png

  • 重启Nginx使配置生效

    systemctl restart nginx
  1. 访问测试
  • a.iopiop.top

1695720322382.png

  • b.iopiop.top

1695720331271.png

通过引入conf.d目录下的配置文件来配置基于不同域名的虚拟主机

  1. 在conf.d目录下创建不同虚拟主机的配置文件
  • aiopioptop.conf
    server {
        #监听端口号IPv4
        listen 80;
        #监听端口号IPv6
      # listen       [::]:83;
        #主机名 (IP)
        server_name a.iopiop.top;

        location / {
        #站点根目录(网站程序存放目录)
        root         /var/www/html/a.iopiop.top/;
        index      index.html;
        }
    }
  • biopioptop.conf
    server {
        #监听端口号IPv4
        listen 80;
        #监听端口号IPv6
      # listen       [::]:83;
        #主机名 (IP)
        server_name b.iopiop.top;

        location / {
        #站点根目录(网站程序存放目录)
        root         /var/www/html/b.iopiop.top/;
        index      index.html;
        }
    }
  1. 修改主配置文件
  • 修改nginx.conf
user root;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

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  /var/log/nginx/access.log  main;
    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;
    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;
    include /etc/nginx/conf.d/*.conf;

    server {

        include /etc/nginx/default.d/*.conf;
        error_page 404 /404.html;
            location = /40x.html {
        }
        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }


}
  • 检查配置是否合法

1695721017239.png

  • 重启Nginx使配置生效

systemctl restart nginx

  1. 访问测试
  • a.iopiop.top

1695720322382.png

  • b.iopiop.top

1695720331271.png