Compare commits
No commits in common. "7a9252692547fd65f187dbea5d523dc7604d6a60" and "ec92777135ae60c756ea554f275328859c606670" have entirely different histories.
7a92526925
...
ec92777135
@ -2,7 +2,4 @@ module ectl
|
|||||||
|
|
||||||
go 1.23.4
|
go 1.23.4
|
||||||
|
|
||||||
require (
|
require rsc.io/getopt v0.0.0-20170811000552-20be20937449 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
|
||||||
rsc.io/getopt v0.0.0-20170811000552-20be20937449 // indirect
|
|
||||||
)
|
|
||||||
|
@ -1,5 +1,2 @@
|
|||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
|
||||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
|
||||||
rsc.io/getopt v0.0.0-20170811000552-20be20937449 h1:UukjJOsjQH0DIuyyrcod6CXHS6cdaMMuJmrt+SN1j4A=
|
rsc.io/getopt v0.0.0-20170811000552-20be20937449 h1:UukjJOsjQH0DIuyyrcod6CXHS6cdaMMuJmrt+SN1j4A=
|
||||||
rsc.io/getopt v0.0.0-20170811000552-20be20937449/go.mod h1:dhCdeqAxkyt5u3/sKRkUXuHaMXUu1Pt13GTQAM2xnig=
|
rsc.io/getopt v0.0.0-20170811000552-20be20937449/go.mod h1:dhCdeqAxkyt5u3/sKRkUXuHaMXUu1Pt13GTQAM2xnig=
|
||||||
|
113
cmd/ectl/main.go
113
cmd/ectl/main.go
@ -3,7 +3,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"gopkg.in/yaml.v3"
|
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
@ -65,7 +64,8 @@ func main() {
|
|||||||
fmt.Printf("Usage: ectl service %s <service>\n", flag.Args()[1])
|
fmt.Printf("Usage: ectl service %s <service>\n", flag.Args()[1])
|
||||||
return
|
return
|
||||||
} else if flag.Args()[1] == "start" {
|
} else if flag.Args()[1] == "start" {
|
||||||
if _, err := os.Stat(path.Join(runstatedir, "esvm", flag.Args()[2])); err != nil {
|
flag.Args()[2] = strings.TrimSuffix(flag.Args()[2], ".esv")
|
||||||
|
if _, err := os.Stat(path.Join(sysconfdir, "esvm/services/", flag.Args()[2]+".esv")); err != nil {
|
||||||
log.Fatalf("Could not start service! Error: %s\n", err)
|
log.Fatalf("Could not start service! Error: %s\n", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,7 +86,8 @@ func main() {
|
|||||||
fmt.Println("Service started successfully!")
|
fmt.Println("Service started successfully!")
|
||||||
return
|
return
|
||||||
} else if flag.Args()[1] == "stop" {
|
} else if flag.Args()[1] == "stop" {
|
||||||
if _, err := os.Stat(path.Join(runstatedir, "esvm", flag.Args()[2])); err != nil {
|
flag.Args()[2] = strings.TrimSuffix(flag.Args()[2], ".esv")
|
||||||
|
if _, err := os.Stat(path.Join(sysconfdir, "esvm/services/", flag.Args()[2]+".esv")); err != nil {
|
||||||
log.Fatalf("Could not stop service! Error: %s\n", err)
|
log.Fatalf("Could not stop service! Error: %s\n", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,8 +107,9 @@ func main() {
|
|||||||
fmt.Println("Service stopped successfully!")
|
fmt.Println("Service stopped successfully!")
|
||||||
return
|
return
|
||||||
} else if flag.Args()[1] == "restart" || flag.Args()[1] == "reload" {
|
} else if flag.Args()[1] == "restart" || flag.Args()[1] == "reload" {
|
||||||
if _, err := os.Stat(path.Join(runstatedir, "esvm", flag.Args()[2])); err != nil {
|
flag.Args()[2] = strings.TrimSuffix(flag.Args()[2], ".esv")
|
||||||
log.Fatalf("Could not restart service! Error: %s\n", err)
|
if _, err := os.Stat(path.Join(sysconfdir, "esvm/services/", flag.Args()[2]+".esv")); err != nil {
|
||||||
|
log.Fatalf("Could not stop service! Error: %s\n", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := socket.Write([]byte("restart " + flag.Args()[2]))
|
_, err := socket.Write([]byte("restart " + flag.Args()[2]))
|
||||||
@ -125,105 +127,10 @@ func main() {
|
|||||||
}
|
}
|
||||||
fmt.Println("Service restarted successfully!")
|
fmt.Println("Service restarted successfully!")
|
||||||
return
|
return
|
||||||
} else if flag.Args()[1] == "enable" {
|
|
||||||
// Check if service exists
|
|
||||||
found := false
|
|
||||||
entries, err := os.ReadDir(path.Join(sysconfdir, "esvm/services/"))
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
type minimalServiceStruct struct {
|
|
||||||
Name string `yaml:"name"`
|
|
||||||
}
|
|
||||||
for _, entry := range entries {
|
|
||||||
if entry.IsDir() || !strings.HasSuffix(entry.Name(), ".esv") {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
bytes, err := os.ReadFile(path.Join(sysconfdir, "esvm/services", entry.Name()))
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
sv := minimalServiceStruct{Name: ""}
|
|
||||||
err = yaml.Unmarshal(bytes, &sv)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if sv.Name == flag.Args()[2] {
|
|
||||||
found = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if !found {
|
|
||||||
log.Fatalf("Service does not exist!")
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, err := os.Stat(path.Join(sysconfdir, "esvm/enabled_services")); err != nil {
|
|
||||||
err := os.WriteFile(path.Join(sysconfdir, "esvm/enabled_services"), []byte(flag.Args()[2]+"\n"), 0644)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
file, err := os.ReadFile(path.Join(sysconfdir, "esvm/enabled_services"))
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
for _, line := range strings.Split(string(file), "\n") {
|
|
||||||
if strings.TrimSpace(line) == flag.Args()[2] {
|
|
||||||
fmt.Println("Service is already enabled!")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
err = os.WriteFile(path.Join(sysconfdir, "esvm/enabled_services"), []byte(string(file)+flag.Args()[2]+"\n"), 0644)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not enable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Printf("Service (%s) has been enabled!\n", flag.Args()[2])
|
|
||||||
return
|
|
||||||
} else if flag.Args()[1] == "disable" {
|
|
||||||
if _, err := os.Stat(path.Join(sysconfdir, "esvm/enabled_services")); err != nil {
|
|
||||||
fmt.Println("Service is already disabled!")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
file, err := os.ReadFile(path.Join(sysconfdir, "esvm/enabled_services"))
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not disable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
lines := strings.Split(string(file), "\n")
|
|
||||||
found := false
|
|
||||||
for i := len(lines) - 1; i >= 0; i-- {
|
|
||||||
line := strings.TrimSpace(lines[i])
|
|
||||||
if strings.TrimSpace(line) == flag.Args()[2] {
|
|
||||||
lines = append(lines[:i], lines[i+1:]...)
|
|
||||||
found = true
|
|
||||||
} else if strings.TrimSpace(line) == "" {
|
|
||||||
lines = append(lines[:i], lines[i+1:]...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if !found {
|
|
||||||
fmt.Println("Service is already disabled!")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
err = os.WriteFile(path.Join(sysconfdir, "esvm/enabled_services"), []byte(strings.Join(lines, "\n")+"\n"), 0644)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("Could not disable service! Error: %s\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Printf("Service (%s) has been disabled!\n", flag.Args()[2])
|
|
||||||
return
|
|
||||||
} else if flag.Args()[1] == "status" {
|
} else if flag.Args()[1] == "status" {
|
||||||
if _, err := os.Stat(path.Join(runstatedir, "esvm", flag.Args()[2])); err != nil {
|
flag.Args()[2] = strings.TrimSuffix(flag.Args()[2], ".esv")
|
||||||
log.Fatalf("Could not get service status! Error: %s\n", err)
|
if _, err := os.Stat(path.Join(sysconfdir, "esvm/services/", flag.Args()[2]+".esv")); err != nil {
|
||||||
|
log.Fatalf("Could not stop service! Error: %s\n", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
var state uint64
|
var state uint64
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
@ -9,7 +8,6 @@ import (
|
|||||||
"os/exec"
|
"os/exec"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"path"
|
"path"
|
||||||
"strings"
|
|
||||||
"syscall"
|
"syscall"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
@ -42,8 +40,6 @@ func main() {
|
|||||||
mountVirtualFilesystems()
|
mountVirtualFilesystems()
|
||||||
// Mount filesystems in fstab
|
// Mount filesystems in fstab
|
||||||
mountFilesystems()
|
mountFilesystems()
|
||||||
// Set hostname
|
|
||||||
setHostname()
|
|
||||||
// Start service manager
|
// Start service manager
|
||||||
startServiceManager()
|
startServiceManager()
|
||||||
|
|
||||||
@ -77,14 +73,14 @@ func mountVirtualFilesystems() {
|
|||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
// Mount /dev/pts
|
// Mount /dev/pts
|
||||||
if err := os.Mkdir("/dev/pts", 0755); err != nil && !errors.Is(err, os.ErrExist) {
|
if err := os.Mkdir("/dev/pts", 0755); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
if err := syscall.Mount("devpts", "/dev/pts", "devpts", commonFlags, "gid=5,mode=620,ptmxmode=000"); err != nil {
|
if err := syscall.Mount("devpts", "/dev/pts", "devpts", commonFlags, "gid=5,mode=620,ptmxmode=000"); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
// Mount /dev/shm
|
// Mount /dev/shm
|
||||||
if err := os.Mkdir("/dev/shm", 0755); err != nil && !errors.Is(err, os.ErrExist) {
|
if err := os.Mkdir("/dev/shm", 0755); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
if err := syscall.Mount("shm", "/dev/shm", "tmpfs", commonFlags|syscall.MS_NODEV, "inode64"); err != nil {
|
if err := syscall.Mount("shm", "/dev/shm", "tmpfs", commonFlags|syscall.MS_NODEV, "inode64"); err != nil {
|
||||||
@ -120,8 +116,6 @@ func startServiceManager() {
|
|||||||
fmt.Print("Initializing service manager... ")
|
fmt.Print("Initializing service manager... ")
|
||||||
|
|
||||||
cmd := exec.Command("/sbin/esvm", path.Join(runstatedir, "esvm"), path.Join(sysconfdir, "esvm"))
|
cmd := exec.Command("/sbin/esvm", path.Join(runstatedir, "esvm"), path.Join(sysconfdir, "esvm"))
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
err := cmd.Start()
|
err := cmd.Start()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Could not initialize service manager!")
|
log.Println("Could not initialize service manager!")
|
||||||
@ -171,25 +165,6 @@ func stopServiceManager() {
|
|||||||
fmt.Println("Done.")
|
fmt.Println("Done.")
|
||||||
}
|
}
|
||||||
|
|
||||||
func setHostname() {
|
|
||||||
fmt.Print("Setting hostname... ")
|
|
||||||
|
|
||||||
bytes, err := os.ReadFile("/etc/hostname")
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Could not set hostname!")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
hostname := strings.TrimSpace(string(bytes))
|
|
||||||
|
|
||||||
if err := syscall.Sethostname([]byte(hostname)); err != nil {
|
|
||||||
log.Println("Could not set hostname!")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Println("Done.")
|
|
||||||
}
|
|
||||||
|
|
||||||
func waitZombieProcesses() {
|
func waitZombieProcesses() {
|
||||||
for {
|
for {
|
||||||
if wpid, _ := syscall.Wait4(-1, nil, syscall.WNOHANG, nil); wpid <= 0 {
|
if wpid, _ := syscall.Wait4(-1, nil, syscall.WNOHANG, nil); wpid <= 0 {
|
||||||
|
@ -11,7 +11,6 @@ import (
|
|||||||
"os/exec"
|
"os/exec"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"path"
|
"path"
|
||||||
"slices"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"syscall"
|
"syscall"
|
||||||
@ -36,9 +35,8 @@ type EnitService struct {
|
|||||||
Type string `yaml:"type"`
|
Type string `yaml:"type"`
|
||||||
StartCmd string `yaml:"start_cmd"`
|
StartCmd string `yaml:"start_cmd"`
|
||||||
ExitMethod string `yaml:"exit_method"`
|
ExitMethod string `yaml:"exit_method"`
|
||||||
CrashOnSafeExit bool `yaml:"crash_on_safe_exit"`
|
|
||||||
StopCmd string `yaml:"stop_cmd,omitempty"`
|
StopCmd string `yaml:"stop_cmd,omitempty"`
|
||||||
Restart string `yaml:"restart,omitempty"`
|
Restart bool `yaml:"restart,omitempty"`
|
||||||
ServiceRunPath string
|
ServiceRunPath string
|
||||||
restartCount int
|
restartCount int
|
||||||
stopChannel chan bool
|
stopChannel chan bool
|
||||||
@ -51,7 +49,6 @@ var runtimeServiceDir string
|
|||||||
var serviceConfigDir string
|
var serviceConfigDir string
|
||||||
|
|
||||||
var Services = make([]EnitService, 0)
|
var Services = make([]EnitService, 0)
|
||||||
var EnabledServices = make([]string, 0)
|
|
||||||
|
|
||||||
var logger *log.Logger
|
var logger *log.Logger
|
||||||
var socket net.Listener
|
var socket net.Listener
|
||||||
@ -147,8 +144,7 @@ func Init() {
|
|||||||
StartCmd: "",
|
StartCmd: "",
|
||||||
ExitMethod: "",
|
ExitMethod: "",
|
||||||
StopCmd: "",
|
StopCmd: "",
|
||||||
Restart: "",
|
Restart: false,
|
||||||
CrashOnSafeExit: true,
|
|
||||||
ServiceRunPath: "",
|
ServiceRunPath: "",
|
||||||
restartCount: 0,
|
restartCount: 0,
|
||||||
stopChannel: make(chan bool),
|
stopChannel: make(chan bool),
|
||||||
@ -158,12 +154,6 @@ func Init() {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, sv := range Services {
|
|
||||||
if sv.Name == service.Name {
|
|
||||||
logger.Printf("Service with name (%s) has already been initialized!", service.Name)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch service.Type {
|
switch service.Type {
|
||||||
case "simple", "background":
|
case "simple", "background":
|
||||||
default:
|
default:
|
||||||
@ -178,12 +168,6 @@ func Init() {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
switch service.Restart {
|
|
||||||
case "true", "always":
|
|
||||||
default:
|
|
||||||
service.Restart = "false"
|
|
||||||
}
|
|
||||||
|
|
||||||
service.ServiceRunPath = path.Join(runtimeServiceDir, service.Name)
|
service.ServiceRunPath = path.Join(runtimeServiceDir, service.Name)
|
||||||
err = os.MkdirAll(path.Join(service.ServiceRunPath), 0755)
|
err = os.MkdirAll(path.Join(service.ServiceRunPath), 0755)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -201,28 +185,15 @@ func Init() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get enabled services
|
// Get services that meet their dependencies
|
||||||
if _, err := os.Stat(path.Join(serviceConfigDir, "enabled_services")); err == nil {
|
|
||||||
file, err := os.ReadFile(path.Join(serviceConfigDir, "enabled_services"))
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
for _, line := range strings.Split(string(file), "\n") {
|
|
||||||
if line != "" {
|
|
||||||
EnabledServices = append(EnabledServices, line)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get enabled services that meet their dependencies
|
|
||||||
servicesWithMetDepends := make([]EnitService, 0)
|
servicesWithMetDepends := make([]EnitService, 0)
|
||||||
for _, service := range Services {
|
for _, service := range Services {
|
||||||
if slices.Contains(EnabledServices, service.Name) && len(service.GetUnmetDependencies()) == 0 {
|
if len(service.GetUnmetDependencies()) == 0 {
|
||||||
servicesWithMetDepends = append(servicesWithMetDepends, service)
|
servicesWithMetDepends = append(servicesWithMetDepends, service)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Loop until all enabled services have started or timed out
|
// Loop until all services have started or timed out
|
||||||
for start := time.Now(); time.Since(start) < 60*time.Second; {
|
for start := time.Now(); time.Since(start) < 60*time.Second; {
|
||||||
if len(servicesWithMetDepends) == 0 {
|
if len(servicesWithMetDepends) == 0 {
|
||||||
break
|
break
|
||||||
@ -369,17 +340,10 @@ func (service *EnitService) StartService() error {
|
|||||||
_ = service.setCurrentState(EnitServiceCompleted)
|
_ = service.setCurrentState(EnitServiceCompleted)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !service.CrashOnSafeExit {
|
|
||||||
logger.Printf("Service (%s) has exited\n", service.Name)
|
|
||||||
_ = service.setCurrentState(EnitServiceStopped)
|
|
||||||
} else {
|
|
||||||
logger.Printf("Service (%s) has crashed!\n", service.Name)
|
logger.Printf("Service (%s) has crashed!\n", service.Name)
|
||||||
_ = service.setCurrentState(EnitServiceCrashed)
|
_ = service.setCurrentState(EnitServiceCrashed)
|
||||||
}
|
|
||||||
|
|
||||||
if service.Restart == "always" {
|
if service.Restart && service.restartCount < 5 {
|
||||||
_ = service.StartService()
|
|
||||||
} else if service.Restart == "true" && service.restartCount < 5 {
|
|
||||||
service.restartCount++
|
service.restartCount++
|
||||||
_ = service.StartService()
|
_ = service.StartService()
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty1
|
name: agetty-tty1
|
||||||
description: Start virtual terminal on tty1
|
description: Start virtual terminal on tty1
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty --noclear tty1
|
start_cmd: /sbin/agetty --noclear tty1
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty2
|
name: agetty-tty2
|
||||||
description: Start virtual terminal on tty2
|
description: Start virtual terminal on tty2
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty tty2
|
start_cmd: /sbin/agetty --noclear tty2
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty3
|
name: agetty-tty3
|
||||||
description: Start virtual terminal on tty3
|
description: Start virtual terminal on tty3
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty tty3
|
start_cmd: /sbin/agetty --noclear tty3
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty4
|
name: agetty-tty4
|
||||||
description: Start virtual terminal on tty4
|
description: Start virtual terminal on tty4
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty tty4
|
start_cmd: /sbin/agetty --noclear tty4
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty5
|
name: agetty-tty5
|
||||||
description: Start virtual terminal on tty5
|
description: Start virtual terminal on tty5
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty tty5
|
start_cmd: /sbin/agetty --noclear tty5
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
@ -1,7 +1,5 @@
|
|||||||
name: agetty-tty6
|
name: agetty-tty6
|
||||||
description: Start virtual terminal on tty6
|
description: Start virtual terminal on tty6
|
||||||
type: background
|
type: background
|
||||||
start_cmd: /usr/bin/setsid /sbin/agetty tty6
|
start_cmd: /sbin/agetty --noclear tty6
|
||||||
exit_method: kill
|
exit_method: kill
|
||||||
crash_on_safe_exit: false
|
|
||||||
restart: always
|
|
Loading…
x
Reference in New Issue
Block a user