关于nginx的vhosts多站点配置(同一服务器下多域名访问多项目)

    技术2022-07-13  64

    按步骤操作即可。

    1.解析多个域名

    解析域名很简单,直接点击添加解析即可,下面是我解析的三个域名。

    2.修改nginx.conf主配置文件

    添加以下代码,表示会加载 vhosts目录下的 xxxx.conf子配置文件。所以子配置文件的后缀名都要为.conf

    include vhosts/*.conf;

     下面是完整的nginx.conf文件:

    #user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; #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; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; include vhosts/*.conf; #server { #listen 80; #server_name www.wananbayue.top; #charset koi8-r; #access_log logs/host.access.log main; #location / { # root html; # proxy_pass http://127.0.0.1:8090; # 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; #} # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} #} # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # HTTPS server # #server { # listen 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} }

    3.创建并编辑子配置文件

    这里只需要把主配置文件的 server{}区域复制过来,修改几个地方就行。

    子配置文件创建在该目录下:

     bear.wananbayue.top.conf子文件全部内容如下:

    #设定虚拟主机配置 server { listen 80; server_name www.bear.wananbayue.top; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; proxy_pass http://127.0.0.1:8090; 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; #} # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} }

     yexiong.wananbayue.top.conf子文件全部内容如下:

    #设定虚拟主机配置 server { listen 80; server_name www.yexiong.wananbayue.top; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; proxy_pass http://127.0.0.1:27002; 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; #} # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} }

    4.检测.conf文件是否正确并重启nginx

    首先命令进入nginx下的sbin目录下(自己安装的nginx目录)

    检测.conf文件的命令为:

    ./nginx -t

    返回结果如下图代表成功:

    重启nginx命令为:

    ./nginx -s reload

    备注:修改文件可以找个编辑器编辑,也可以直接在linux下编辑,参考:Linux下编辑文件并保存

              

     

     

     

     

     

     

     

    Processed: 0.009, SQL: 9