Replace Delay by RefreshSecond in Eureka
This commit is contained in:
parent
c4529820f2
commit
3a2b421566
5 changed files with 36 additions and 25 deletions
|
@ -432,8 +432,9 @@ func TestDo_globalConfiguration(t *testing.T) {
|
||||||
Trace: true,
|
Trace: true,
|
||||||
DebugLogGeneratedTemplate: true,
|
DebugLogGeneratedTemplate: true,
|
||||||
},
|
},
|
||||||
Endpoint: "eureka Endpoint",
|
Endpoint: "eureka Endpoint",
|
||||||
Delay: flaeg.Duration(30 * time.Second),
|
Delay: flaeg.Duration(30 * time.Second),
|
||||||
|
RefreshSeconds: flaeg.Duration(30 * time.Second),
|
||||||
}
|
}
|
||||||
config.ECS = &ecs.Provider{
|
config.ECS = &ecs.Provider{
|
||||||
BaseProvider: provider.BaseProvider{
|
BaseProvider: provider.BaseProvider{
|
||||||
|
|
|
@ -166,7 +166,7 @@ func NewTraefikDefaultPointersConfiguration() *TraefikConfiguration {
|
||||||
|
|
||||||
// default Eureka
|
// default Eureka
|
||||||
var defaultEureka eureka.Provider
|
var defaultEureka eureka.Provider
|
||||||
defaultEureka.Delay = flaeg.Duration(30 * time.Second)
|
defaultEureka.RefreshSeconds = flaeg.Duration(30 * time.Second)
|
||||||
|
|
||||||
// default ServiceFabric
|
// default ServiceFabric
|
||||||
var defaultServiceFabric servicefabric.Provider
|
var defaultServiceFabric servicefabric.Provider
|
||||||
|
|
|
@ -201,6 +201,13 @@ func (gc *GlobalConfiguration) SetEffectiveConfiguration(configFile string) {
|
||||||
gc.LifeCycle.GraceTimeOut = gc.GraceTimeOut
|
gc.LifeCycle.GraceTimeOut = gc.GraceTimeOut
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if gc.Eureka != nil {
|
||||||
|
if gc.Eureka.Delay != 0 {
|
||||||
|
log.Warn("Delay has been deprecated -- please use RefreshSeconds")
|
||||||
|
gc.Eureka.RefreshSeconds = gc.Eureka.Delay
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if gc.Rancher != nil {
|
if gc.Rancher != nil {
|
||||||
// Ensure backwards compatibility for now
|
// Ensure backwards compatibility for now
|
||||||
if len(gc.Rancher.AccessKey) > 0 ||
|
if len(gc.Rancher.AccessKey) > 0 ||
|
||||||
|
|
|
@ -21,7 +21,7 @@ endpoint = "http://my.eureka.server/eureka"
|
||||||
# Optional
|
# Optional
|
||||||
# Default: 30s
|
# Default: 30s
|
||||||
#
|
#
|
||||||
delay = "1m"
|
refreshSeconds = "1m"
|
||||||
|
|
||||||
# Override default configuration template.
|
# Override default configuration template.
|
||||||
# For advanced users :)
|
# For advanced users :)
|
||||||
|
|
|
@ -18,7 +18,8 @@ import (
|
||||||
type Provider struct {
|
type Provider struct {
|
||||||
provider.BaseProvider `mapstructure:",squash" export:"true"`
|
provider.BaseProvider `mapstructure:",squash" export:"true"`
|
||||||
Endpoint string `description:"Eureka server endpoint"`
|
Endpoint string `description:"Eureka server endpoint"`
|
||||||
Delay flaeg.Duration `description:"Override default configuration time between refresh" export:"true"`
|
Delay flaeg.Duration `description:"Override default configuration time between refresh (Deprecated)" export:"true"` // Deprecated
|
||||||
|
RefreshSeconds flaeg.Duration `description:"Override default configuration time between refresh" export:"true"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Provide allows the eureka provider to provide configurations to traefik
|
// Provide allows the eureka provider to provide configurations to traefik
|
||||||
|
@ -46,26 +47,28 @@ func (p *Provider) Provide(configurationChan chan<- types.ConfigMessage, pool *s
|
||||||
Configuration: configuration,
|
Configuration: configuration,
|
||||||
}
|
}
|
||||||
|
|
||||||
ticker := time.NewTicker(time.Duration(p.Delay))
|
ticker := time.NewTicker(time.Duration(p.RefreshSeconds))
|
||||||
safe.Go(func() {
|
pool.Go(func(stop chan bool) {
|
||||||
for t := range ticker.C {
|
for {
|
||||||
log.Debugf("Refreshing Provider %s", t.String())
|
select {
|
||||||
|
case t := <-ticker.C:
|
||||||
applications, err := client.GetApplications()
|
log.Debugf("Refreshing Provider %s", t.String())
|
||||||
if err != nil {
|
applications, err := client.GetApplications()
|
||||||
log.Errorf("Failed to retrieve applications, error: %s", err)
|
if err != nil {
|
||||||
continue
|
log.Errorf("Failed to retrieve applications, error: %s", err)
|
||||||
}
|
continue
|
||||||
|
}
|
||||||
configuration, err := p.buildConfiguration(applications)
|
configuration, err := p.buildConfiguration(applications)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("Failed to refresh Provider configuration, error: %s", err)
|
log.Errorf("Failed to refresh Provider configuration, error: %s", err)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
configurationChan <- types.ConfigMessage{
|
||||||
configurationChan <- types.ConfigMessage{
|
ProviderName: "eureka",
|
||||||
ProviderName: "eureka",
|
Configuration: configuration,
|
||||||
Configuration: configuration,
|
}
|
||||||
|
case <-stop:
|
||||||
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue