mirror of
https://github.com/nabbar/golib.git
synced 2025-12-24 11:51:02 +08:00
Package HTTP Client:
- Add DNS Mapper to force destination for a fqdn source - Allow wildcard and multi wildcard for fqdn source - DNS Mapper create Transport, Dialer & http client - DNS Mapper allow a config input to customize timeout, limit and TLS config - DNS Mapper use a gloabl transport connection poller - DNS Mapper implement DialContext & Dial method for transport - DNS Mapper use cache to accelerate process - DNS Mapper cache is only dnsmapper, not DNS cache - Replace old helper for http client with DNSMapper - Add default DNSMapper into the main lib of http client - Allow to overide the default DNS Mapper with a new one - Add ticker to force clean idle connection every given duration - "Compatible" with old config, as the default config will be used instead of old client build - Clean code and fix minor bugs - Add config component to allow use a global config - Config Component httpcli can overide default httpcli dns mapper when updated Package Certificates - Add function type to impose function that return a slice of rootCA string - update config/component/tls by replacing mutex with atomic - optimize some code Package Config - expand errors code index to add component httpcli Package Config/component: - database: add new validation, that config key existing into viper - head: add new validation, that config key existing into viper - http: add new validation, that config key existing into viper - ldap: add new validation, that config key existing into viper - log: add new validation, that config key existing into viper - mail: add new validation, that config key existing into viper - smtp: add new validation, that config key existing into viper Package AWS: - update package following update of httpcli - use interface for http cli that implement the Do function - update following the config/component/aws - rework config/component/aws to use atomic instead of mutex - update test unit following change Package Request: - update following http client update - use interface of HTTP Client that implement DO function, instead of http client struct pointer - update config & code following - apply same modification into config/component/request - update config/component/request by replacing mutex to atomic Package Server - add function Uptime to model to expose the duration since last start Package Semaphore - apply change name of constant following bump of lib associated Package Crypt - fix bug into reader to remove suffix of EOF if prevent Package Errors: - expand index module to add DNS Mapper client Package HTTP Server: - update monitor to apply changes Package Socket: - add additional check if reading error: if buffer has data, send it to handler before break run Other: - bump dependencies
This commit is contained in:
@@ -29,10 +29,9 @@ package httpserver
|
||||
import (
|
||||
"sync"
|
||||
|
||||
liblog "github.com/nabbar/golib/logger"
|
||||
|
||||
libctx "github.com/nabbar/golib/context"
|
||||
srvtps "github.com/nabbar/golib/httpserver/types"
|
||||
liblog "github.com/nabbar/golib/logger"
|
||||
montps "github.com/nabbar/golib/monitor/types"
|
||||
libsrv "github.com/nabbar/golib/server"
|
||||
libver "github.com/nabbar/golib/version"
|
||||
|
||||
@@ -30,14 +30,15 @@ import (
|
||||
"context"
|
||||
"errors"
|
||||
"fmt"
|
||||
"net"
|
||||
"runtime"
|
||||
|
||||
logent "github.com/nabbar/golib/logger/entry"
|
||||
loglvl "github.com/nabbar/golib/logger/level"
|
||||
|
||||
libmon "github.com/nabbar/golib/monitor"
|
||||
moninf "github.com/nabbar/golib/monitor/info"
|
||||
montps "github.com/nabbar/golib/monitor/types"
|
||||
libptc "github.com/nabbar/golib/network/protocol"
|
||||
libver "github.com/nabbar/golib/version"
|
||||
)
|
||||
|
||||
@@ -90,9 +91,16 @@ func (o *srv) runAndHealthy(ctx context.Context) error {
|
||||
return errNotRunning
|
||||
} else if e := o.PortNotUse(ctx, o.GetBindable()); e != nil {
|
||||
return e
|
||||
} else {
|
||||
d := &net.Dialer{}
|
||||
co, ce := d.DialContext(ctx, libptc.NetworkTCP.Code(), o.GetBindable())
|
||||
defer func() {
|
||||
if co != nil {
|
||||
_ = co.Close()
|
||||
}
|
||||
}()
|
||||
return ce
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (o *srv) MonitorName() string {
|
||||
|
||||
@@ -28,6 +28,7 @@ package pool
|
||||
|
||||
import (
|
||||
"context"
|
||||
"time"
|
||||
|
||||
libhtp "github.com/nabbar/golib/httpserver"
|
||||
)
|
||||
@@ -106,3 +107,17 @@ func (o *pool) IsRunning() bool {
|
||||
|
||||
return run
|
||||
}
|
||||
|
||||
func (o *pool) Uptime() time.Duration {
|
||||
var res time.Duration
|
||||
|
||||
o.Walk(func(name string, val libhtp.Server) bool {
|
||||
if dur := val.Uptime(); res < dur {
|
||||
res = dur
|
||||
}
|
||||
|
||||
return true
|
||||
})
|
||||
|
||||
return res
|
||||
}
|
||||
|
||||
@@ -31,6 +31,7 @@ import (
|
||||
"fmt"
|
||||
"net"
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
srvtps "github.com/nabbar/golib/httpserver/types"
|
||||
loglvl "github.com/nabbar/golib/logger/level"
|
||||
@@ -227,3 +228,14 @@ func (o *srv) runFuncStop(ctx context.Context) (err error) {
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
func (o *srv) Uptime() time.Duration {
|
||||
o.m.RLock()
|
||||
defer o.m.RUnlock()
|
||||
|
||||
if o.r != nil {
|
||||
return o.r.Uptime()
|
||||
}
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user