标签:HttpServer LB 轮询 LoadBalance server 算法 CurIndex Servers
package util
import (
"fmt"
"hash/crc32"
"math/rand"
"time"
)
type HttpServer struct { //目标server类
Host string
Weight int
}
func NewHttpServer(host string, weight int) *HttpServer {
return &HttpServer{Host: host, Weight: weight}
}
type LoadBalance struct { //负载均衡类
Servers []*HttpServer
CurIndex int //指向当前访问的服务器
}
func NewLoadBalance() *LoadBalance {
return &LoadBalance{Servers: make([]*HttpServer, 0)}
}
func (this *LoadBalance) AddServer(server *HttpServer) {
this.Servers = append(this.Servers, server)
}
func (this *LoadBalance) RoundRobin() *HttpServer {
server := this.Servers[this.CurIndex]
//this.CurIndex++
//if this.CurIndex >= len(this.Servers) {
// this.CurIndex = 0
//}
this.CurIndex = (this.CurIndex + 1) % len(this.Servers) //因为一个数的余数永远在0-它本身之间,所以用这种方式得到的轮询更好
return server
}
var LB *LoadBalance
var ServerIndices []int
func init() {
LB = NewLoadBalance()
LB.AddServer(NewHttpServer("http://localhost:8001/web1", 5)) //web1
LB.AddServer(NewHttpServer("http://localhost:8002/web2", 15)) //web2
for index, server := range LB.Servers {
if server.Weight > 0 {
for i := 0; i < server.Weight; i++ {
ServerIndices = append(ServerIndices, index)
}
}
}
}
来自为知笔记(Wiz)
标签:HttpServer,LB,轮询,LoadBalance,server,算法,CurIndex,Servers 来源: https://www.cnblogs.com/hualou/p/12070723.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。