本文使用Nginx作為代理服務(wù)器,用來做負載均衡。只是一個簡單的應(yīng)用示例,并不涉及原理。
(這里主機有限,42.192.22.128主機8000端口用來做代理服務(wù)器監(jiān)聽端口,8181是服務(wù)監(jiān)聽端口)
客戶端訪問代理服務(wù)器,由代理服務(wù)器分發(fā)請求給相應(yīng)的服務(wù)端。
修改Nginx的配置文件來配置Tcp負載均衡(Nginx安裝后配置文件在/usr/local/nginx/conf/nginx.config
中,Nginx可執(zhí)行程序在/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
表示權(quán)重,兩臺主機都為1,說明代理服務(wù)器會平分客戶端請求給上游服務(wù)器,max_fails
與fail_timeout
配合使用,指在fail_timeout
時間段內(nèi),如果向當前的上游服務(wù)器轉(zhuǎn)發(fā)失敗次數(shù)超過3次,則認為在當前的fail_timeout
時間段內(nèi)這臺上游服務(wù)器不可用。fail_timeout
表示該時間段內(nèi)轉(zhuǎn)發(fā)失敗多少次后就認為上游服務(wù)器暫時不可用。server
中指定了代理服務(wù)器監(jiān)聽的端口號8000
,proxy_pass
指定upstream
塊中的名字Server
。
配置完成后,使用nginx -s reload
使運行中的Nginx重讀配置項并生效。
上游服務(wù)器使用“瑞士軍刀”nc
命令來模擬TCP服務(wù)端,監(jiān)聽在相應(yīng)的端口:(這里的Ip地址是云主機的內(nèi)網(wǎng)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
,并發(fā)送消息,可以看到消息被分發(fā)到了兩臺主機上,說明客戶端的請求確實被分發(fā)到了不同的服務(wù)端上。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持。