Nginx配置转发端口80到8080 并使得原网页不受影响

环境

  • 服务器:机房 外网统一只暴露80端口
  • 系统:CentOS 7.5
  • 面板:装了宝塔面板方便管理 7.70
  • Nginx:1.20.1

背景

  • 一台单机服务器,上面搭建了几个静态网页,现在要为服务器增添网页的后端为前端提供服务。并保证原来的静态网页访问不受影响。
  • 后端技术栈: Springboot内置Tomcat,打成jar直接执行。
  • 后端端口:8080

正文
打开Ngix配置项,如果是通过宝塔安装的话,路径是:

/www/server/nginx/conf/nginx.conf

如果通过yum安装,一般路径是:

/etc/nginx/nginx.conf

如果找不到配置文件,可以用Linux的搜索搜 nginx.conf。

打开配置文件:
nginx配置文件结构
如果对Nginx配置文件不熟悉,可以看这篇教程:Nginx 配置详解

找到 server 代码块,如果是宝塔安装,里面自带一个 phpmyadmin 的代理(phpmyadmin 是一个Web版的mysql图形管理工具)。

我们复制一个同级的 server 代码块,并按以下填写。
(如果本来配置文件里没有 server 代码块,则手动填写一个 server{} 到 http{} 代码块里)

server
    {
        listen 80;
        server_name xxx.com;   # 你的域名,没有特殊需求的话也可以填localhost。

		# 这段location用于保证原网页访问不受影响
		location / {
    		# root 填写原网页所在的文件路径。如果是宝塔安装,路径是 /www/wwwroot/xxx,xxx是之前自定义的。
    		# 如果不是宝塔,则按实际情况填写。
            root   /www/wwwroot/xxx;   
            # 下面两行代码用于自动匹配index.html ,如果用户只输入了路径没输入index.html,会自动请求到index上。
			try_files $uri $uri/ /index.html;
            index  index.html index.htm;
            }
            
		# 这段location用于将访问springboot后端的请求转发到运行中的jar包上。
    	# ^~/xxx/ 用于匹配请求Url前缀,前端访问时,统一带上xxx前缀,并且会删掉这个前缀发给后端。
        location ^~/xxx/ {
        	#	代理设置转发请求头,保证springboot后端接收到请求时能正确识别。
            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  X-NginX-Proxy true;

			# 转发到8080端口上
            proxy_pass http://localhost:8080/;
        }
    
        access_log  /www/wwwlogs/indoor_map_admin.log;
    }

比较关键的东西都打在nginx配置的注释上了,可细看。

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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端口的访问请求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值