CentOS 编译和配置支持 HTTPS 正向代理的 Nginx

因为身处外贸行业,最近发现在国内连接 eBay 的接口越来越不稳定了。调用一个上传图片的接口,之前两三秒就能请求完成,现在两分钟都会大概率超时,拉取订单也是类似的情况,已经严重影响到正常业务的处理。遂考虑通过在香港部署一个代理服务来实现 eBay 接口请求的中转代理,以实现提速的目的。

Nginx 本身就提供了代理服务的功能,所以就使用 Nginx 了。Nginx 代理分为“反向代理”和“正向代理”。这个“正反”的概念简单理解如下: 反向代理就是代理服务器会把客户端请求转发到服务内部,具体处理的主机对客户端是隐藏的。正向代理是代理服务器把客户请求转发给要访问的网址,这时对要访问的网站来说,客户端来源是隐藏的。所以这次我要用到的就是 Nginx 的正向代理功能。

Nginx 虽然默认虽然支持正向代理,但仅支持 HTTP 协议的网址。对于 HTTPS 协议,需要一个开源的补丁: chobits/ngx_http_proxy_connect_module。这个补丁模块需要通过编译的方式来安装 Nginx。以下是过程流水账,系统为 CentOS 7。

下载 Nginx 源码:

wget -c https://nginx.org/download/nginx-1.16.1.tar.gz

拉取 ngx_http_proxy_connect_module 补丁源码:

git cloen https://github.com/chobits/ngx_http_proxy_connect_module.git

解压 Nginx 源码并应用补丁文件:

tar zxvf nginx-1.16.1.tar.gz
cd nginx-1.16.1

patch -p1 < /home/zzxworld/src/ngx_http_proxy_connect_module/patch/proxy_connect_rewrite_101504.patch

这里要注意 patch 命令后面跟的 patch 后缀文件,不同的 Nginx 版本对应了不同的 patch 文件。具体的对应关系可以参照 ngx_http_proxy_connect_module 项目的说明。

安装 Nginx 编译依赖:

sudo yum install pcre-devel zlib-devel

开始编译 Nginx:

./configure \
    --prefix=/usr/local/nginx \
    --add-module=/home/zzxworld/src/ngx_http_proxy_connect_module

make

sudo make install

在 Nginx 中添加以下支持 HTTPS 正向代理的配置:

server {
    listen                         8080;

    resolver                       8.8.8.8;

    proxy_connect;
    proxy_connect_allow            443 563;
    proxy_connect_connect_timeout  10s;
    proxy_connect_read_timeout     10s;
    proxy_connect_send_timeout     10s;

    location / {
        proxy_pass http://$host;
        proxy_set_header Host $host;
    }
}

编译完成后使用 sudo /usr/local/nginx/sbin/nginx 启动 Nginx,然后就可以使用 IP:8080 的配置来代理要请求的地址了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CentOS 中安装 Nginx 正向代理 https,可以按照以下步骤进行: 1. 安装 NginxCentOS 中,可以使用以下命令安装 Nginx: ``` sudo yum update sudo yum install nginx ``` 2. 配置 SSL 证书 在 Nginx 中,需要使用 SSL 证书来启用 HTTPS,可以通过以下步骤来配置 SSL 证书: 1) 在服务器上安装 SSL 证书,可以通过购买 SSL 证书或使用 Let's Encrypt 免费证书。 2) 在 Nginx 配置文件中添加以下代码: ``` server { listen 443 ssl; server_name example.com; ssl_certificate /path/to/cert.pem; ssl_certificate_key /path/to/key.pem; location / { proxy_pass http://localhost:8000; 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; } } ``` 其中,/path/to/cert.pem 和 /path/to/key.pem 替换为您的 SSL 证书和密钥的路径。 3. 配置 Nginx 正向代理Nginx 中,可以使用 proxy_pass 指令来实现正向代理,可以通过以下步骤来配置 Nginx 正向代理: 1) 在 Nginx 配置文件中添加以下代码: ``` server { listen 80; server_name example.com; location / { proxy_pass https://www.example.com; 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; } } ``` 其中,example.com 替换为您的域名,https://www.example.com 替换为您需要代理的网站地址。 2) 重新加载 Nginx 配置文件: ``` sudo nginx -t sudo nginx -s reload ``` 上述命令将测试 Nginx 配置文件的语法,并重新加载配置文件。 现在您已经成功地在 CentOS 中安装了 Nginx 正向代理 HTTPS,并配置了 SSL 证书和正向代理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值