diff options
author | Alexander Kiryukhin <alexander@kiryukhin.su> | 2018-12-05 00:48:33 +0300 |
---|---|---|
committer | Alexander Kiryukhin <alexander@kiryukhin.su> | 2018-12-05 00:48:33 +0300 |
commit | c582001e89c0b81df1b9eb1e8f1857d1c075a805 (patch) | |
tree | 1269ce0169824e967e0eccc83c257f2a2ab9f445 /README.md | |
parent | 381df5413c2be2a183945aa334ff1690a2cdfb0c (diff) |
Initial commit
Diffstat (limited to 'README.md')
-rwxr-xr-x[-rw-r--r--] | README.md | 59 |
1 files changed, 58 insertions, 1 deletions
diff --git a/README.md b/README.md index c8c7853..c7beb77 100644..100755 --- a/README.md +++ b/README.md @@ -1 +1,58 @@ -# rutina
\ No newline at end of file +# rutina + +Package Rutina (russian "рутина" - ordinary boring everyday work) works like https://godoc.org/golang.org/x/sync/errgroup with small differences: + +1) propagates context to routines +2) cancels context when any routine ends with any result (not only when error result) + +## When it need? + +Usually, when yout program consists of several routines (i.e.: http server, metrics server and os signals subscriber) and you want to stop all routines when one of them ends (i.e.: by TERM os signal in signal subscriber). + +## Example + +HTTP server with graceful shutdown (`example/http_server.go`): + +``` +// New instance with builtin context. Alternative: r, ctx := rutina.WithContext(ctx) +r := rutina.New() + +srv := &http.Server{Addr: ":8080"} +http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + io.WriteString(w, "hello world\n") +}) + +// Starting http server and listen connections +r.Go(func(ctx context.Context) error { + if err := srv.ListenAndServe(); err != nil { + return err + } + log.Println("Server stopped") + return nil +}) + +// Gracefully stoping server when context canceled +r.Go(func(ctx context.Context) error { + <-ctx.Done() + log.Println("Stopping server...") + return srv.Shutdown(ctx) +}) + +// OS signals subscriber +r.Go(func(ctx context.Context) error { + sig := make(chan os.Signal, 1) + signal.Notify(sig, syscall.SIGTERM, syscall.SIGINT) + select { + case <-sig: + log.Println("TERM or INT signal received") + case <-ctx.Done(): + } + return nil +}) + +if err := r.Wait(); err != nil { + log.Fatal(err) +} + +log.Println("All routines successfully stopped") +```
\ No newline at end of file |