Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rcrowley/goagain
Zero-downtime restarts in Go
https://github.com/rcrowley/goagain
Last synced: 1 day ago
JSON representation
Zero-downtime restarts in Go
- Host: GitHub
- URL: https://github.com/rcrowley/goagain
- Owner: rcrowley
- License: other
- Created: 2011-08-27T16:55:16.000Z (over 13 years ago)
- Default Branch: master
- Last Pushed: 2019-02-13T23:18:41.000Z (almost 6 years ago)
- Last Synced: 2025-01-11T00:04:40.374Z (8 days ago)
- Language: Go
- Homepage:
- Size: 293 KB
- Stars: 2,099
- Watchers: 81
- Forks: 143
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome - rcrowley/goagain - 02 star:2.1k fork:0.1k Zero-downtime restarts in Go (Go)
README
goagain
=======Zero-downtime restarts in Go
----------------------------The `goagain` package provides primitives for bringing zero-downtime restarts to Go applications that accept connections from a [`net.TCPListener`](http://golang.org/pkg/net/#TCPListener) or [`net.UnixListener`](http://golang.org/pkg/net/#UnixListener).
Have a look at the examples because it isn't just a matter of importing the library and everything working. Your `main` function will have to accomodate the `goagain` protocols and your process will have to have some definition (however contrived you like) of a graceful shutdown process.
Installation
------------go get github.com/rcrowley/goagain
Usage
-----Send `SIGUSR2` to a process using `goagain` and it will restart without downtime.
[`example/single/main.go`](https://github.com/rcrowley/goagain/blob/master/example/single/main.go): The `Single` strategy (named because it calls `execve`(2) once) operates similarly to Nginx and Unicorn. The parent forks a child, the child execs, and then the child kills the parent. This is easy to understand but doesn't play nicely with Upstart and similar direct-supervision `init`(8) daemons. It should play nicely with `systemd`.
[`example/double/main.go`](https://github.com/rcrowley/goagain/blob/master/example/double/main.go): The `Double` strategy (named because it calls `execve`(2) twice) is **experimental** so proceed with caution. The parent forks a child, the child execs, the child signals the parent, the parent execs, and finally the parent kills the child. This is regrettably much more complicated but plays nicely with Upstart and similar direct-supervision `init`(8) daemons.