Nginx基础教程(94)Nginx Stream机制之处理引擎:Nginx Stream:原来你是这样一位“网络交通指挥官”!

你以为Nginx只会做网站服务器?那可就太小看它了。这个看似普通的软件,其实是一位出色的网络交通指挥官。

1. 什么是Nginx Stream?为什么你需要了解它?

简单来说,Nginx Stream模块就是一个四层代理工具,专门处理原始TCP和UDP数据流。与我们熟知的HTTP模块(处理第七层应用数据)不同,Stream模块工作在更底层,就像一位指挥交通的警察,不关心车辆里坐着什么人,只负责把它们引导到正确的目的地。

传统Nginx主要处理HTTP/HTTPS请求:你访问一个网站,Nginx根据URL路径决定如何响应。

# 这是你熟悉的HTTP配置
server {
    listen 80;
    server_name example.com;
    location / {
        proxy_pass http://backend;
    }
}

Nginx Stream则处理任意TCP/UDP协议:数据库连接、邮件服务、DNS查询等。

# 这是Stream配置,完全不同!
stream {
    upstream dns_servers {
        server 192.168.0.1:53535;
        server dns.example.com:53;
    }
    
    server {
        listen 53 udp;
        proxy_pass dns_servers;
    }
}

那么,为什么你需要了解Stream模块呢?因为在现代微服务架构中,很多核心服务并不使用HTTP协议。数据库、消息队列、自定义RPC服务等都直接基于TCP/UDP。通过Nginx Stream,你可以为这些服务增加负载均衡、故障转移和安全防护能力,极大地提升系统整体的稳定性和可扩展性

2. 初窥门径:Stream模块基础配置

要使用Stream功能,首先需要在编译Nginx时加上--with-stream参数。现在大多数预编译版本都已经包含此模块。

Stream配置不能放在http块内,而必须与events同级。通常,我们将其直接放在nginx.conf主配置文件中:

# 主配置文件 nginx.conf
events {
    worker_connections 1024;
}

# Stream配置在这里,与events同级
stream {
    upstream mysql_backend {
        server 192.168.58.143:3306 weight=5;
        server 192.168.58.142:3306 weight=1;
    }
    
    server {
        listen 9945;
        proxy_connect_timeout 1s;
        proxy_timeout 3s;
        proxy_pass mysql_backend;
    }
}

http {
    # 这里是你熟悉的HTTP配置
    server {
        listen 80;
        # ... 
    }
}

这个配置示例创建了一个MySQL数据库的负载均衡代理。客户端不再直接连接数据库服务器,而是连接到Nginx的9945端口,由Nginx将连接转发到后端的实际数据库服务器。

重要提醒

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

值引力

持续创作,多谢支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值