factorio-docker/README.md

118 lines
4.7 KiB
Markdown
Raw Normal View History

2016-04-15 07:45:25 +02:00
# Supported tags and respective Dockerfile links
* `0.12.30`, `latest` [(0.12.30/Dockerfile)](https://github.com/dtandersen/docker_factorio_server/blob/master/Dockerfile)
2016-04-15 07:41:33 +02:00
[![](https://badge.imagelayers.io/dtandersen/factorio:latest.svg)](https://imagelayers.io/?images=dtandersen/factorio:latest 'Get your own badge on imagelayers.io')
2016-04-15 07:37:25 +02:00
What is Factorio?
2016-03-04 15:50:01 +01:00
=====
2016-04-15 07:37:25 +02:00
[Factorio](https://www.factorio.com) is a game in which you build and maintain factories.
You will be mining resources, researching technologies, building infrastructure, automating production and fighting enemies. Use your imagination to design your factory, combine simple elements into ingenious structures, apply management skills to keep it working and finally protect it from the creatures who don't really like you.
The game is very stable and optimized for building massive factories. You can create your own maps, write mods in Lua or play with friends via Multiplayer.
NOTE: This is only the server. The game is available on [Steam](http://store.steampowered.com/app/427520/).
2016-03-24 08:39:16 +01:00
Current Version
-----
2016-04-06 12:17:42 +02:00
0.12.30
2016-04-15 01:02:34 +02:00
2016-04-15 07:23:36 +02:00
### Features
* Automatically takes latest save or autosave when restarting the container.
* Volumes for saves and mods
* Set autosave interval and number of saves.
* Enable/disable the no-auto-pause option.
* Enable/disable console commands in game.
2016-04-15 07:37:25 +02:00
* Based on Alpine Linux.
2016-03-26 10:23:21 +01:00
2016-03-10 11:35:35 +01:00
Versions
-----
2016-04-15 07:23:36 +02:00
If you need to use an older version, checkout out the different [tags](https://hub.docker.com/r/dtandersen/factorio/tags/).
2016-03-04 15:50:01 +01:00
2016-04-15 07:37:25 +02:00
How to use this image?
2016-03-04 15:50:01 +01:00
-----
### I just want to play !
This runs factorio with default settings, and your save will be kept :
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
-v [PATH]:/opt/factorio/saves \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-27 08:57:43 +02:00
* Where [PATH] is a folder where you'll put your saves, if there already is a save in it with the string "save", that one will be taken by default, otherwize, a new one will be made.
* Where [PORT] is the port number you choose, if you're going to launch it on your local machine, don't use the port 34197, take another one at random.
### Advanced usage
#### Without map persistence
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-04 15:50:01 +01:00
This will generate a new random map with default settings.
#### With map persistence
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
-v [PATH]:/opt/factorio/saves \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-04 15:50:01 +01:00
This will generate a new random map with default settings and save it onto the volume.
Replace [PATH] with a path to a folder on the host where the map will be saved.
#### With existing map
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
-v [PATH]:/opt/factorio/saves \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-24 10:35:28 +01:00
It's the same as above, it takes the last modified file which contains the word save in the filename as current save when booting the server. This allows when upgrading the container to take the last save, you don't have to rename the last autosave as save.zip
2016-03-26 10:49:27 +01:00
#### Autosave interval
You can set the autosave interval. By default it is set at 2 minutes bud you can change it by launching the container with the "FACTORIO_AUTOSAVE_INTERVAL" variable to whatever suits you best.
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
--env FACTORIO_AUTOSAVE_INTERVAL=[NUMBER] \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-26 10:49:27 +01:00
Where [NUMBER] is the number of minutes between autosaves.
#### Autosave slots
You can set the number of autosave slots. By default it is set at 3 slots bud you can change it by launching the container with the "FACTORIO_AUTOSAVE_SLOTS" variable to whatever suits you best.
2016-03-27 08:56:09 +02:00
```
docker run -d \
2016-03-27 08:50:17 +02:00
--env FACTORIO_AUTOSAVE_SLOTS=[NUMBER] \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
2016-03-26 10:49:27 +01:00
Where [NUMBER] is the number of autosave slots.
#### Mounting mod volume
As everybody knows about factorio is you can add mods to it. Now you can also do it in this docker image by mounting a volume.
2016-03-27 08:56:09 +02:00
```
docker run -d \
-v [PATH]:/opt/factorio/mods \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 08:56:09 +02:00
```
Where [PATH] is the path to the folder with your mods.
2016-03-27 18:39:55 +02:00
#### Allowing in-game commands
2016-03-27 19:10:33 +02:00
I've always disabled in-game commands because I think it is like cheating, however, you can enable them by setting the the "FACTORIO_DISSALOW_COMMANDS" variable to "false".
2016-03-27 18:39:55 +02:00
```
docker run -d \
--env FACTORIO_DISSALOW_COMMANDS=false \
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 18:39:55 +02:00
```
2016-03-27 19:10:33 +02:00
#### Activating no-auto-pause in the game when no one is on the server
2016-04-15 01:04:06 +02:00
I do not recommend this feature, bud it can make the game more difficult if you're up for a challenge :-). Just set the "FACTORIO_NO_AUTO_PAUSE" variable to "true".
2016-03-27 19:10:33 +02:00
```
docker run -d \
2016-04-15 01:04:06 +02:00
--env FACTORIO_NO_AUTO_PAUSE=true \
2016-03-27 19:10:33 +02:00
-p [PORT]:34197/udp \
2016-04-15 07:23:36 +02:00
dtandersen/factorio
2016-03-27 19:10:33 +02:00
```
2016-04-15 07:23:36 +02:00
### Credits
Based on [Zopanix' Factorio Server](https://github.com/zopanix/docker_factorio_server).