nginx 简单配置转发

问题分析
一台服务器运行多个项目的时候会遇到这样的问题:如果使用同一个tomcat来启动不同项目的话,项目之间会相互影响;如果用多个tomcat运行项目,那么在访问项目的时候又不能都使用80端口,还要加上端口号,显得很麻烦又不美观。
考虑用Nginx实现转发,目标是通过访问不同的域名实现对不同tomcat上运行的项目的跳转,例如访问www.a.com 跳转到本地的8088端口的项目,访问www.b.com跳转到本地的8080端口的项目。

配置
修改本地的hosts文件
修改IP映射文件,添加本地IP地址解析,文件位置是C:\Windows\System32\drivers\etc

127.0.0.1       www.a.com
127.0.0.1       www.b.com


这样浏览器访问www.a.com和www.b.com的时候就会直接访问本机的地址,不会去网络上询问IP地址。

添加自定义的Nginx配置文件
在nginx根目录下新建文件夹“vhost”,新建a.conf 、b.conf两个配置文件,内容如下:

a.conf 

server {
        listen       80;
        server_name  www.a.com;
        location /fileServer {
            alias D:\m2;
            autoindex on;# 显示目录
            autoindex_exact_size on;# 显示文件大小
            autoindex_localtime on;# 显示文件时间
            allow all;
            index  index.html index.htm;
        }
}


b.conf 

server {
        listen       80;
        server_name  www.b.com;
        location / {
            proxy_pass http://127.0.0.1:8080;
            proxy_set_header Host $proxy_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Via "nginx";
        }   
}

这里我把 www.a.com 对应的项目设置成文件服务器,www.b.com 对应的项目设置成本地端口号为 8080 对应的项目。

修改Nginx的配置文件
在conf文件夹下的nginx.conf文件中追加如下配置

include ../vhost/*.conf;

这样就会去读取上边自定义的配置文件。

运行项目
启动8080端口对应的tomcat,启动nginx

验证结果
浏览器访问www.a.com,结果如图

浏览器访问www.b.com ,结果如图


结果
通过简单配置实现了都使用80端口,通过不同的域名来访问不同的项目。如果需要添加其他项目了,就再添加c.conf配置项目,一个配置文件对应一个项目,维护起来也方便一些。
 

搭建过程中出现过一些问题:

nginx: [emerg] "server" directive is not allowed here in G:\Program\nginx-1.12.2/conf/../vhost/a.conf:1

查看原因 原来是 nginx.conf 的配置问题,include 放错了位置了,完整的 nginx.conf 配置如下:

events {
    worker_connections  1024;
}

http {

    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;
    keepalive_timeout  65;

    server {
        listen       80;
        server_name  localhost;

        location / {
            root   html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

	include ../vhost/*.conf;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值