Nginx 可以通过 stream 模块实现基于 SSL 的 TCP 代理服务器。以下是详细说明及案例:

1. 安装 Nginx 并启用 Stream 模块

确保 Nginx 已安装并支持 stream 模块。可以通过以下命令检查:

nginx -V 2>&1 | grep -- '--with-stream'

如果没有输出,需要重新编译 Nginx 并添加 --with-stream 选项。

2. 配置 Nginx 作为 TCP 代理

编辑 Nginx 配置文件(通常位于 /etc/nginx/nginx.conf/etc/nginx/conf.d/ 目录下),添加 stream 块:

stream {
    upstream backend {
        server backend_server_ip:backend_port;
    }

    server {
        listen 443 ssl;
        proxy_pass backend;

        ssl_certificate /path/to/your/certificate.crt;
        ssl_certificate_key /path/to/your/private.key;

        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_ciphers HIGH:!aNULL:!MD5;
    }
}

3. 配置说明

  • upstream backend:定义后端服务器地址和端口。

  • server:定义 Nginx 监听的端口和 SSL 配置。

    • listen 443 ssl:监听 443 端口并启用 SSL。

    • proxy_pass backend:将流量转发到 upstream 定义的后端服务器。

    • ssl_certificatessl_certificate_key:指定 SSL 证书和私钥路径。

    • ssl_protocolsssl_ciphers:配置 SSL 协议和加密套件。

4. 案例

假设后端服务器 IP 为 192.168.1.100,端口为 3306(MySQL 数据库),Nginx 配置文件如下:

stream {
    upstream mysql_backend {
        server 192.168.1.100:3306;
    }

    server {
        listen 3306 ssl;
        proxy_pass mysql_backend;

        ssl_certificate /etc/nginx/ssl/mysql.crt;
        ssl_certificate_key /etc/nginx/ssl/mysql.key;

        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_ciphers HIGH:!aNULL:!MD5;
    }
}

5. 重启 Nginx

保存配置文件后,重启 Nginx 以应用更改:

sudo systemctl restart nginx

6. 测试

通过客户端连接 Nginx 的 3306 端口,Nginx 会将加密的 TCP 流量转发到后端 MySQL 服务器。

总结

通过 Nginx 的 stream 模块,可以轻松实现基于 SSL 的 TCP 代理服务器,确保数据传输的安全性。

本篇文章内容来源于:Nginx 基于SSL的TCP代理服务器详细说明以及案例