mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 22:06:20 +00:00
agent: separate service and check loading/unloading concerns
This commit is contained in:
parent
0b9f2b0954
commit
cfde9313de
@ -142,10 +142,10 @@ func Create(config *Config, logOutput io.Writer) (*Agent, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Load checks/services
|
// Load checks/services
|
||||||
if err := agent.reloadServices(config); err != nil {
|
if err := agent.loadServices(config); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if err := agent.reloadChecks(config); err != nil {
|
if err := agent.loadChecks(config); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -895,18 +895,9 @@ func (a *Agent) deletePid() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// reloadServices reloads all known services from config and state. It is used
|
// loadServices will load service definitions from configuration and persisted
|
||||||
// at initial agent startup as well as during config reloads.
|
// definitions on disk, and load them into the local agent.
|
||||||
func (a *Agent) reloadServices(conf *Config) error {
|
func (a *Agent) loadServices(conf *Config) error {
|
||||||
for _, service := range a.state.Services() {
|
|
||||||
if service.ID == consul.ConsulServiceID {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err := a.RemoveService(service.ID, false); err != nil {
|
|
||||||
return fmt.Errorf("Failed deregistering service '%s': %v", service.ID, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Register the services from config
|
// Register the services from config
|
||||||
for _, service := range conf.Services {
|
for _, service := range conf.Services {
|
||||||
ns := service.NodeService()
|
ns := service.NodeService()
|
||||||
@ -924,15 +915,24 @@ func (a *Agent) reloadServices(conf *Config) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// reloadChecks reloads all known checks from config and state. It can be used
|
// unloadServices will deregister all services other than the 'consul' service
|
||||||
// during initial agent start or for config reloads.
|
// known to the local agent.
|
||||||
func (a *Agent) reloadChecks(conf *Config) error {
|
func (a *Agent) unloadServices() error {
|
||||||
for _, check := range a.state.Checks() {
|
for _, service := range a.state.Services() {
|
||||||
if err := a.RemoveCheck(check.CheckID, false); err != nil {
|
if service.ID == consul.ConsulServiceID {
|
||||||
return fmt.Errorf("Failed deregistering check '%s': %s", check.CheckID, err)
|
continue
|
||||||
|
}
|
||||||
|
if err := a.RemoveService(service.ID, false); err != nil {
|
||||||
|
return fmt.Errorf("Failed deregistering service '%s': %v", service.ID, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// loadChecks loads check definitions and/or persisted check definitions from
|
||||||
|
// disk and re-registers them with the local agent.
|
||||||
|
func (a *Agent) loadChecks(conf *Config) error {
|
||||||
// Register the checks from config
|
// Register the checks from config
|
||||||
for _, check := range conf.Checks {
|
for _, check := range conf.Checks {
|
||||||
health := check.HealthCheck(conf.NodeName)
|
health := check.HealthCheck(conf.NodeName)
|
||||||
@ -949,3 +949,14 @@ func (a *Agent) reloadChecks(conf *Config) error {
|
|||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// unloadChecks will deregister all checks known to the local agent.
|
||||||
|
func (a *Agent) unloadChecks() error {
|
||||||
|
for _, check := range a.state.Checks() {
|
||||||
|
if err := a.RemoveCheck(check.CheckID, false); err != nil {
|
||||||
|
return fmt.Errorf("Failed deregistering check '%s': %s", check.CheckID, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -722,12 +722,23 @@ func (c *Command) handleReload(config *Config) *Config {
|
|||||||
c.agent.PauseSync()
|
c.agent.PauseSync()
|
||||||
defer c.agent.ResumeSync()
|
defer c.agent.ResumeSync()
|
||||||
|
|
||||||
// Reload services and check definitions
|
// First unload all checks and services. This lets us begin the reload
|
||||||
if err := c.agent.reloadServices(newConf); err != nil {
|
// with a clean slate.
|
||||||
|
if err := c.agent.unloadServices(); err != nil {
|
||||||
|
c.Ui.Error(fmt.Sprintf("Failed unloading services: %s", err))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if err := c.agent.unloadChecks(); err != nil {
|
||||||
|
c.Ui.Error(fmt.Sprintf("Failed unloading checks: %s", err))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reload services and check definitions.
|
||||||
|
if err := c.agent.loadServices(newConf); err != nil {
|
||||||
c.Ui.Error(fmt.Sprintf("Failed reloading services: %s", err))
|
c.Ui.Error(fmt.Sprintf("Failed reloading services: %s", err))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if err := c.agent.reloadChecks(newConf); err != nil {
|
if err := c.agent.loadChecks(newConf); err != nil {
|
||||||
c.Ui.Error(fmt.Sprintf("Failed reloading checks: %s", err))
|
c.Ui.Error(fmt.Sprintf("Failed reloading checks: %s", err))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user