linux使用nginx负载udp
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux使用nginx负载udp相关的知识,希望对你有一定的参考价值。
环境介绍:
centos7上搭建的dnsmasq服务,这是一款小巧的dns服务,配置简单,容易上手;
编译安装 nginx ,因为要负载udp,1.9以下的版本是不支持的,此处使用的是nginx-1.10的版本;
我们在利用nginx进行http的负载时已经很简单了,后来公司有dns负载的需求,就想用nginx做dns服务的负载,经过多次配置和测试,终于完成;
172.22.10.50 ---搭建的dnsmasq服务;
172.22.10.237 ---搭建的dnsmasq服务;
172.22.10.156 ---编译安装nginx,将客户端的dns解析请求分发到50和237两台dns服务器上;
例图:
dnsmasq的安装和配置就不多说了,换成其他的dns服务也可以,这里只讲解nginx的负载方法和配置;
下载nginx安装包(版本要大于1.9),上传至172.22.10.156;我的放到了/usr/local/src/nginx-1.10.3.tar.gz,
//首先安装编译工具、依赖包
yum -y install gcc gcc-c++ autoconf automake
yum -y install zlib zlib-devel openssl openssl-devel pcre-devel
//解压nginx:
` tar xzvf nginx-1.10.3.tar.gz`
//进入nginx目录并查看
`cd nginx-1.10.3 && ls`
有的nginx版本本身就大于1.9,但是为什么不能做到udp负载?可能是没编译所需要的模块
//查看nginx可以编译的模块;
`./configure --help`
其中有一个stream的模块,
//预编译
`./configure --with-stream`
//make编译
`make`
//安装
`make install`
此时,nginx就会安装到默认目录: /usr/local/nginx 下了;
/usr/local/nginx/conf/nginx.conf 就是nginx的主配置文件了;
**vim编辑 /usr/local/nginx/conf/nginx.conf :**
将里面的内容修改成:
`#user nobody;
worker_processes 4;
events {
worker_connections 1024;
}
stream {
upstream dns {
server 172.22.10.237:53 weight=1;
server 172.22.10.50:53 weight=1;
}
server {
listen 53 udp;
proxy_connect_timeout 1s;
proxy_timeout 20s;
proxy_pass dns;
}
}<br/>保存退出执行:
/usr/local/nginx/sbin/nginx -t` 检查配置;
这个时候就可以启动nginx了:
`/usr/local/nginx/sbin/nginx`
为了排除其他影响,建议将防火墙和selinux先关掉;172.22.10.237和172.22.10.50的防火墙也关掉,这样nginx才能访问并分发udp;
测试:
在172.22.10.237 DNS配置文件中配置一个域名解析:172.22.10.110 www.xxx.com
在172.22.10.50 DNS配置文件中配置一个域名解析:172.22.10.110 www.ppp.com
重启dns服务,让配置生效;
将客户端的dns该为 172.22.10.156 ,使用 nslookup 对172.22.10.110这个ip进行解析,你会发现,解析的结果会在 www.xxx.com 和 www.ppp.com 中来回变动,这就是nginx按照权重分配的结果了
` upstream dns {
server 172.22.10.237:53 weight=1;
server 172.22.10.50:53 weight=1;
}`
以上是关于linux使用nginx负载udp的主要内容,如果未能解决你的问题,请参考以下文章
Nginx stream 配置代理(Nginx TCP/UDP 负载均衡)