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 config.Configuration, startupTimer startup.Timer, dic *di.Container, handlers []handlers.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 ¶
type Deferred func()
Deferred defines the signature of a function returned by RunAndReturnWaitGroup that should be executed via defer.
func RunAndReturnWaitGroup ¶
func RunAndReturnWaitGroup( ctx context.Context, cancel context.CancelFunc, commonFlags flags.Common, serviceKey string, configStem string, serviceConfig config.Configuration, configUpdated processor.UpdatedStream, startupTimer startup.Timer, dic *di.Container, handlers []handlers.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).