Nginx配置反向代理

Nginx配置文件:

server {
        listen       80; 
        server_name  tomcat1.com;  域名,ip本机
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location  / {
        proxy_pass   http://127.0.0.1:8280;   #本地服务端口
        index  index.html index.htm;
        }
    }

启动  Nginx:start Nginx

### 配置 Nginx 作为反向代理 #### 什么是反向代理 反向代理是一种服务器配置方式,其中 Nginx 接收客户端请求并将它们转发到后端服务器。最终由后端服务器处理请求并将结果返回给客户端[^4]。 #### 基本配置流程 为了使 Nginx 成功充当反向代理角色,需按照以下方式进行配置: 1. **安装 Nginx** 确保已正确安装 Nginx 并运行正常。如果没有安装,可通过包管理器完成安装操作。例如在 Ubuntu 上执行命令 `sudo apt-get install nginx` 安装软件[^5]。 2. **编辑 Nginx 配置文件** 打开主要的站点配置文件,默认位于 `/etc/nginx/sites-available/default` 或者自定义位置下的 `.conf` 文件中进行修改。 3. **添加反向代理规则** 假设目标是让所有发往域名 `www.example.com` 的流量被重定向至实际提供服务的地址 `http://localhost:8080` ,那么可以在对应 server block 下加入如下内容: ```nginx server { listen 80; server_name www.example.com; location / { proxy_pass http://localhost:8080; # 后端应用的真实URL proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } ``` 以上代码片段设置了基本的反向代理行为,并传递必要的头部信息以保留原始请求的相关属性[^1]。 4. **测试配置语法并重新加载 Nginx** 修改完成后保存退出,接着检验新配置是否存在错误: ```bash sudo nginx -t ``` 若无误,则刷新当前活动的服务实例使之生效: ```bash sudo systemctl reload nginx ``` #### 特殊情况考虑 - **HTTPS 支持**: 若要支持 SSL/TLS 加密通信,则需要额外引入证书材料并通过 ssl 模块启用加密通道。 - **WebSockets 处理**: 对于实时通讯协议 WebSocket (WSS),还需要特别指定升级握手相关的头字段[^3]: ```nginx location /ws/ { proxy_pass http://backend_ws_server; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } ``` #### 示例综合配置 这里给出一个较为全面的例子展示如何在一个典型的 LEMP(Linux, Nginx, MySQL/MariaDB, PHP) 架构之上叠加反向代理功能: ```nginx upstream php_backend { server unix:/run/php/php7.4-fpm.sock fail_timeout=0; } server { listen 80; server_name mysite.local; root /var/www/mysite; index index.php index.html; location /api/ { rewrite ^/api/(.*)$ /$1 break; proxy_pass http://jsonplaceholder.typicode.com/; proxy_set_header Host jsonplaceholder.typicode.com; } location / { try_files $uri $uri/ =404; } location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass php_backend; } } ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值