本文使用Nginx作為代理服務(wù)器,用來(lái)做負(fù)載均衡。只是一個(gè)簡(jiǎn)單的應(yīng)用示例,并不涉及原理。

(這里主機(jī)有限,42.192.22.128主機(jī)8000端口用來(lái)做代理服務(wù)器監(jiān)聽(tīng)端口,8181是服務(wù)監(jiān)聽(tīng)端口)
客戶(hù)端訪問(wèn)代理服務(wù)器,由代理服務(wù)器分發(fā)請(qǐng)求給相應(yīng)的服務(wù)端。
修改Nginx的配置文件來(lái)配置Tcp負(fù)載均衡(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;
? ? }
}
這里主要涉及兩個(gè)配置塊upstream和server
在upstream中定義了兩臺(tái)主機(jī),weight表示權(quán)重,兩臺(tái)主機(jī)都為1,說(shuō)明代理服務(wù)器會(huì)平分客戶(hù)端請(qǐng)求給上游服務(wù)器,max_fails與fail_timeout配合使用,指在fail_timeout時(shí)間段內(nèi),如果向當(dāng)前的上游服務(wù)器轉(zhuǎn)發(fā)失敗次數(shù)超過(guò)3次,則認(rèn)為在當(dāng)前的fail_timeout時(shí)間段內(nèi)這臺(tái)上游服務(wù)器不可用。fail_timeout表示該時(shí)間段內(nèi)轉(zhuǎn)發(fā)失敗多少次后就認(rèn)為上游服務(wù)器暫時(shí)不可用。server中指定了代理服務(wù)器監(jiān)聽(tīng)的端口號(hào)8000,proxy_pass指定upstream塊中的名字Server。
配置完成后,使用nginx -s reload使運(yùn)行中的Nginx重讀配置項(xiàng)并生效。
上游服務(wù)器使用“瑞士軍刀”nc命令來(lái)模擬TCP服務(wù)端,監(jiān)聽(tīng)在相應(yīng)的端口:(這里的Ip地址是云主機(jī)的內(nèi)網(wǎng)ip)

客戶(hù)端用一個(gè)簡(jiǎn)單的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());
}
先后啟動(dòng)兩個(gè)客戶(hù)端,通過(guò)TCP連接至42.192.22.128:8000,并發(fā)送消息,可以看到消息被分發(fā)到了兩臺(tái)主機(jī)上,說(shuō)明客戶(hù)端的請(qǐng)求確實(shí)被分發(fā)到了不同的服務(wù)端上。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。






