mirror of
https://git.sdf.org/rudi/headless9.git
synced 2026-03-22 13:27:29 +00:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
5bf240b616
|
|||
|
b06284f841
|
|||
|
7d8ef637b5
|
|||
|
5106303181
|
|||
|
d35d6d9ea4
|
74
main.go
74
main.go
@ -13,22 +13,27 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
daemon = false
|
serviceFile = "/adm/services"
|
||||||
serviceFile = "/adm/services"
|
services = make(map[string]Service)
|
||||||
services = make(map[string]Service)
|
controlSocket = "/adm/headless9/ctl/headless9.ctl"
|
||||||
controlSocket = "/adm/headless9/ctl/headless9.ctl"
|
logPath = "/adm/headless9/log/"
|
||||||
logPath = "/adm/headless9/log/"
|
execWait = false
|
||||||
|
headless9Start = time.Now()
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
if flag.NArg() == 0 {
|
if flag.NArg() == 0 {
|
||||||
|
logFile, err := os.Create(fmt.Sprintf("%+v/%+v.log", logPath, "headless9"))
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
log.SetOutput(logFile)
|
||||||
log.Println(DAEMON_START)
|
log.Println(DAEMON_START)
|
||||||
daemon = true
|
|
||||||
runDaemon()
|
runDaemon()
|
||||||
}
|
}
|
||||||
if flag.NArg() != 2 {
|
if flag.NArg() != 2 {
|
||||||
fmt.Println(CMD_SYNTAX)
|
log.Println(CMD_SYNTAX)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
verb := flag.Args()[0]
|
verb := flag.Args()[0]
|
||||||
@ -37,41 +42,33 @@ func main() {
|
|||||||
f := getCtl()
|
f := getCtl()
|
||||||
_, err := fmt.Fprintf(f, "%+v %+v", verb, service)
|
_, err := fmt.Fprintf(f, "%+v %+v", verb, service)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf(CTL_UNABLE_WRITE, controlSocket)
|
log.Fatalf(CTL_UNABLE_WRITE, controlSocket)
|
||||||
}
|
}
|
||||||
f.Close()
|
f.Close()
|
||||||
err = watchFile(controlSocket)
|
err = watchFile(controlSocket)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
}
|
}
|
||||||
fmt.Println(strings.Join(sysTail(10, controlSocket), "\n"))
|
fmt.Println(sysTail(10, controlSocket))
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func getCtl() *os.File {
|
func getCtl() *os.File {
|
||||||
f, err := os.OpenFile(controlSocket, os.O_TRUNC, 0660)
|
f, err := os.OpenFile(controlSocket, os.O_TRUNC, 0660)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if daemon {
|
log.Fatalf(CTL_NOT_OPEN, controlSocket)
|
||||||
log.Printf(CTL_NOT_OPEN, controlSocket)
|
|
||||||
} else {
|
|
||||||
fmt.Printf(CTL_NOT_OPEN, controlSocket)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
err = f.Truncate(0)
|
err = f.Truncate(0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if daemon {
|
log.Fatalf(CTL_NOT_CLEAR, controlSocket)
|
||||||
log.Printf(CTL_NOT_CLEAR, controlSocket)
|
|
||||||
} else {
|
|
||||||
fmt.Printf(CTL_NOT_CLEAR, controlSocket)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
_, err = f.Seek(0, 0)
|
_, err = f.Seek(0, 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if daemon {
|
log.Fatalf(CTL_NOT_REWOUND, controlSocket)
|
||||||
log.Printf(CTL_NOT_REWOUND, controlSocket)
|
}
|
||||||
} else {
|
f, err = os.OpenFile(controlSocket, os.O_RDWR, 0660)
|
||||||
fmt.Printf(CTL_NOT_REWOUND, controlSocket)
|
if err != nil {
|
||||||
}
|
log.Fatalf(CTL_NOT_OPEN, controlSocket)
|
||||||
}
|
}
|
||||||
return f
|
return f
|
||||||
}
|
}
|
||||||
@ -138,22 +135,28 @@ func headlessControls() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func processCommand(cmd string) error {
|
func processCommand(cmd string) error {
|
||||||
|
defer PanicSafe()
|
||||||
parts := strings.Split(cmd, " ")
|
parts := strings.Split(cmd, " ")
|
||||||
verb := parts[0]
|
verb := parts[0]
|
||||||
svc := parts[1]
|
svc := parts[1]
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
|
messages := 0
|
||||||
|
|
||||||
if verb == "restart" || verb == "stop" {
|
if verb == "restart" || verb == "stop" {
|
||||||
f, err := os.OpenFile(fmt.Sprintf("/proc/%d/ctl", services[svc].ProcessHandle.Pid), os.O_WRONLY, 0660)
|
f, err := os.OpenFile(fmt.Sprintf("/proc/%d/ctl", services[svc].ProcessHandle.Pid), os.O_WRONLY, 0660)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("")
|
log.Printf(DAEMON_CTL_FAILED, err, time.Since(start))
|
||||||
|
messages++
|
||||||
}
|
}
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
_, err = f.WriteString("kill")
|
_, err = f.WriteString("kill")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf(DAEMON_CTL_FAILED, err, time.Since(start))
|
log.Printf(DAEMON_CTL_FAILED, err, time.Since(start))
|
||||||
|
messages++
|
||||||
} else {
|
} else {
|
||||||
delete(services, svc)
|
delete(services, svc)
|
||||||
log.Printf(DAEMON_CTL_PROCESSED, svc, time.Since(start))
|
log.Printf(DAEMON_CTL_PROCESSED, svc, time.Since(start))
|
||||||
|
messages++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if verb == "restart" || verb == "start" {
|
if verb == "restart" || verb == "start" {
|
||||||
@ -168,10 +171,29 @@ func processCommand(cmd string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
log.Printf(DAEMON_SVC_MISSING, svcArgs[0])
|
log.Printf(DAEMON_SVC_MISSING, svcArgs[0])
|
||||||
|
messages++
|
||||||
|
execWait = true
|
||||||
go execCommand(svcArgs[0], svcArgs[1:]...)
|
go execCommand(svcArgs[0], svcArgs[1:]...)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for execWait {
|
||||||
|
time.Sleep(5 * time.Millisecond)
|
||||||
|
}
|
||||||
|
ctlOut := ""
|
||||||
|
if verb == "status" {
|
||||||
|
ctlOut += fmt.Sprintf("%+v up %+v PID %+v\n", svc, time.Since(services[svc].StartTime), services[svc].ProcessHandle.Pid)
|
||||||
|
ctlOut += strings.Join(sysTail(5, fmt.Sprintf("%+v/%+v.log", logPath, svc)), "\n")
|
||||||
|
} else {
|
||||||
|
|
||||||
|
ctlOut += fmt.Sprintf("%+v up %+v\n", "headless9", time.Since(headless9Start))
|
||||||
|
ctlOut += strings.Join(sysTail(messages, fmt.Sprintf("%+v/%+v.log", logPath, "headless9")), "\n")
|
||||||
|
}
|
||||||
|
f := getCtl()
|
||||||
|
_, err := fmt.Fprintf(f, "%s", ctlOut)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf(CTL_UNABLE_WRITE, controlSocket)
|
||||||
|
}
|
||||||
|
f.Close()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -210,6 +232,7 @@ func execCommand(cmd string, arg ...string) {
|
|||||||
StartupArgs: arg,
|
StartupArgs: arg,
|
||||||
StartTime: time.Now(),
|
StartTime: time.Now(),
|
||||||
}
|
}
|
||||||
|
execWait = false
|
||||||
proc.Wait()
|
proc.Wait()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -264,7 +287,6 @@ func PanicSafe(a ...interface{}) {
|
|||||||
func sysTail(count int, path string) []string {
|
func sysTail(count int, path string) []string {
|
||||||
c := exec.Command("tail", fmt.Sprintf("-%d", count+1), path)
|
c := exec.Command("tail", fmt.Sprintf("-%d", count+1), path)
|
||||||
output, _ := c.Output()
|
output, _ := c.Output()
|
||||||
//log.Printf("SysTail call output: %+v\nEND", string(output))
|
|
||||||
lines := strings.Split(string(output), "\n")
|
lines := strings.Split(string(output), "\n")
|
||||||
|
|
||||||
return lines[:len(lines)-1]
|
return lines[:len(lines)-1]
|
||||||
|
|||||||
@ -3,7 +3,7 @@ package main
|
|||||||
var (
|
var (
|
||||||
DAEMON_START = "Starting headless9"
|
DAEMON_START = "Starting headless9"
|
||||||
CMD_SYNTAX = "Command structure: \"headless9 $verb $service\""
|
CMD_SYNTAX = "Command structure: \"headless9 $verb $service\""
|
||||||
CTL_UNABLE_WRITE = "Unable to write to Control Socket. Please check the file %+v and that it's permissions are 660"
|
CTL_UNABLE_WRITE = "Unable to write to Control Socket. Please check the file %+v exists and that its permissions are 660"
|
||||||
CTL_NOT_OPEN = "Unable to open Control Socket. Please check the file %+v and that its permissions are 660"
|
CTL_NOT_OPEN = "Unable to open Control Socket. Please check the file %+v and that its permissions are 660"
|
||||||
CTL_NOT_CLEAR = "Unable to clear Control Socket. Please check the file %+v and that its permissions are 660"
|
CTL_NOT_CLEAR = "Unable to clear Control Socket. Please check the file %+v and that its permissions are 660"
|
||||||
CTL_NOT_REWOUND = "Unable to rewind Control Socket. Please check the file %+v and that its permissions are 660"
|
CTL_NOT_REWOUND = "Unable to rewind Control Socket. Please check the file %+v and that its permissions are 660"
|
||||||
|
|||||||
Reference in New Issue
Block a user