Merge remote-tracking branch 'remotes/origin/0.14.16'

# Conflicts:
#	Dockerfile
#	README.md
This commit is contained in:
David Andersen 2016-10-26 17:15:54 -07:00
commit 667bd97388
6 changed files with 80 additions and 158 deletions

View File

@ -14,11 +14,13 @@ RUN apk --update --no-cache add bash curl && \
echo "$SHA1 /tmp/factorio_headless_x64_$VERSION.tar.gz" | sha1sum -c && \ echo "$SHA1 /tmp/factorio_headless_x64_$VERSION.tar.gz" | sha1sum -c && \
tar xzf /tmp/factorio_headless_x64_$VERSION.tar.gz --directory /opt && \ tar xzf /tmp/factorio_headless_x64_$VERSION.tar.gz --directory /opt && \
rm /tmp/factorio_headless_x64_$VERSION.tar.gz && \ rm /tmp/factorio_headless_x64_$VERSION.tar.gz && \
cp /opt/factorio/data/server-settings.example.json /opt/factorio/data/server-settings.json && \ apk --no-cache del curl && \
cp /opt/factorio/data/map-gen-settings.example.json /opt/factorio/data/map-gen-settings.json && \ ln -s /factorio/saves /opt/factorio/saves && \
apk --no-cache del curl ln -s /factorio/mods /opt/factorio/mods && \
ln -s /factorio/config/server-settings.json /opt/factorio/data/server-settings.json && \
ln -s /factorio/config/map-gen-settings.json /opt/factorio/data/map-gen-settings.json
VOLUME /opt/factorio/saves /opt/factorio/mods VOLUME /factorio
EXPOSE 34197/udp 27015/tcp EXPOSE 34197/udp 27015/tcp

121
README.md
View File

