mirror of https://github.com/bjdgyc/anylink.git
修复ip分配的bug
This commit is contained in:
parent
273552ddfe
commit
29953911da
|
@ -49,7 +49,7 @@ func initIpPool() {
|
||||||
IpPool.IpLongMax = utils.Ip2long(net.ParseIP(base.Cfg.Ipv4End))
|
IpPool.IpLongMax = utils.Ip2long(net.ParseIP(base.Cfg.Ipv4End))
|
||||||
|
|
||||||
// 获取IpLease数据
|
// 获取IpLease数据
|
||||||
go cronIpLease()
|
//go cronIpLease()
|
||||||
}
|
}
|
||||||
|
|
||||||
func cronIpLease() {
|
func cronIpLease() {
|
||||||
|
@ -84,65 +84,79 @@ func AcquireIp(username, macAddr string, uniqueMac bool) net.IP {
|
||||||
defer ipPoolMux.Unlock()
|
defer ipPoolMux.Unlock()
|
||||||
|
|
||||||
var (
|
var (
|
||||||
err error
|
err error
|
||||||
tNow = time.Now()
|
tNow = time.Now()
|
||||||
sNow = time.Now().Add(-1 * time.Duration(base.Cfg.IpLease) * time.Second)
|
leaseTime = time.Now().Add(-1 * time.Duration(base.Cfg.IpLease) * time.Second)
|
||||||
)
|
)
|
||||||
|
|
||||||
if uniqueMac {
|
if uniqueMac {
|
||||||
// 判断是否已经分配过
|
// 判断是否已经分配过
|
||||||
mi := &dbdata.IpMap{}
|
mi := &dbdata.IpMap{}
|
||||||
err = dbdata.One("mac_addr", macAddr, mi)
|
err = dbdata.One("mac_addr", macAddr, mi)
|
||||||
|
// 查询报错
|
||||||
|
if err != nil {
|
||||||
|
if !dbdata.CheckErrNotFound(err) {
|
||||||
|
base.Error(err)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 存在ip记录
|
// 存在ip记录
|
||||||
if err == nil {
|
ipStr := mi.IpAddr
|
||||||
|
ip := net.ParseIP(ipStr)
|
||||||
|
// 跳过活跃连接
|
||||||
|
_, ok := ipActive[ipStr]
|
||||||
|
// 检测原有ip是否在新的ip池内
|
||||||
|
if IpPool.Ipv4IPNet.Contains(ip) && !ok &&
|
||||||
|
utils.Ip2long(ip) >= IpPool.IpLongMin &&
|
||||||
|
utils.Ip2long(ip) <= IpPool.IpLongMax {
|
||||||
|
mi.Username = username
|
||||||
|
mi.LastLogin = tNow
|
||||||
|
mi.UniqueMac = uniqueMac
|
||||||
|
// 回写db数据
|
||||||
|
_ = dbdata.Set(mi)
|
||||||
|
ipActive[ipStr] = true
|
||||||
|
return ip
|
||||||
|
}
|
||||||
|
_ = dbdata.Del(mi)
|
||||||
|
|
||||||
|
} else {
|
||||||
|
ipMaps := []dbdata.IpMap{}
|
||||||
|
err = dbdata.FindWhere(&ipMaps, 50, 1, "username=? and unique_mac=?", username, false)
|
||||||
|
// 查询报错
|
||||||
|
if err != nil {
|
||||||
|
if !dbdata.CheckErrNotFound(err) {
|
||||||
|
base.Error(err)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//遍历mac记录
|
||||||
|
for _, mi := range ipMaps {
|
||||||
ipStr := mi.IpAddr
|
ipStr := mi.IpAddr
|
||||||
ip := net.ParseIP(ipStr)
|
ip := net.ParseIP(ipStr)
|
||||||
|
|
||||||
// 跳过活跃连接
|
// 跳过活跃连接
|
||||||
_, ok := ipActive[ipStr]
|
if _, ok := ipActive[ipStr]; ok {
|
||||||
// 检测原有ip是否在新的ip池内
|
continue
|
||||||
if IpPool.Ipv4IPNet.Contains(ip) && !ok &&
|
}
|
||||||
|
//跳过保留ip
|
||||||
|
if mi.Keep {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if IpPool.Ipv4IPNet.Contains(ip) &&
|
||||||
|
mi.LastLogin.Before(leaseTime) && // 说明已经超过租期,可以直接使用
|
||||||
utils.Ip2long(ip) >= IpPool.IpLongMin &&
|
utils.Ip2long(ip) >= IpPool.IpLongMin &&
|
||||||
utils.Ip2long(ip) <= IpPool.IpLongMax {
|
utils.Ip2long(ip) <= IpPool.IpLongMax {
|
||||||
mi.Username = username
|
|
||||||
mi.LastLogin = tNow
|
mi.LastLogin = tNow
|
||||||
|
mi.MacAddr = macAddr
|
||||||
mi.UniqueMac = uniqueMac
|
mi.UniqueMac = uniqueMac
|
||||||
// 回写db数据
|
// 回写db数据
|
||||||
_ = dbdata.Set(mi)
|
_ = dbdata.Set(mi)
|
||||||
ipActive[ipStr] = true
|
ipActive[ipStr] = true
|
||||||
return ip
|
return ip
|
||||||
}
|
}
|
||||||
_ = dbdata.Del(mi)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
ipMaps := []dbdata.IpMap{}
|
|
||||||
err = dbdata.FindWhere(&ipMaps, 50, 1, "username=? and unique_mac=?", username, false)
|
|
||||||
if err == nil {
|
|
||||||
//遍历mac记录
|
|
||||||
for _, mi := range ipMaps {
|
|
||||||
ipStr := mi.IpAddr
|
|
||||||
ip := net.ParseIP(ipStr)
|
|
||||||
|
|
||||||
// 跳过活跃连接
|
|
||||||
if _, ok := ipActive[ipStr]; ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
// 跳过ip租期内数据
|
|
||||||
if _, ok := ipLease[ipStr]; ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
if IpPool.Ipv4IPNet.Contains(ip) &&
|
|
||||||
utils.Ip2long(ip) >= IpPool.IpLongMin &&
|
|
||||||
utils.Ip2long(ip) <= IpPool.IpLongMax {
|
|
||||||
mi.LastLogin = tNow
|
|
||||||
mi.MacAddr = macAddr
|
|
||||||
mi.UniqueMac = uniqueMac
|
|
||||||
// 回写db数据
|
|
||||||
_ = dbdata.Set(mi)
|
|
||||||
ipActive[ipStr] = true
|
|
||||||
return ip
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -155,22 +169,24 @@ func AcquireIp(username, macAddr string, uniqueMac bool) net.IP {
|
||||||
if _, ok := ipActive[ipStr]; ok {
|
if _, ok := ipActive[ipStr]; ok {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
// 跳过ip租期内数据
|
|
||||||
if _, ok := ipLease[ipStr]; ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
mi := &dbdata.IpMap{}
|
mi := &dbdata.IpMap{}
|
||||||
err = dbdata.One("ip_addr", ipStr, mi)
|
err = dbdata.One("ip_addr", ipStr, mi)
|
||||||
if err == nil && mi.LastLogin.Before(sNow) {
|
if err == nil {
|
||||||
// 存在记录,说明已经超过租期,可以直接使用
|
//跳过保留ip
|
||||||
mi.LastLogin = tNow
|
if mi.Keep {
|
||||||
mi.MacAddr = macAddr
|
continue
|
||||||
mi.UniqueMac = uniqueMac
|
}
|
||||||
// 回写db数据
|
if mi.LastLogin.Before(leaseTime) {
|
||||||
_ = dbdata.Set(mi)
|
// 存在记录,说明已经超过租期,可以直接使用
|
||||||
ipActive[ipStr] = true
|
mi.LastLogin = tNow
|
||||||
return ip
|
mi.MacAddr = macAddr
|
||||||
|
mi.UniqueMac = uniqueMac
|
||||||
|
// 回写db数据
|
||||||
|
_ = dbdata.Set(mi)
|
||||||
|
ipActive[ipStr] = true
|
||||||
|
return ip
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if dbdata.CheckErrNotFound(err) {
|
if dbdata.CheckErrNotFound(err) {
|
||||||
|
@ -180,9 +196,12 @@ func AcquireIp(username, macAddr string, uniqueMac bool) net.IP {
|
||||||
ipActive[ipStr] = true
|
ipActive[ipStr] = true
|
||||||
return ip
|
return ip
|
||||||
}
|
}
|
||||||
|
|
||||||
// 查询报错
|
// 查询报错
|
||||||
base.Error(err)
|
if err != nil {
|
||||||
return nil
|
base.Error(err)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
base.Warn("no ip available, please see ip_map table row")
|
base.Warn("no ip available, please see ip_map table row")
|
||||||
|
|
Loading…
Reference in New Issue