nginx 本地怎么配置多项目的访问

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx 本地怎么配置多项目的访问相关的知识,希望对你有一定的参考价值。

这个是我之前公司里面做多个项目的配置方法你可以看一下,这些都是实际经验
这里以配置2个站点(2个域名)为例,n 个站点可以相应增加调整,假设:

IP地址: 202.252.11 (IP地址和域名随便编写一个)
域名1 fengzhongjincao.com放在 /www/fengzhongjincao 域名2 meiweirenqi.com 放在 /www/meiweirenqi

配置 nginx virtual hosting 的基本思路和步骤如下:

把2个站点 fengzhongjincao.com, meiweirenqi.com 放到 nginx 可以访问的目录 /www/
给每个站点分别创建一个 nginx 配置文件fengzhongjincao.com.conf,meiweirenqi.com.conf, 并把配置文件放到 /etc/nginx/vhosts/ 然后在 /etc/nginx.conf 里面加一句 include 把步骤2创建的配置文件全部包含进来(用 * 号)
重启 nginx

具体过程

下面是具体的配置过程:

1、在 /etc/nginx 下创建 vhosts 目录

mkdir /etc/nginx/vhosts

2、在 /etc/nginx/vhosts/ 里创建一个名字为 fengzhongjincao.com.conf 的文件,把以下内容拷进去

server
listen 80;
server_name example1.com www. fengzhongjincao.com;

access_log /www/access_ fengzhongjincao.log main;

location /
root /www/fengzhongjincao.com;
index index.php index.html index.htm;


error_page 500 502 503 504 /50x.html;
location = /50x.html
root /usr/share/nginx/html;


# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \\.php$
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /www/fengzhongjincao.com/$fastcgi_script_name;
include fastcgi_params;


location ~ /\\.ht
deny all;



3、在 /etc/nginx/vhosts/ 里创建一个名字为 meiweirenqi.com.conf 的文件,把以下内容拷进去

server
listen 80;
server_name example2.com www. meiweirenqi.com;

access_log /www/access_ fengzhongjincao.log main;

location /
root /www/meiweirenqi.com;
index index.php index.html index.htm;


error_page 500 502 503 504 /50x.html;
location = /50x.html
root /usr/share/nginx/html;


# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \\.php$
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /www/meiweirenqi.com/$fastcgi_script_name;
include fastcgi_params;


location ~ /\\.ht
deny all;



4、打开 /etc/nginix.conf 文件,在相应位置加入 include 把以上2个文件包含进来

user nginx;
worker_processes 1;

# main server error log
error_log /var/log/nginx/error.log ;
pid /var/run/nginx.pid;

events
worker_connections 1024;


# main server config
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"\';

sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
gzip on;

server
listen 80;
server_name _;
access_log /var/log/nginx/access.log main;
server_name_in_redirect off;
location /
root /usr/share/nginx/html;
index index.html;



# 包含所有的虚拟主机的配置文件
include /usr/local/etc/nginx/vhosts/*;


5、重启 Nginx

/etc/init.d/nginx restart
参考技术A 给每个站点分别创建一个 nginx 配置文件fengzhongjincao.com.conf,meiweirenqi.com.conf, 并把配置文件放到 /etc/nginx/vhosts/ 然后在 /etc/nginx.conf 里面加一句 include 把步骤2创建的配置文件全部包含进来(用 * 号)!

Nginx访问异常的解决方法

Nginx访问异常的解决方法

项目场景

项目使用前端Vue+后端SpringBoot进行开发,今天试图将前端项目打包部署到本地Windows nginx上进行访问。


问题描述

于是,在nginx配置文件nginx.conf中进行了如下的配置:

 server 
        listen       80;  
        server_name  localhost;
 
        root E:\\xk_project\\vue;  
        index index.html index.htm;
 
        location /      #全匹配到index页面
             index  index.html index.htm; 
        

重启nginx后,发现前端项目无法访问。


原因分析及解决方案

通过查看nginx的错误日志文件error.log发现:

2022/03/24 09:43:27 [crit] 10204#6208: *1 GetFileAttributesEx() "C:
ginx\\webapp\\test" failed (123: The filename, directory name, or volume label syntax is incorrect), client: 127.0.0.1, server: localhost, request: "GET / HTTP/1.1", host: "127.0.0.1:8084"
2022/03/24 09:43:27 [crit] 10204#6208: *2 CreateFile() "C:
ginx\\webapp\\test/favicon.ico" failed (123: The filename, directory name, or volume label syntax is incorrect), client: 127.0.0.1, server: localhost, request: "GET /favicon.ico HTTP/1.1", host: "127.0.0.1:8084", referrer: "http://127.0.0.1:8084/"

主要原因:

Windows上路径识别问题,将配置文件(nginx.conf)的本地路径中“\\”改为“\\\\”即可。

 server 
        listen       80;  
        server_name  localhost;
    root E:\\\\xk_project\\\\vue;  
    index index.html index.htm;

    location /      #全匹配到index页面
         index  index.html index.htm; 
    


修改完成后,保存,使用命令:nginx.exe -s reload 重启nginx后,项目正常访问。

以上是关于nginx 本地怎么配置多项目的访问的主要内容,如果未能解决你的问题,请参考以下文章

vue项目用nginx写好项目本地先试试路路径问题

Nginx配置Web项目(多页面应用,单页面应用)

nginx下TP5 隐藏入口文件+支持pathinfo模式+配置多项目根目录

Nginx下配置ThinkPhp多入口访问

nginx同域名配置多目录路径

一台机器多服务部署nginx配置