Compare commits

..

2 Commits

Author SHA1 Message Date
1fc94b7c43 Use java8 2021-10-27 22:18:57 +13:00
a1c170b9c9 Add java 8 version 2021-10-27 21:22:01 +13:00
3 changed files with 12 additions and 16 deletions

View File

@@ -10,7 +10,7 @@ RUN go build -o /app/main /app/src/main.go
RUN go build -o /app/cmd /app/src/cmd.go
ARG JAVA_VERSION=16
FROM openjdk:16
FROM openjdk:8
ENV MIN_MEM=512M
ENV MAX_MEM=1G

View File

@@ -2,7 +2,7 @@ version: '3.7'
services:
minecraft:
image: magmise/minecraft:latest
image: magmise/minecraft:java8
container_name: minecraft
build: .
restart: unless-stopped

View File

@@ -21,7 +21,6 @@ func main() {
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGTERM)
//get environmental variables
var minram, maxram, args, stop, jar, regex string
for _, e := range os.Environ() {
pair := strings.SplitN(e, "=", 2)
@@ -41,15 +40,16 @@ func main() {
}
}
log.Printf("Ram: Min: %s Max: %s Stop: %s Jar: %s\n\r", minram, maxram, stop, jar)
//check if there is a server jar
if _, err := os.Stat("/server/"+jar); os.IsNotExist(err) {
log.Println("\033[31mJar \"" + jar + "\" not found\033[0m")
os.Exit(1)
}
//create command
var cmd *exec.Cmd
if args == "" {
cmd = exec.Command("java", minram, maxram, "-jar", jar)
@@ -58,16 +58,16 @@ func main() {
log.Printf("Args: %s \n\r", args)
}
//start server
cmd.Dir = "/server"
tty, err := pty.Start(cmd)
ln, _ := net.Listen("tcp", ":8081")
if err != nil {
panic(err)
}
//cleanup
defer func() {
cmd.Process.Kill()
cmd.Process.Wait()
@@ -84,8 +84,6 @@ func main() {
}
}()
//accepts command from cmd.go and sends them to the server
ln, _ := net.Listen("tcp", ":8081")
go func() {
//accept connections from clients
for {
@@ -97,7 +95,7 @@ func main() {
}
}()
//copy to standard out. If the the is a regex pattern, do output anything that matches
go func() {
filter := regexp.MustCompile(regex)
if(regex != "") {
@@ -108,22 +106,20 @@ func main() {
fmt.Println(text)
}
}
} else { //don't filter
} else {
io.Copy(os.Stdout, tty)
}
}()
//copy stdin
go func() {
io.Copy(tty, os.Stdin)
}()
cmd.Wait() //wait for server to stop
cmd.Wait()
tty.Write([]byte("\033[31mServer Stopped\033[0m"))
os.Exit(0)
}
//take commands from cmd.go and send it to sdtin of the server
func handleClient(conn net.Conn, tty *os.File) {
defer conn.Close()
cmd, _ := bufio.NewReader(conn).ReadString('\n')