improve: 为 linux 添加可靠的网卡绑定
This commit is contained in:
@@ -31,7 +31,7 @@ func main() {
|
|||||||
interfaces, _ := tools.GetInterfaceAddr()
|
interfaces, _ := tools.GetInterfaceAddr()
|
||||||
for _, eth := range interfaces {
|
for _, eth := range interfaces {
|
||||||
log.Infoln("使用网卡: ", eth.Name)
|
log.Infoln("使用网卡: ", eth.Name)
|
||||||
if err = controllers.Login(eth.Addr, false); err != nil {
|
if err = controllers.Login(ð, false); err != nil {
|
||||||
log.Errorf("网卡 %s 登录出错: %v", eth.Name, err)
|
log.Errorf("网卡 %s 登录出错: %v", eth.Name, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ func Guardian() {
|
|||||||
if e == nil {
|
if e == nil {
|
||||||
for _, eth := range interfaces {
|
for _, eth := range interfaces {
|
||||||
log.Debugf("使用 %s 网口登录 ", eth.Name)
|
log.Debugf("使用 %s 网口登录 ", eth.Name)
|
||||||
e = Login(eth.Addr, true)
|
e = Login(ð, true)
|
||||||
if e != nil {
|
if e != nil {
|
||||||
log.Errorln("网口 ", eth.Name+" 登录出错: ", e)
|
log.Errorln("网口 ", eth.Name+" 登录出错: ", e)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,15 +6,14 @@ import (
|
|||||||
"github.com/Mmx233/BitSrunLoginGo/pkg/srun"
|
"github.com/Mmx233/BitSrunLoginGo/pkg/srun"
|
||||||
"github.com/Mmx233/BitSrunLoginGo/tools"
|
"github.com/Mmx233/BitSrunLoginGo/tools"
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
"net"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Login 登录逻辑
|
// Login 登录逻辑
|
||||||
func Login(localAddr net.Addr, debugOutput bool) error {
|
func Login(eth *tools.Eth, debugOutput bool) error {
|
||||||
// 登录状态检查
|
// 登录状态检查
|
||||||
|
|
||||||
httpClient := tools.HttpPackSelect(localAddr).Client
|
httpClient := tools.HttpPackSelect(eth).Client
|
||||||
conf := &srun.Conf{
|
conf := &srun.Conf{
|
||||||
Https: global.Config.Settings.Basic.Https,
|
Https: global.Config.Settings.Basic.Https,
|
||||||
LoginInfo: srun.LoginInfo{
|
LoginInfo: srun.LoginInfo{
|
||||||
@@ -38,12 +37,6 @@ func Login(localAddr net.Addr, debugOutput bool) error {
|
|||||||
return e
|
return e
|
||||||
}
|
}
|
||||||
|
|
||||||
if localAddr != nil && global.Config.Settings.Basic.UseDhcpIP {
|
|
||||||
ip = localAddr.(*net.TCPAddr).IP.String()
|
|
||||||
} else if global.Flags.ClientIP != "" {
|
|
||||||
ip = global.Flags.ClientIP
|
|
||||||
}
|
|
||||||
|
|
||||||
log.Debugln("认证客户端 ip: ", ip)
|
log.Debugln("认证客户端 ip: ", ip)
|
||||||
|
|
||||||
// 登录执行
|
// 登录执行
|
||||||
|
|||||||
@@ -11,13 +11,10 @@ var Flags struct {
|
|||||||
RunningDaemon bool
|
RunningDaemon bool
|
||||||
//强制daemon
|
//强制daemon
|
||||||
Daemon bool
|
Daemon bool
|
||||||
//指定 client ip
|
|
||||||
ClientIP string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func initFlags() {
|
func initFlags() {
|
||||||
flag.StringVar(&Flags.Path, "config", "Config.yaml", "config path")
|
flag.StringVar(&Flags.Path, "config", "Config.yaml", "config path")
|
||||||
flag.StringVar(&Flags.ClientIP, "ip", "", "client ip for login")
|
|
||||||
flag.BoolVar(&Flags.RunningDaemon, "running-daemon", false, "")
|
flag.BoolVar(&Flags.RunningDaemon, "running-daemon", false, "")
|
||||||
flag.BoolVar(&Flags.Daemon, "daemon", false, "")
|
flag.BoolVar(&Flags.Daemon, "daemon", false, "")
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|||||||
@@ -19,7 +19,6 @@ type Basic struct {
|
|||||||
SkipCertVerify bool `json:"skip_cert_verify" yaml:"skip_cert_verify" mapstructure:"skip_cert_verify"`
|
SkipCertVerify bool `json:"skip_cert_verify" yaml:"skip_cert_verify" mapstructure:"skip_cert_verify"`
|
||||||
Timeout uint `json:"timeout" yaml:"timeout" mapstructure:"timeout"`
|
Timeout uint `json:"timeout" yaml:"timeout" mapstructure:"timeout"`
|
||||||
Interfaces string `json:"interfaces" yaml:"interfaces" mapstructure:"interfaces"`
|
Interfaces string `json:"interfaces" yaml:"interfaces" mapstructure:"interfaces"`
|
||||||
UseDhcpIP bool `json:"use_dhcp_ip" yaml:"use_dhcp_ip" mapstructure:"use_dhcp_ip"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type Log struct {
|
type Log struct {
|
||||||
|
|||||||
@@ -2,8 +2,6 @@ package tools
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/Mmx233/BitSrunLoginGo/internal/global"
|
"github.com/Mmx233/BitSrunLoginGo/internal/global"
|
||||||
"github.com/Mmx233/tool"
|
|
||||||
"net"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -13,40 +11,25 @@ type Http struct {
|
|||||||
|
|
||||||
var HttpPack *Http
|
var HttpPack *Http
|
||||||
|
|
||||||
var httpTools map[net.Addr]*Http
|
var httpTools map[string]*Http
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
if global.Config.Settings.Basic.Interfaces == "" {
|
if global.Config.Settings.Basic.Interfaces == "" {
|
||||||
HttpPack = genHttpPack(nil)
|
HttpPack = genHttpPack(nil)
|
||||||
} else {
|
} else {
|
||||||
httpTools = make(map[net.Addr]*Http, 0)
|
httpTools = make(map[string]*Http, 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func HttpPackSelect(addr net.Addr) *Http {
|
func HttpPackSelect(eth *Eth) *Http {
|
||||||
if HttpPack != nil {
|
if HttpPack != nil {
|
||||||
return HttpPack
|
return HttpPack
|
||||||
}
|
}
|
||||||
if addrHttp, ok := httpTools[addr]; ok {
|
if addrHttp, ok := httpTools[eth.Name]; ok {
|
||||||
return addrHttp
|
return addrHttp
|
||||||
} else {
|
} else {
|
||||||
addrHttp = genHttpPack(addr)
|
addrHttp = genHttpPack(eth)
|
||||||
httpTools[addr] = addrHttp
|
httpTools[eth.Name] = addrHttp
|
||||||
return addrHttp
|
return addrHttp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func genHttpPack(addr net.Addr) *Http {
|
|
||||||
tr := tool.GenHttpTransport(&tool.HttpTransportOptions{
|
|
||||||
Timeout: global.Timeout,
|
|
||||||
LocalAddr: addr,
|
|
||||||
SkipSslCertVerify: global.Config.Settings.Basic.SkipCertVerify,
|
|
||||||
})
|
|
||||||
tr.Proxy = http.ProxyFromEnvironment
|
|
||||||
return &Http{
|
|
||||||
Client: tool.GenHttpClient(&tool.HttpClientOptions{
|
|
||||||
Transport: tr,
|
|
||||||
Timeout: global.Timeout,
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
29
tools/http_default.go
Normal file
29
tools/http_default.go
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
//go:build !linux
|
||||||
|
|
||||||
|
package tools
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/Mmx233/BitSrunLoginGo/internal/global"
|
||||||
|
"github.com/Mmx233/tool"
|
||||||
|
"net"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
func genHttpPack(eth *Eth) *Http {
|
||||||
|
var addr net.Addr
|
||||||
|
if eth != nil {
|
||||||
|
addr = eth.Addr
|
||||||
|
}
|
||||||
|
tr := tool.GenHttpTransport(&tool.HttpTransportOptions{
|
||||||
|
Timeout: global.Timeout,
|
||||||
|
LocalAddr: addr,
|
||||||
|
SkipSslCertVerify: global.Config.Settings.Basic.SkipCertVerify,
|
||||||
|
})
|
||||||
|
tr.Proxy = http.ProxyFromEnvironment
|
||||||
|
return &Http{
|
||||||
|
Client: tool.GenHttpClient(&tool.HttpClientOptions{
|
||||||
|
Transport: tr,
|
||||||
|
Timeout: global.Timeout,
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
}
|
||||||
45
tools/http_linux.go
Normal file
45
tools/http_linux.go
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
package tools
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/Mmx233/BitSrunLoginGo/internal/global"
|
||||||
|
"github.com/Mmx233/tool"
|
||||||
|
"net"
|
||||||
|
"net/http"
|
||||||
|
"syscall"
|
||||||
|
)
|
||||||
|
|
||||||
|
func genHttpPack(eth *Eth) *Http {
|
||||||
|
dialer := net.Dialer{
|
||||||
|
Timeout: global.Timeout,
|
||||||
|
}
|
||||||
|
if eth != nil {
|
||||||
|
dialer.LocalAddr = eth.Addr
|
||||||
|
ethName := eth.Name
|
||||||
|
dialer.Control = func(network string, address string, c syscall.RawConn) error {
|
||||||
|
var operr error
|
||||||
|
fn := func(fd uintptr) {
|
||||||
|
operr = syscall.SetsockoptString(int(fd), syscall.SOL_SOCKET, syscall.SO_BINDTODEVICE, ethName)
|
||||||
|
}
|
||||||
|
if err := c.Control(fn); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if operr != nil {
|
||||||
|
return operr
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tr := &http.Transport{
|
||||||
|
DialContext: dialer.DialContext,
|
||||||
|
TLSHandshakeTimeout: global.Timeout,
|
||||||
|
IdleConnTimeout: global.Timeout,
|
||||||
|
}
|
||||||
|
tr.Proxy = http.ProxyFromEnvironment
|
||||||
|
return &Http{
|
||||||
|
Client: tool.GenHttpClient(&tool.HttpClientOptions{
|
||||||
|
Transport: tr,
|
||||||
|
Timeout: global.Timeout,
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user