Nginx配置多个服务共用80端口

本文介绍如何通过Nginx的代理转发功能实现在同一台服务器上多个服务共用80端口的方法,详细解释了如何配置Nginx以支持vue.msg.com和react.msg.com两个二级域名分别访问不同的项目。

对于Web而已,80端口和443端口是十分重要的,原则上需要输入http://domain.com:80才可以浏览网页的,但由于默认端口是80,所以‘:80’可以忽略。同理对于https的443端口也一样。

随着服务器性能的提升和业务的需求,一台服务器上往往会同时有多个服务,这些服务都希望监听80端口,比如有vue.msg.com和react.msg.com。这时候我们可以使用nginx的代理转发功能帮我们实现共用80端口的需求。


13908708-b6c16f70271cce1a.png
http

首先我们先在两个空闲的端口上分别部署项目(非80,假设是8080和8081),nginx.conf配置如下:

$ vim /ect/nginx/nginx.conf
// nginx.conf
# vue项目配置
server {
    listen       8080;
    root         /web/vue-base-demo/dist/;
    index        index.html;
    location / {
        try_files $uri $uri/ /index.html; # 路由模式history的修改
    }
}

# react项目配置
server {
    listen       8081;
    root         /web/react-base-demo/build;
    index        index.html;
    location / {}
}

上面就是常规的配置,紧接着如果已经做好域名解析,希望vue.msg.com打开vue项目,react.msg.com打开react项目。我们需要再做两个代理,如下:

// nginx.conf
# nginx 80端口配置 (监听vue二级域名)
server {
    listen  80;
    server_name     vue.msg.com;
    location / {
        proxy_pass      http://localhost:8080; # 转发
    }
}

# nginx 80端口配置 (监听react二级域名)
server {
    listen  80;
    server_name     react.msg.com;
    location / {
        proxy_pass      http://localhost:8081; # 转发
    }
}

nginx如果检测到vue.msg.com的请求,将原样转发请求到本机的8080端口,如果检测到的是react.msg.com请求,也会将请求转发到8081端口。

这样nginx对外就有四个服务,我们只需要公布80端口的就可以了,这样就实现了多个服务共用80端口。

Nginx是一个流行的Web服务器以及反向代理框架,它具有高性能、稳定性和可扩展性等优点。在使用Nginx时,我们可能会需要在同一台服务器上运行多个站点,这时候就需要用到多站点共用80端口配置。 首先,我们需要在Nginx配置文件中指定各自站点的位置,比如可以用类似下面的方式指定两个站点的位置: ```nginx server { listen 80; server_name site1.com; root /var/www/site1.com/; index index.html; } server { listen 80; server_name site2.com; root /var/www/site2.com/; index index.html; } ``` 在以上的配置中,我们分别指定了两个站点的名称、根目录位置和默认文档,同时将监听端口设置为80以确保多个站点可以共用同一个端口。 接着,我们需要将各自站点的请求进行转发。这时候我们可以使用Nginx的location指令来指定转发规则,比如下面的例子中我们将所有以/site1开头的请求都转发到site1站点的根目录下: ```nginx location /site1 { proxy_pass http://site1.com/; } ``` 类似地,我们也可以为site2站点指定请求的转发规则。这样,当用户访问site1.com/site1或者site2.com/site2时,Nginx会按照预设规则进行请求转发,从而保证了多个站点可以共用80端口的访问请求。 总结起来,在Nginx配置多个站点共用80端口时,我们需要首先指定各自站点的位置和监听端口,然后通过location指令来指定请求的转发规则。这样,我们就可以使得多个站点在同一台服务器上运行,且共用同一个80端口的访问请求。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值