有时我们会使用一些java或node应用,但又不想让他们直接监听80端口,这时就需要用到端口转发
本文中,我们介绍Nginx如何做端口转发,还有各种转发规则
将域名转发到本地端口 首先介绍最常用的,将域名转发到本地另一个端口上
server{
listen 80;
server_nametomcat.shaochenfeng.com;
indexindex.php index.html index.htm;
location / {
proxy_passhttp://127.0.0.1:8080;
# 转发规则
proxy_set_header Host $proxy_host;
# 修改转发请求头,让8080端口的应用可以受到真实的请求
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
【运维|用Nginx做端口转发(反向代理)】这样访问 http://tomcat.shaochenfeng.com 时就会转发到本地的 8080 端口
将域名转发到另一个域名
server{
listen 80;
server_namebaidu.shaochenfeng.com;
indexindex.php index.html index.htm;
location / {
proxy_passhttp://www.baidu.com;
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;
}
}
这样访问 http://baidu.shaochenfeng.com 时就会转发到 http://www.baidu.com
本地一个端口转发到另一个端口或另一个域名
server{
listen 80;
server_name 127.0.0.1;
# 公网ip
indexindex.php index.html index.htm;
location / {
proxy_passhttp://127.0.0.1:8080;
# 或 http://www.baidu.com
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;
}
}
这样访问 http://127.0.0.1 时就会转发到本地的 8080 端口或 http://www.baidu.com
加 / 与不加 / 在配置proxy_pass代理转发时,如果后面的url加/,表示绝对根路径;如果没有/,表示相对路径
例如
- 加 /
server_name shaochenfeng.com
location /data/ {
proxy_pass http://127.0.0.1/;
}
访问 http://shaochenfeng.com/data/index.html 会转发到 http://127.0.0.1/index.html
- 不加 /
server_name shaochenfeng.com
location /data/ {
proxy_pass http://127.0.0.1;
}
访问 http://shaochenfeng.com/data/index.html 会转发到 http://127.0.0.1/data/index.html
欢迎查看更多运维技术文章 www.shaochenfeng.com
推荐阅读
- web前端|Mac搭建nodejs运行环境
- javaWeb|Linux基本使用
- 数据库|实时计算,连接时序数据库和核心业务
- Linux系统打包解压参数
- java|ceph-msg-messager|simple 代码分析
- Linux系统|互联网最受欢迎的开源Web服务器软件——Nginx的搭建和优化
- Nginx|Nginx笔记——代理服务配置
- 服务器运维|LNMP详解(八)——Nginx动静分离实战配置
- linux|Web服务(08)——Nginx的Rewrite