Compare commits
25 Commits
918b837067
...
java8
Author | SHA1 | Date | |
---|---|---|---|
1fc94b7c43 | |||
a1c170b9c9 | |||
88718390fa | |||
1075fac43f | |||
23294760b6 | |||
119251c799 | |||
dbe6362fc7 | |||
8c4a434afd | |||
082084dd13 | |||
17dd869ff3 | |||
19700e5b4f | |||
974caf208b | |||
81bbcf4b17 | |||
15d38dece9 | |||
baf4c9a383 | |||
4112ad56b4 | |||
8feaca77b2 | |||
fe266e57de | |||
767122e8c0 | |||
c16ce977f8 | |||
3508e16c64 | |||
80f5be957b | |||
a43de5a4f3 | |||
b7268bdfad | |||
95f086454f |
19
.gitignore
vendored
19
.gitignore
vendored
@@ -1,17 +1,2 @@
|
|||||||
# ---> Go
|
server/*
|
||||||
# Binaries for programs and plugins
|
bin/*
|
||||||
*.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/
|
|
||||||
|
|
24
Dockerfile
24
Dockerfile
@@ -1,18 +1,30 @@
|
|||||||
ARG JAVA_VERSION=14.0.2
|
FROM golang AS builder
|
||||||
FROM java:${JAVA_VERSION}
|
|
||||||
|
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
|
||||||
|
|
||||||
|
ARG JAVA_VERSION=16
|
||||||
|
FROM openjdk:8
|
||||||
|
|
||||||
ENV MIN_MEM=512M
|
ENV MIN_MEM=512M
|
||||||
ENV MAX_MEM=1G
|
ENV MAX_MEM=1G
|
||||||
ENV STOP="stop"
|
ENV STOP="stop"
|
||||||
|
|
||||||
ENV JAR=server.jar
|
ENV JAR=server.jar
|
||||||
|
ENV REGEX=""
|
||||||
|
|
||||||
COPY ./bin/main /main
|
COPY --from=builder /app/main /main
|
||||||
COPY ./bin/cmd /usr/local/bin/cmd
|
COPY --from=builder /app/cmd /usr/local/bin/cmd
|
||||||
COPY ./entry.sh /entry.sh
|
|
||||||
|
|
||||||
EXPOSE 25565
|
EXPOSE 25565
|
||||||
|
|
||||||
VOLUME [ "/server" ]
|
VOLUME [ "/server" ]
|
||||||
|
|
||||||
|
WORKDIR /server
|
||||||
|
|
||||||
ENTRYPOINT [ "/main" ]
|
ENTRYPOINT [ "/main" ]
|
||||||
|
61
README.md
61
README.md
@@ -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
|
|
5
build.sh
5
build.sh
@@ -1,5 +1,2 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
sudo docker build -t magmise/minecraft:latest .
|
||||||
go build -o bin/main src/main.go
|
|
||||||
go build -o bin/cmd src/cmd.go
|
|
||||||
sudo docker build -t minecraft .
|
|
||||||
|
@@ -1,29 +1,20 @@
|
|||||||
version: '3.7'
|
version: '3.7'
|
||||||
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
minecraft:
|
minecraft:
|
||||||
image: minecraft
|
image: magmise/minecraft:java8
|
||||||
container_name: minecraft
|
container_name: minecraft
|
||||||
|
build: .
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
environment:
|
environment:
|
||||||
|
MIN_MEM: 1G
|
||||||
MAX_MEM: 1G
|
MAX_MEM: 1G
|
||||||
|
STOP: stop
|
||||||
|
JAR: jar.jar
|
||||||
|
REGEX: "Preparing spawn area:"
|
||||||
ports:
|
ports:
|
||||||
- 25565:25565
|
- 25565:25565
|
||||||
volumes:
|
volumes:
|
||||||
- /home/jimmy/misc/paper/:/server
|
- ./server/:/server
|
||||||
stdin_open: true
|
stdin_open: true
|
||||||
tty: 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
5
get_minecraft.sh
Executable 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
|
48
src/main.go
48
src/main.go
@@ -10,15 +10,18 @@ import (
|
|||||||
"os/signal"
|
"os/signal"
|
||||||
"strings"
|
"strings"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
"log"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
"github.com/creack/pty"
|
"github.com/creack/pty"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
log.Println("\033[32mStarting Server\033[0m")
|
||||||
sigs := make(chan os.Signal, 1)
|
sigs := make(chan os.Signal, 1)
|
||||||
signal.Notify(sigs, syscall.SIGTERM)
|
signal.Notify(sigs, syscall.SIGTERM)
|
||||||
|
|
||||||
var minram, maxram, args, stop string
|
var minram, maxram, args, stop, jar, regex string
|
||||||
for _, e := range os.Environ() {
|
for _, e := range os.Environ() {
|
||||||
pair := strings.SplitN(e, "=", 2)
|
pair := strings.SplitN(e, "=", 2)
|
||||||
switch pair[0] {
|
switch pair[0] {
|
||||||
@@ -30,22 +33,39 @@ func main() {
|
|||||||
args = pair[1]
|
args = pair[1]
|
||||||
case "STOP":
|
case "STOP":
|
||||||
stop = pair[1]
|
stop = pair[1]
|
||||||
|
case "JAR":
|
||||||
|
jar = pair[1]
|
||||||
|
case "REGEX":
|
||||||
|
regex = pair[1]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
log.Printf("Ram: Min: %s Max: %s Stop: %s Jar: %s\n\r", minram, maxram, stop, 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
|
var cmd *exec.Cmd
|
||||||
if args == "" {
|
if args == "" {
|
||||||
cmd = exec.Command("java", minram, maxram, "-jar", "server.jar")
|
cmd = exec.Command("java", minram, maxram, "-jar", jar)
|
||||||
} else {
|
} 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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
cmd.Dir = "/server"
|
cmd.Dir = "/server"
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
tty, err := pty.Start(cmd)
|
tty, err := pty.Start(cmd)
|
||||||
ln, _ := net.Listen("tcp", ":8081")
|
ln, _ := net.Listen("tcp", ":8081")
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
@@ -55,10 +75,11 @@ func main() {
|
|||||||
ln.Close()
|
ln.Close()
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
// capture sigterm
|
||||||
go func() {
|
go func() {
|
||||||
sig := <-sigs
|
sig := <-sigs
|
||||||
if sig == syscall.SIGTERM {
|
if sig == syscall.SIGTERM {
|
||||||
fmt.Println("Stopping server")
|
fmt.Println("\033[31mStopping server\033[0m")
|
||||||
tty.WriteString(stop + "\n\r")
|
tty.WriteString(stop + "\n\r")
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
@@ -74,11 +95,28 @@ func main() {
|
|||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
|
||||||
|
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 {
|
||||||
|
io.Copy(os.Stdout, tty)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
io.Copy(tty, os.Stdin)
|
io.Copy(tty, os.Stdin)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
cmd.Wait()
|
cmd.Wait()
|
||||||
|
tty.Write([]byte("\033[31mServer Stopped\033[0m"))
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user