Compare commits

...

29 Commits

Author SHA1 Message Date
Jimmy
21e2aefbe8 Change to CMD 2021-12-02 22:55:10 +13:00
265879de92 change jar to server.jar 2021-11-27 11:44:56 +13:00
84d7bc4d25 Print java version 2021-11-27 11:44:38 +13:00
baea748f90 Update to java 17 2021-11-27 11:44:19 +13:00
0f78b51945 Open socket before defer close 2021-11-12 00:55:15 +13:00
0d05c20961 Add comments 2021-11-03 18:59:52 +13:00
88718390fa Add ignore line based on regex 2021-10-12 23:32:30 +13:00
1075fac43f Add line ignore regex 2021-10-12 23:30:50 +13:00
23294760b6 Add default regex 2021-10-12 23:30:02 +13:00
119251c799 Reset colour 2021-09-21 11:32:37 +12:00
dbe6362fc7 Fix typos 2021-09-20 21:43:14 +12:00
8c4a434afd Use multi stage build 2021-09-20 21:40:53 +12:00
082084dd13 Colour logs, check server jar exists 2021-09-20 21:40:29 +12:00
17dd869ff3 Add JAR env. Add env debug vode 2021-09-17 22:14:03 +12:00
19700e5b4f Swtich to latest 2021-08-25 17:21:02 +12:00
974caf208b Add Server Stopped message 2021-08-25 17:20:48 +12:00
81bbcf4b17 Add latest tag 2021-08-25 17:20:33 +12:00
15d38dece9 Update to Java 16 by default 2021-08-25 17:20:14 +12:00
baf4c9a383 Formatting 2021-01-05 03:27:16 +13:00
4112ad56b4 Don't create bin dir if it allready exists 2021-01-05 03:26:48 +13:00
8feaca77b2 Update readme 2021-01-05 03:24:19 +13:00
fe266e57de Update readme 2021-01-05 03:23:47 +13:00
767122e8c0 Add script to download Minecraft server 2021-01-04 21:40:40 +13:00
c16ce977f8 Remove entry.sh 2021-01-04 21:39:06 +13:00
3508e16c64 Remove binaries 2021-01-04 21:38:36 +13:00
80f5be957b Add example of MIN_MEM STOP and JAR 2021-01-04 21:33:44 +13:00
a43de5a4f3 Exclude server files 2021-01-04 21:32:48 +13:00
b7268bdfad Removed second server. Changed location of server under volumes 2021-01-04 21:14:00 +13:00
95f086454f Changed name of image 2021-01-04 21:12:24 +13:00
9 changed files with 155 additions and 54 deletions

19
.gitignore vendored
View File

@@ -1,17 +1,2 @@
# ---> Go
# Binaries for programs and plugins
*.exe
*.exe~
*.dll
*.so
*.dylib
# Test binary, built with `go test -c`
*.test
# Output of the go coverage tool, specifically when used with LiteIDE
*.out
# Dependency directories (remove the comment below to include it)
# vendor/
server/*
bin/*

View File

@@ -1,18 +1,31 @@
ARG JAVA_VERSION=14.0.2
FROM java:${JAVA_VERSION}
ARG VERSION=17
FROM golang AS builder
WORKDIR /app
COPY ./src /app/src
COPY ./go.mod /app
COPY ./go.sum /app
RUN go build -o /app/main /app/src/main.go
RUN go build -o /app/cmd /app/src/cmd.go
FROM openjdk:$VERSION
ENV MIN_MEM=512M
ENV MAX_MEM=1G
ENV STOP="stop"
ENV JAR=server.jar
ENV REGEX=""
COPY ./bin/main /main
COPY ./bin/cmd /usr/local/bin/cmd
COPY ./entry.sh /entry.sh
COPY --from=builder /app/main /main
COPY --from=builder /app/cmd /usr/local/bin/cmd
EXPOSE 25565
VOLUME [ "/server" ]
ENTRYPOINT [ "/main" ]
WORKDIR /server
CMD [ "/main" ]

View File

@@ -1,3 +1,60 @@
# minecraftimage
# Docker Minecraft
Wrapper to run Minecraft in Docker
## Build Image
```./build.sh```
## Get Minecraft Sever For Testing
```./get_minecraft.sh```
## Run Server
```docker-compose up -d```
```docker run -it --name minecraft -p 25565:25565 -v $PWD:/server -e MAX_MEM=1G magmise/minecraft```
## Get Logs
```docker-compose logs```
```docker logs minecraft```
## Send Command to Server
```docker-compose exec cmd say hello```
```docker exec minecraft cmd say hello```
## Attach to Container
```docker attach minecraft```
To detach use ```ctrl+p ctrl+q```
Don't use ```ctrl+c``` to disconnect, it will kill the server
## Environmental Variables
### JAR
Default is ```server.jar```
### MIN_MEM
Default is ```512M```
### MAX_MEM
Default is ```1G```
### STOP
Default is ```stop```
This would be used for Bungee where the stop command is ```end```
Docker wrapper to run Minecraft in Docker

BIN
bin/cmd

Binary file not shown.

BIN
bin/main

Binary file not shown.

View File

@@ -1,5 +1,2 @@
#!/bin/sh
go build -o bin/main src/main.go
go build -o bin/cmd src/cmd.go
sudo docker build -t minecraft .
sudo docker build -t magmise/minecraft:latest .

View File

@@ -1,29 +1,20 @@
version: '3.7'
services:
minecraft:
image: minecraft
image: magmise/minecraft:latest
container_name: minecraft
build: .
restart: unless-stopped
environment:
MIN_MEM: 1G
MAX_MEM: 1G
STOP: stop
JAR: server.jar
REGEX: "Preparing spawn area:"
ports:
- 25565:25565
volumes:
- /home/jimmy/misc/paper/:/server
- ./server/:/server
stdin_open: true
tty: true
minecraft2:
image: minecraft
container_name: minecraft2
restart: unless-stopped
environment:
MAX_MEM: 1G
ports:
- 25566:25565
volumes:
- /home/jimmy/misc/paper2/:/server
stdin_open: true
tty: true

5
get_minecraft.sh Executable file
View File

@@ -0,0 +1,5 @@
#!/bin/bash
mkdir server
wget https://launcher.mojang.com/v1/objects/35139deedbd5182953cf1caa23835da59ca3d7cd/server.jar -O server/server.jar
echo eula=true > server/eula.txt

View File

@@ -10,15 +10,20 @@ import (
"os/signal"
"strings"
"syscall"
"log"
"regexp"
"bytes"
"github.com/creack/pty"
)
func main() {
log.Println("\033[32mStarting Server\033[0m")
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGTERM)
var minram, maxram, args, stop string
//get environmental variables
var minram, maxram, args, stop, jar, regex string
for _, e := range os.Environ() {
pair := strings.SplitN(e, "=", 2)
switch pair[0] {
@@ -30,24 +35,50 @@ func main() {
args = pair[1]
case "STOP":
stop = pair[1]
case "JAR":
jar = pair[1]
case "REGEX":
regex = pair[1]
}
}
//create command
var cmdversion *exec.Cmd
cmdversion = exec.Command("java", "--version")
var out bytes.Buffer
cmdversion.Stdout = &out
cmdversion.Run()
log.Println(out.String())
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)
}
var cmd *exec.Cmd
if args == "" {
cmd = exec.Command("java", minram, maxram, "-jar", "server.jar")
cmd = exec.Command("java", minram, maxram, "-jar", jar)
} else {
cmd = exec.Command("java", minram, maxram, args, "-jar", "server.jar")
cmd = exec.Command("java", minram, maxram, args, "-jar", jar)
log.Printf("Args: %s \n\r", args)
}
//start server
cmd.Dir = "/server"
cmd.Stdout = os.Stdout
tty, err := pty.Start(cmd)
ln, _ := net.Listen("tcp", ":8081")
if err != nil {
panic(err)
}
ln, _ := net.Listen("tcp", ":8081")
//cleanup
defer func() {
cmd.Process.Kill()
cmd.Process.Wait()
@@ -55,14 +86,17 @@ func main() {
ln.Close()
}()
// capture sigterm
go func() {
sig := <-sigs
if sig == syscall.SIGTERM {
fmt.Println("Stopping server")
fmt.Println("\033[31mStopping server\033[0m")
tty.WriteString(stop + "\n\r")
}
}()
//accepts command from cmd.go and sends them to the server
go func() {
//accept connections from clients
for {
@@ -74,14 +108,33 @@ 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 != "") {
scanner := bufio.NewScanner(tty)
for scanner.Scan() {
text := scanner.Text()
if(!filter.MatchString(text)) {
fmt.Println(text)
}
}
} else { //don't filter
io.Copy(os.Stdout, tty)
}
}()
//copy stdin
go func() {
io.Copy(tty, os.Stdin)
}()
cmd.Wait()
cmd.Wait() //wait for server to stop
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')