run

A universal mechanism to manage goroutine lifecycles

  • Owner: oklog/run
  • Platform:
  • License:: Apache License 2.0
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

run

GoDoc
Build Status
Go Report Card
Apache 2 licensed

run.Group is a universal mechanism to manage goroutine lifecycles.

Create a zero-value run.Group, and then add actors to it. Actors are defined as
a pair of functions: an execute function, which should run synchronously;
and an interrupt function, which, when invoked, should cause the execute
function to return. Finally, invoke Run, which concurrently runs all of the
actors, waits until the first actor exits, invokes the interrupt functions, and
finally returns control to the caller only once all actors have returned. This
general-purpose API allows callers to model pretty much any runnable task, and
achieve well-defined lifecycle semantics for the group.

run.Group was written to manage component lifecycles in func main for
OK Log.
But it's useful in any circumstance where you need to orchestrate multiple
goroutines as a unit whole.
Click here to see a
video of a talk where run.Group is described.

Examples

context.Context

ctx, cancel := context.WithCancel(context.Background())
g.Add(func() error {
	return myProcess(ctx, ...)
}, func(error) {
	cancel()
})

net.Listener

ln, _ := net.Listen("tcp", ":8080")
g.Add(func() error {
	return http.Serve(ln, nil)
}, func(error) {
	ln.Close()
})

io.ReadCloser

var conn io.ReadCloser = ...
g.Add(func() error {
	s := bufio.NewScanner(conn)
	for s.Scan() {
		println(s.Text())
	}
	return s.Err()
}, func(error) {
	conn.Close()
})

Comparisons

Package run is somewhat similar to package
errgroup,
except it doesn't require actor goroutines to understand context semantics.

It's somewhat similar to package
tomb.v1 or
tomb.v2,
except it has a much smaller API surface, delegating e.g. staged shutdown of
goroutines to the caller.

Main metrics

Overview
Name With Owneroklog/run
Primary LanguageGo
Program languageGo (Language Count: 1)
Platform
License:Apache License 2.0
所有者活动
Created At2017-11-13 21:30:14
Pushed At2024-04-15 13:22:42
Last Commit At
Release Count2
Last Release Namev1.1.0 (Posted on )
First Release Namev1.0.0 (Posted on )
用户参与
Stargazers Count1.6k
Watchers Count31
Fork Count86
Commits Count14
Has Issues Enabled
Issues Count16
Issue Open Count1
Pull Requests Count8
Pull Requests Open Count1
Pull Requests Close Count12
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private