@ -19,88 +19,73 @@ The game is very stable and optimized for building massive factories. You can cr
NOTE: This is only the server. The game is available on [Steam](http://store.steampowered.com/app/427520/). NOTE: This is only the server. The game is available on [Steam](http://store.steampowered.com/app/427520/).
# Features # Usage
* Configurable via ```server-config.json```.
* Automatically loads the last save.
* Volumes for saves and mods.
* Small size. Based on Alpine Linux.
# How to use this image?
## Quick Start ## Quick Start
Start the server in interactive mode for debugging. The game isn't saved. Begin by running the server to create the necessary folder structure and configuration files. For this example we'll use ```/tmp/factorio``` to store our data.
``` ```
docker run --rm -it -P dtandersen/factorio docker run -d -P -v /tmp/factorio:/factorio --name factorio dtandersen/factorio
``` ```
* ```--rm``` - Remove container after stopping Here is an explanation of the options:
* ```-it``` - Interactive mode, i.e. you can see the console
* ```--d``` - Run as a daemon (detached).
* ```-P``` - Expose all ports. * ```-P``` - Expose all ports.
* ```-v``` - Mount ```/tmp/factorio``` on the local file system to ```/factorio``` in the container.
* ```--name``` - Name the container ```factorio``` (otherwise it has a random name).
## Usage Check the logs to see what happened:
Normally the server runs as a daemon and a configuration file is specified. Volumes are mounted for saves and mods.
Create ```server-config.json``` and modify it to your liking.
```
docker run -d -P \
-v /path/to/server-config.json:/opt/factorio/data/server-config.json \
-v /path/to/saves:/opt/factorio/saves \
-v /path/to/mods:/opt/factorio/mods \
--name factorio \
dtandersen/factorio
```
* ```-d``` - Start the server as a daemon.
* ```-P``` - Expose all ports.
* ```-v``` - Mount volumes for config, mods, and saves.
* ```--name``` - Give the container a name (otherwise it'll be random).
## Saves
The first time the server is started a new map is generated and saved as ```save.zip```. On subsequent runs the newest save is used. To load an old save ```touch save.zip``` and restart the server.
## Mods
Copy them into the mods folder and restart the server.
## Start/Stopping
Assuming the server is named ```factorio```, to stop the server:
```
docker stop factorio
```
To restart the server:
```
docker start factorio
```
## Volumes
* ```/opt/factorio/saves``` - Saves (recommened)
* ```/opt/factorio/mods``` - Mods (optional)
* ```/opt/factorio/data/server-config.json``` - Configuration (recommended)
## Ports
* ```34197/udp``` - Client (required)
* ```27015/tcp``` - Remote console (optional)
## Logs
Sometimes it's useful to see the logs of a running container:
``` ```
docker logs factorio docker logs factorio
``` ```
Stop the server:
```docker stop factorio```
Now there's a ```server-settings.json``` file in the folder ```/tmp/factorio/config```. Modify this to your liking.
Restart the server:
```docker start factorio```
Try to connect to the server. Check the logs if it isn't working.
## Saves
A new map (```save.zip```) is generated the first time the server is started. On subsequent runs the newest save is used.
To load an old save ```touch save.zip``` and restart the server.
To generate a new map delete all of the saves and restart the server.
For custom map settings edit ```map-gen-settings.json``` in ```/tmp/factorio/config```. Then generate a new map.
## Mods
Copy the mods into the mods folder and restart the server.
# Container Details
## Volumes
The container has one volume located at ```/factorio```. Under this folder there are sub-folders for configuration, mods, and saves.
* ```/factorio```
* ```/config```
* ```server-settings.json```
* ```map-gen-settings.json```
* ```/mods```
* ```/saves```
## Ports
* ```34197/udp``` - Factorio clients (required).
* ```27015/tcp``` - RCON (optional).
# Credits # Credits
Based on [Zopanix' Factorio Server](https://github.com/zopanix/docker_factorio_server). Based on [Zopanix' Factorio Server](https://github.com/zopanix/docker_factorio_server).

View File

@ -1,9 +1,22 @@
#!/bin/bash -x #!/bin/bash -x
set -e
SAVES=/opt/factorio/saves SAVES=/opt/factorio/saves
if ! find $SAVES -iname \*.zip -mindepth 1 -print | grep -q .; then mkdir -p /factorio/saves
#if [ -z $(find $SAVES -iname \*.zip -mindepth 1 -print | grep -q .) ]; then mkdir -p /factorio/mods
mkdir -p /factorio/config
if [ ! -f /factorio/config/server-settings.json ]; then
cp /opt/factorio/data/server-settings.example.json /factorio/config/server-settings.json
fi
if [ ! -f /factorio/config/map-gen-settings.json ]; then
cp /opt/factorio/data/map-gen-settings.example.json /factorio/config/map-gen-settings.json
fi
if ! find -L $SAVES -iname \*.zip -mindepth 1 -print | grep -q .; then
/opt/factorio/bin/x64/factorio \ /opt/factorio/bin/x64/factorio \
--create $SAVES/save.zip \ --create $SAVES/save.zip \
--map-gen-settings /opt/factorio/data/map-gen-settings.json --map-gen-settings /opt/factorio/data/map-gen-settings.json

View File

@ -1,18 +0,0 @@
{
"_comment": "Sizes can be specified as none, very-low, low, normal, high, very-high",
"terrain_segmentation": "normal",
"water": "normal",
"width": 0,
"height": 0,
"starting_area": "normal",
"peaceful_mode": false,
"autoplace_controls":
{
"coal": {"frequency": "very-low", "size": "high", "richness": "high"},
"copper-ore": {"frequency": "very-low", "size": "high", "richness": "high"},
"crude-oil": {"frequency": "normal", "size": "high", "richness": "high"},
"enemy-base": {"frequency": "low", "size": "normal", "richness": "normal"},
"iron-ore": {"frequency": "very-low", "size": "high", "richness": "high"},
"stone": {"frequency": "very-low", "size": "normal", "richness": "normal"}
}
}

15
run.sh
View File

@ -1,12 +1,9 @@
mkdir -p /tmp/factorio #mkdir -p /tmp/factorio/config
mkdir -p /tmp/factorio/mods #mkdir -p /tmp/factorio/mods
mkdir -p /tmp/factorio/saves #mkdir -p /tmp/factorio/saves
cp -n server-settings.example.json /tmp/factorio/server-settings.json #cp -n server-settings.example.json /tmp/factorio/config/server-settings.json
cp -n map-gen-settings.example.json /tmp/factorio/map-gen-settings.json #cp -n map-gen-settings.example.json /tmp/factorio/config/map-gen-settings.json
sudo docker run --rm -it \ sudo docker run --rm -it \
-v /tmp/factorio/server-settings.json:/opt/factorio/data/server-settings.json \ -v /tmp/factorio:/factorio \
-v /tmp/factorio/map-gen-settings.json:/opt/factorio/data/map-gen-settings.json \
-v /tmp/factorio/mods:/opt/factorio/mods \
-v /tmp/factorio/saves:/opt/factorio/saves \
--name factorio \ --name factorio \
factorio "$@" factorio "$@"

View File

@ -1,57 +0,0 @@
{
"name": "Name of the game as it will appear in the game listing",
"description": "Description of the game that will appear in the listing",
"tags": ["game", "tags"],
"_comment_max_players": "Maximum number of players allowed, admins can join even a full server. 0 means unlimited.",
"max_players": 0,
"_comment_visibility": ["public: Game will be published on the official Factorio matching server",
"lan: Game will be broadcast on LAN"],
"visibility":
{
"public": true,
"lan": true
},
"_comment_credentials": "Your factorio.com login credentials. Required for games with visibility public",
"username": "",
"password": "",
"_comment_token": "Authentication token. May be used instead of 'password' above.",
"token": "",
"game_password": "",
"_comment_require_user_verification": "When set to true, the server will only allow clients that have a valid Factorio.com account",
"require_user_verification": true,
"_comment_max_upload_in_kilobytes_per_second" : "optional, default value is 0. 0 means unlimited.",
"max_upload_in_kilobytes_per_second": 0,
"_comment_ignore_player_limit_for_returning_players": "Players that played on this map already can join even when the max player limit was reached.",
"ignore_player_limit_for_returning_players": false,
"_comment_allow_commands": "possible values are, true, false and admins-only",
"allow_commands": "admins-only",
"_comment_autosave_interval": "Autosave interval in minutes",
"autosave_interval": 10,
"_comment_autosave_slots": "server autosave slots, it is cycled through when the server autosaves.",
"autosave_slots": 5,
"_comment_afk_autokick_interval": "How many minutes until someone is kicked when doing nothing, 0 for never.",
"afk_autokick_interval": 0,
"_comment_auto_pause": "Whether should the server be paused when no players are present.",
"auto_pause": true,
"only_admins_can_pause_the_game": true,
"_comment_autosave_only_on_server": "Whether autosaves should be saved only on server or also on all connected clients. Default is true.",
"autosave_only_on_server": true,
"_comment_admins": "List of case insensitive usernames, that will be promoted immediately",
"admins": []
}