A Go library for creating and managing Windows services with ease.
- Install, uninstall, start, and stop Windows services
- Run your Go application as a Windows service
- Flexible configuration options for service installation
- Support for both standard and advanced installation methods
go get github.com/lib-x/winsvc
Here's a simple example of how to use the library:
package main
import (
"fmt"
"log"
"github.com/lib-x/winsvc"
)
func main() {
if winsvc.InServiceMode() {
err := winsvc.RunAsService("MyService", startServer, stopServer, false)
if err != nil {
log.Fatalf("Failed to run as service: %v", err)
}
return
}
// Run as a normal application
startServer()
}
func startServer() {
fmt.Println("Server starting...")
// Your server logic here
}
func stopServer() {
fmt.Println("Server stopping...")
// Your cleanup logic here
}
You can use the optional installation method for more control over service configuration:
package main
import (
"flag"
"fmt"
"log"
"github.com/lib-x/winsvc"
)
var (
flagServiceName = flag.String("name", "MyService", "Service name")
flagServiceDisplayName = flag.String("display", "My Service Display Name", "Service display name")
flagServiceDesc = flag.String("desc", "My service description", "Service description")
flagServiceInstall = flag.Bool("install", false, "Install the service")
)
func main() {
flag.Parse()
if *flagServiceInstall {
if err := installService(); err != nil {
log.Fatalf("Failed to install service: %v", err)
}
fmt.Println("Service installed successfully")
return
}
// Other service operations or normal application logic
}
func installService() error {
exePath, err := winsvc.GetAppPath()
if err != nil {
return fmt.Errorf("failed to get executable path: %w", err)
}
options := []winsvc.ServiceOption{
winsvc.DisplayName(*flagServiceDisplayName),
winsvc.Description(*flagServiceDesc),
winsvc.AutoStart(),
winsvc.Dependencies("dependency1", "dependency2"),
}
return winsvc.InstallServiceWithOption(exePath, *flagServiceName, nil, options...)
}
This example demonstrates how to:
- Use command-line flags to configure service properties
- Get the current executable path
- Use various service options like display name, description, start type, and dependencies
- Install the service with custom options
To install the service with this configuration, you would run:
yourprogram.exe -install -name "MyCustomService" -display "My Custom Service" -desc "This is a custom Windows service"
For detailed API documentation, please refer to the GoDoc.
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
This project was originally forked from chai2010/winsvc. We appreciate their initial work on this library.
If you encounter any bugs or have feature requests, please file an issue on the GitHub issue tracker.
For any questions or support, please contact czyt.go@gmail.com.