Nginx配置Tcp负载均衡的方法
本文使用Nginx作为代理服务器,用来做负载均衡。只是一个简单的应用示例,并不涉及原理。
(这里主机有限,42.192.22.128主机8000端口用来做代理服务器监听端口,8181是服务监听端口)
客户端访问代理服务器,由代理服务器分发请求给相应的服务端。
修改Nginx的配置文件来配置Tcp负载均衡(Nginx安装后配置文件在/usr/local/nginx/conf/nginx.config
中,Nginx可执行程序在/usr/local/nginx/sbin
目录下)
在nginx.conf
配置文件中添加如下字段:
stream { upstream Server { server 42.192.22.128:8181 weight=1 max_fails=3 fail_timeout=30s; server 1.13.180.100:8181 weight=1 max_fails=3 fail_timeout=30s; } server { listen 8000; proxy_pass Server; } }
这里主要涉及两个配置块upstream
和server
在upstream
中定义了两台主机,weight
表示权重,两台主机都为1,说明代理服务器会平分客户端请求给上游服务器,max_fails
与fail_timeout
配合使用,指在fail_timeout
时间段内,如果向当前的上游服务器转发失败次数超过3次,则认为在当前的fail_timeout
时间段内这台上游服务器不可用。fail_timeout
表示该时间段内转发失败多少次后就认为上游服务器暂时不可用。server
中指定了代理服务器监听的端口号8000
,proxy_pass
指定upstream
块中的名字Server
。
配置完成后,使用nginx -s reload
使运行中的Nginx重读配置项并生效。
上游服务器使用“瑞士军刀”nc
命令来模拟TCP服务端,监听在相应的端口:(这里的Ip地址是云主机的内网ip)
客户端用一个简单的Qt小程序模拟一下:
void Widget::on_btnConnection_clicked() { m_pTcpSocket->connectToHost(ui->lineeditIp->text(), ui->lineeditPort->text().toUShort()); qDebug() << m_pTcpSocket->state(); } void Widget::on_btnSend_clicked() { qDebug() << m_pTcpSocket->state(); QByteArray byteArray; byteArray.append(ui->texteditMsg->toPlainText()); const char *pChatMsg = byteArray.data(); qDebug() << m_pTcpSocket->write(pChatMsg, byteArray.size()); }
先后启动两个客户端,通过TCP连接至42.192.22.128:8000
,并发送消息,可以看到消息被分发到了两台主机上,说明客户端的请求确实被分发到了不同的服务端上。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Nginx 配置 ModSecurity 网络应用防火墙实现
这篇文章主要介绍了Nginx 配置 ModSecurity 网络应用防火墙实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-12-12nginx服务器access日志中大量400 bad request错误的解决方法
这篇文章主要介绍了nginx服务器access日志中大量400 bad request错误的解决方法,本文结论是空主机头导致的大量400错误日志,关闭默认主机的日志记录就可以解决问题,需要的朋友可以参考下2015-01-01Nginx CertBot配置HTTPS泛域名证书Debian及常见问题
这篇文章主要介绍了Nginx CertBot配置HTTPS泛域名证书Debian及常见问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11Nginx+cpolar实现内网穿透多个Windows Web站点端口的步骤详解
这篇文章主要给大家介绍了Nginx+cpolar实现内网穿透多个Windows Web站点端口的详细步骤,文章通过图文介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下2023-10-10
最新评论