Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sevlyar/go-daemon
A library for writing system daemons in golang.
https://github.com/sevlyar/go-daemon
daemon go golang library pid pidfile
Last synced: 5 days ago
JSON representation
A library for writing system daemons in golang.
- Host: GitHub
- URL: https://github.com/sevlyar/go-daemon
- Owner: sevlyar
- License: mit
- Created: 2013-07-14T16:33:10.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2024-07-23T08:33:26.000Z (6 months ago)
- Last Synced: 2025-01-14T00:06:03.218Z (12 days ago)
- Topics: daemon, go, golang, library, pid, pidfile
- Language: Go
- Size: 181 KB
- Stars: 2,214
- Watchers: 58
- Forks: 251
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- go-awesome - go-daemon - daemon process package (Open source library / Command Line)
- awesome-golang-repositories - go-daemon
README
# go-daemon [![Build Status](https://travis-ci.org/sevlyar/go-daemon.svg?branch=master)](https://travis-ci.org/sevlyar/go-daemon) [![GoDoc](https://godoc.org/github.com/sevlyar/go-daemon?status.svg)](https://godoc.org/github.com/sevlyar/go-daemon)
Library for writing system daemons in Go.
Now supported only UNIX-based OS (Windows is not supported). But the library was tested only on Linux
and OSX, so that if you have an ability to test the library on other platforms, give me feedback, please (#26).*Please, feel free to send me bug reports and fixes. Many thanks to all contributors.*
## Features
* Goroutine-safe daemonization;
* Out of box work with pid-files;
* Easy handling of system signals;
* The control of a daemon.## Installation
go get github.com/sevlyar/go-daemon
You can use [gopkg.in](http://labix.org/gopkg.in):
go get gopkg.in/sevlyar/go-daemon.v0
If you want to use the library in production project, please use vendoring,
because i can not ensure backward compatibility before release v1.0.## Examples
* [Simple](examples/cmd/gd-simple/)
* [Log rotation](examples/cmd/gd-log-rotation/)
* [Signal handling](examples/cmd/gd-signal-handling/)## Documentation
[godoc.org/github.com/sevlyar/go-daemon](https://godoc.org/github.com/sevlyar/go-daemon)
## How it works
We can not use `fork` syscall in Golang's runtime, because child process doesn't inherit
threads and goroutines in that case. The library uses a simple trick: it runs its own copy with
a mark - a predefined environment variable. Availability of the variable for the process means
an execution in the child's copy. So that if the mark is not setted - the library executes
parent's operations and runs its own copy with mark, and if the mark is setted - the library
executes child's operations:```go
import "log"func main() {
Pre()context := new(Context)
child, _ := context.Reborn()if child != nil {
PostParent()
} else {
defer func() {
if err := context.Release(); err != nil {
log.Printf("Unable to release pid-file: %s", err.Error())
}
}()PostChild()
}
}
```![](img/idea.png)