Im getting the below error msg while stopping the service in windows server 2008 r2.
package main
import (
"flag"
"net"
"net/http"
"github.com/kardianos/service"
"./mygopackage"
)
var logger service.Logger
var ln net.Listener
type program struct {
exit chan struct{}
}
func (p *program) Start(s service.Service) error {
if service.Interactive() {
logger.Info("Running in terminal.")
} else {
logger.Info("Running under service manager.")
}
p.exit = make(chan struct{})
// Start should not block. Do the actual work async.
go p.run()
return nil
}
func (p *program) run() {
log.Info("Listening on :8081")
ln, err := net.Listen("tcp", ":8081")
if err != nil {
log.Error("Err listening specified port:", err)
}
go mygopackage.do()
http.HandleFunc("/plugins", plugins)
http.Serve(ln, nil)
}
func (p *program) Stop(s service.Service) error {
// Any work in Stop should be quick, usually a few seconds at most.
ln.Close()
log.Info("Stopping SaaSAgent...!")
close(p.exit)
return nil
}
func main() {
svcFlag := flag.String("service", "", "Control the system service.")
flag.Parse()
svcConfig := &service.Config{
Name: "myapp",
DisplayName: "myapp",
Description: "myapp Service :)",
}
prg := &program{}
s, err := service.New(prg, svcConfig)
if err != nil {
log.Error(err)
}
errs := make(chan error, 5)
logger, err = s.Logger(errs)
if err != nil {
log.Error(err)
}
go func() {
for {
err := <-errs
if err != nil {
log.Error(err)
}
}
}()
if len(*svcFlag) != 0 {
err := service.Control(s, *svcFlag)
if err != nil {
log.Info("Valid actions: %q\n", service.ControlAction)
log.Error(err)
}
return
}
err = s.Run()
if err != nil {
logger.Error(err)
}
}