mirror of
https://github.com/caddyserver/caddy.git
synced 2025-10-19 15:53:17 +00:00
tls: wait for keeping storage clean to finish when stopping
This commit is contained in:
parent
4bfc3b95b5
commit
d5b7c74c88
1 changed files with 15 additions and 7 deletions
|
@ -125,13 +125,14 @@ type TLS struct {
|
||||||
DNSRaw json.RawMessage `json:"dns,omitempty" caddy:"namespace=dns.providers inline_key=name"`
|
DNSRaw json.RawMessage `json:"dns,omitempty" caddy:"namespace=dns.providers inline_key=name"`
|
||||||
dns any // technically, it should be any/all of the libdns interfaces (RecordSetter, RecordAppender, etc.)
|
dns any // technically, it should be any/all of the libdns interfaces (RecordSetter, RecordAppender, etc.)
|
||||||
|
|
||||||
certificateLoaders []CertificateLoader
|
certificateLoaders []CertificateLoader
|
||||||
automateNames map[string]struct{}
|
automateNames map[string]struct{}
|
||||||
ctx caddy.Context
|
ctx caddy.Context
|
||||||
storageCleanTicker *time.Ticker
|
storageCleanTicker *time.Ticker
|
||||||
storageCleanStop chan struct{}
|
storageCleanStop chan struct{}
|
||||||
logger *zap.Logger
|
storageCleanStopDone chan struct{}
|
||||||
events *caddyevents.App
|
logger *zap.Logger
|
||||||
|
events *caddyevents.App
|
||||||
|
|
||||||
serverNames map[string]struct{}
|
serverNames map[string]struct{}
|
||||||
serverNamesMu *sync.Mutex
|
serverNamesMu *sync.Mutex
|
||||||
|
@ -439,6 +440,9 @@ func (t *TLS) Stop() error {
|
||||||
if t.storageCleanTicker != nil {
|
if t.storageCleanTicker != nil {
|
||||||
t.storageCleanTicker.Stop()
|
t.storageCleanTicker.Stop()
|
||||||
}
|
}
|
||||||
|
if t.storageCleanStopDone != nil {
|
||||||
|
<-t.storageCleanStopDone
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -788,16 +792,20 @@ func (t *TLS) HasCertificateForSubject(subject string) bool {
|
||||||
func (t *TLS) keepStorageClean() {
|
func (t *TLS) keepStorageClean() {
|
||||||
t.storageCleanTicker = time.NewTicker(t.storageCleanInterval())
|
t.storageCleanTicker = time.NewTicker(t.storageCleanInterval())
|
||||||
t.storageCleanStop = make(chan struct{})
|
t.storageCleanStop = make(chan struct{})
|
||||||
|
t.storageCleanStopDone = make(chan struct{})
|
||||||
go func() {
|
go func() {
|
||||||
defer func() {
|
defer func() {
|
||||||
if err := recover(); err != nil {
|
if err := recover(); err != nil {
|
||||||
log.Printf("[PANIC] storage cleaner: %v\n%s", err, debug.Stack())
|
log.Printf("[PANIC] storage cleaner: %v\n%s", err, debug.Stack())
|
||||||
|
// close the channel manually if panicked
|
||||||
|
close(t.storageCleanStopDone)
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
t.cleanStorageUnits()
|
t.cleanStorageUnits()
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-t.storageCleanStop:
|
case <-t.storageCleanStop:
|
||||||
|
close(t.storageCleanStopDone)
|
||||||
return
|
return
|
||||||
case <-t.storageCleanTicker.C:
|
case <-t.storageCleanTicker.C:
|
||||||
t.cleanStorageUnits()
|
t.cleanStorageUnits()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue