一、stream模块介绍
????????Nginx 的 TCP/UDP 代理功能的模块分为核心模块和辅助模块。核心模块stream 需要在编译配置时增加“--with-stream”参数进行编译。stream模块一般用于TCP/UDP数据流的代理和负载均衡,通过stream模块我们可以代理转发tcp报文。
二、stream模块的作用和使用场景
????????其实介绍里已经说了,stream模块一般用于数据流的代理转发和负载均衡。这里说的代理转发,一般是对源地址有限制的环境下,就比如MySQL。外部服务器想访问mysql里的数据,但是MySQL对源地址有限制,我们就可以通过nginx做代理。还有就是实现流量的负载均衡,如果有多个TCP或UDP端口服务,我们可以通过stream模块实现数据流的负载均衡。我这边主要是用到stream模块的代理转发。
三、配置实列
????????配置方法一: 只转发一个端口,我这里只需要转发到内网MySQL的3306端口,就可以写的简单点。修改nginx.conf 配置文件。
????????注意:stream模块配置与http块和event块并列。
stream { ? ? ? ? ? ? ? ? server { ? ? ? ? ? ? listen 9003;??# 配置监听端口 ? ? ? ? ? ? proxy_connect_timeout 10s;??#设置nginx服务器和后端连接超时时间为10s ? ? ? ? ? ? proxy_timeout 30s;? ?#设置客户端和代理服务之间的超时时间,如果30秒内没操作将自动断开。 ? ? ? ? ? ? proxy_pass 127.0.0.1:3306 ;? # 转发服务器IP+端口 ? ? ? ? } }
http {
? ? ……
????????配置方法二:实现负载均衡,用include方式将我们配置实例单独配置,方便管理。在include配置的路径下添加 stream 文件。
# 修改nginx.conf 配置文件
stream { ? ? log_format proxy '$remote_addr [$time_local] ' '$protocol $status $bytes_sent $bytes_received ' '$session_time "$upstream_addr" ' '"$upstream_bytes_sent" "$upstream_bytes_received" "$upstream_connect_time"'; ? ? access_log /var/log/nginx/tcp-access.log proxy ; ? ? open_log_file_cache off; ? ? include /usr/local/nginx/conf/vhost/*.stream; }
http { ……
# 文件路径:/usr/local/nginx/conf/vhost/mysql.stream
upstream sql { ? server 192.168.1.11:3306; ? server 192.168.1.10:3306; } ? server { ? ? listen 9003 ; ?# 配置监听端口 ? ? proxy_connect_timeout 10s; ?#设置nginx服务器和后端连接超时时间为10s ? ? proxy_timeout 30s; #设置客户端和代理服务之间的超时时间,如果30秒内没操作将自动断开。 ? ? proxy_pass sql ;? # 这里的sql必须和upstream 上配置的名称一样 ? ? error_log /data/nginx/error.log ; } ?
四、使用stream时报错及处理
编辑完配置文件后,使用nginx -t 时如果有以下报错:nginx: [emerg] “stream“ directive is not allowed here in ……
那么一般有以下几种可能:
????????1. stream 模块位置没写对。仔细检查一下,一定要与http模块并列。
????????2. 没有安装stream。这个可以百度一下。
|