Docker container for running a Space Engineers server on a Linux machine.
- Debian 8 (to use these files as-is)
- docker (this one is obvious)
- systemd (you can use System V init, but you will have to write your own startup script).
Perform the following steps in the written order.
- Create a new system user account which will own the container. The files in this repository assumes that the new user is named
saiban. You can of course change this to whatever you prefer. Please note that the user ID must correspond to the ID specified in the Dockerfile. If you change it here, you should change it there.
adduser --system --home /home/saiban --uid 256 --group --gecos "Space Engineers" saiban- Change to the new user and move into its home directory by issuing the following commands.
sudo -u saiban /bin/bash
cd- Create the required directory structure.
mkdir -p games/space-engineers/{docker,data}
mkdir -p games/space-engineers/data/Space\ Engineers/{Mods,Saves}- Clone this repository into the home directory of the new user account.
git clone git@github.com:marjacob/se-server.git games/space-engineers/docker-
Obtain a copy of the most current
DedicatedServer.zipand place it in~/games/space-engineers/data. You will usually find it in[...]\SteamApps\SpaceEngineers\Tools\DedicatedServer.zip(do not extract its contents). -
Upload your
SpaceEngineers-Dedicated.cfgand place it in~/games/space-engineers/data/Space Engineers. Use the one in this repository and edit it to your liking if you do not already have one. -
Copy
space-engineers.servicefrom this repository to/etc/systemd/system. Do not forget to change theUserandGroupsetting in this file if you did not go with the defaults.
sudo cp games/space-engineers/docker/space-engineers.service /etc/systemd/system- Build the image!
This will take a while.
games/space-engineers/docker/build.shUpdate Space Engineers by replacing the DedicatedServer.zip with an updated version and restarting the server.
sudo systemctl start space-engineerssudo systemctl stop space-engineersThis will give you live output from the server, as if it was running locally in your terminal.
sudo journalctl --no-tail -f -u space-engineeersRunning Space Engineers this way requires a helper program called sigmap which I developed for this use specifically. It is cloned and built by the Dockerfile and should not add any additional overhead. Because Space Engineers ignores SIGTERM which is sent by Docker to shut down the service, sigmap catches that signal and forwards SIGINT to Space Engineers.
See here for more information.
The original Dockerfile was written by webanck and can be found here.