Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Run ¶
func Run( ctx context.Context, cancel context.CancelFunc, commonFlags flags.Common, serviceKey string, configStem string, serviceConfig interfaces.Configuration, startupTimer startup.Timer, dic *di.Container, handlers []interfaces.BootstrapHandler)
Run bootstraps an application. It loads configuration and calls the provided list of handlers. Any long-running process should be spawned as a go routine in a handler. Handlers are expected to return immediately. Once all of the handlers are called this function will wait for any go routines spawned inside the handlers to exit before returning to the caller. It is intended that the caller stop executing on the return of this function.
Types ¶
type Deferred ¶ added in v0.0.20
type Deferred func()
Deferred defines the signature of a function returned by RunAndReturnWaitGroup that should be executed via defer.
func RunAndReturnWaitGroup ¶ added in v0.0.15
func RunAndReturnWaitGroup( ctx context.Context, cancel context.CancelFunc, commonFlags flags.Common, serviceKey string, configStem string, serviceConfig interfaces.Configuration, configUpdatedStream config.UpdatedStream, startupTimer startup.Timer, dic *di.Container, handlers []interfaces.BootstrapHandler) (*sync.WaitGroup, Deferred, bool)
RunAndReturnWaitGroup bootstraps an application. It loads configuration and calls the provided list of handlers. Any long-running process should be spawned as a go routine in a handler. Handlers are expected to return immediately. Once all of the handlers are called this function will return a sync.WaitGroup reference to the caller. It is intended that the caller take whatever additional action makes sense before calling Wait() on the returned reference to wait for the application to be signaled to stop (and the corresponding goroutines spawned in the various handlers to be stopped cleanly).
Directories ¶
Path | Synopsis |
---|---|
****************************************************************************** * Copyright 2020 Intel Corp.
|
****************************************************************************** * Copyright 2020 Intel Corp. |
handlers
|
|