Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use context in Server #3007

Merged
merged 8 commits into from
Mar 14, 2018
Merged

Use context in Server #3007

merged 8 commits into from
Mar 14, 2018

Conversation

juliens
Copy link
Member

@juliens juliens commented Mar 13, 2018

What does this PR do?

Use context when the server Start and then, cancel the context when we receive signals ( SIGINT, SIGTERM ).
Close timeout is no longer RequestAcceptGraceTimeout and if the Close timeout, we panic instead of os.Exit

Motivation

Separation of concern

Additional Notes

Close timeout is a timeout to wait for stop of goroutines (provider and metrics). So it make no sense to configure this timeout. Moreover if we failed to stop goroutines, it's a real problem and os.Exit is not enough verbose.

)

func (s *Server) configureSignals() {
signal.Notify(s.signals, syscall.SIGINT, syscall.SIGTERM)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You cannot remove this file

Copy link
Contributor

@ldez ldez left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@ldez ldez added the kind/enhancement a new or improved feature. label Mar 13, 2018
@ldez ldez added this to the 1.6 milestone Mar 13, 2018
server/server.go Outdated
go func() {
defer s.Close()
<-ctx.Done()
log.Infof("I have to go...")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you please use a log.Info instead of log.Infof

Copy link
Contributor

@nmengin nmengin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 🛑 👏

@@ -173,7 +174,8 @@ func runCmd(globalConfiguration *configuration.GlobalConfiguration, configFile s
acme.Get().SetConfigListenerChan(make(chan types.Configuration))
svr.AddListener(acme.Get().ListenConfiguration)
}
svr.Start()
ctx := server.ContextWithSignal(context.Background())
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should this be just in the main (or in cmd/traefik in that case). The server package doesn't really have to care about signal handling.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm ok with this, I will move ContextWithSignal

server/server.go Outdated
@@ -235,14 +252,13 @@ func (s *Server) Stop() {

// Close destroys the server
func (s *Server) Close() {
ctx, cancel := context.WithTimeout(context.Background(), time.Duration(s.globalConfiguration.LifeCycle.GraceTimeOut))
ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why the magic time number here instead of using GraceTimeOut ?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In fact, this timeout is for the stop of goroutines in Providers and Metrics, not for GraceTimeOut on entry points.
Moreover it's a technical timeout, there is no reason to configure it.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we certain that those 10 seconds are always enough for providers to finish?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In reality, I reuse the previous DefaultValue of GraceTimeOut. So, if you don't override the GraceTimeout, it will not really change the behavior. Moreover, as I change the os.Exit to panic, I think we will have more feedback if some goroutines never end or needs a bigger timeout (without change the "real" behavior, because os.Exit or panic will only change the "logs".

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Where is GraceTimeOut being used now? I see that the PR removes an existing usage but does not add it anywhere again.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Member

@mmatur mmatur left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@traefiker traefiker merged commit f993636 into traefik:master Mar 14, 2018
@juliens juliens deleted the server-context branch April 18, 2018 09:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind/enhancement a new or improved feature. size/S
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants