From a66623496a8e9fb38e5aace0c1f5983140a91f78 Mon Sep 17 00:00:00 2001 From: Jeff Mitchell Date: Wed, 28 Jun 2017 18:52:00 -0400 Subject: [PATCH] Don't dial on backend startup; retry dials at log time so that transient network failures are worked around. Also, during a reconnect always close the existing connection. Fixes #2931 --- builtin/audit/socket/backend.go | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/builtin/audit/socket/backend.go b/builtin/audit/socket/backend.go index 0507af3c2b8d..bf0ce7f2157f 100644 --- a/builtin/audit/socket/backend.go +++ b/builtin/audit/socket/backend.go @@ -72,13 +72,7 @@ func Factory(conf *audit.BackendConfig) (audit.Backend, error) { logRaw = b } - conn, err := net.Dial(socketType, address) - if err != nil { - return nil, err - } - b := &Backend{ - connection: conn, saltConfig: conf.SaltConfig, saltView: conf.SaltView, formatConfig: audit.FormatterConfig{ @@ -182,6 +176,12 @@ func (b *Backend) LogResponse(auth *logical.Auth, req *logical.Request, } func (b *Backend) write(buf []byte) error { + if b.connection == nil { + if err := b.reconnect(); err != nil { + return err + } + } + err := b.connection.SetWriteDeadline(time.Now().Add(b.writeDuration)) if err != nil { return err @@ -196,12 +196,16 @@ func (b *Backend) write(buf []byte) error { } func (b *Backend) reconnect() error { + if b.connection != nil { + b.connection.Close() + b.connection = nil + } + conn, err := net.Dial(b.socketType, b.address) if err != nil { return err } - b.connection.Close() b.connection = conn return nil