/satisfactory-server

An unofficial implementation of a dedicated server for Satisfactory.

Primary LanguageGoMIT LicenseMIT

Unofficial Satisfactory Server

This is an unofficial implementation of a dedicated server for Satisfactory.

Setup

This guide assumes the following:

  • You have intermediate knowledge of Linux and Docker
  • You have Satisfactory on Steam (Epic may be supported in the future)

You'll need to generate a new save (or grab an existing save) for the server to use. You can usually find your save files located in C:\Users\Your User\AppData\Local\FactoryGame\Saved\SaveGames\common\your-world.sav. Once you've located this file, put it into /config/savefiles/ and make sure that its file extension is .sav.

You'll need to bind a local directory to the Docker container's /config directory. This directory will hold the following directories:

  • /gamefiles - this is for the game's files. They're stored outside of the container to avoid needing to redownload 15GB+ every time you want to rebuild the container.
  • /savefilebackups - the server will automatically backup your saves every 6 hours into this directory.
  • /savefiles - this is for the game's saves. They're copied into the container on start, and the saves will be copied back to the host every 30 minutes.
  • /steam - this retains your Steam credentials, simplifying the update process.

You'll also need to provide your Steam username, password, and Steam Guard code when you first run the container. To get your Steam Guard code, start the login process using the steamcmd Docker image, which will send you an email with the code in (you don't need to finish the login process in that image, you can just press CTRL + C to cancel it). You can run that image like this:

docker run -it steamcmd/steamcmd +login Your-Steam-Username Your-Steam-Password

With your credentials in hand, as well as the absolute path to your config directory, run the Satisfactory server image like this:

docker run -d --name=satisfactory-server -h satisfactory-server -e STEAMUSER=Your-Steam-Username -e STEAMPWD=Your-Steam-Password -e STEAMCODE=Your-Steam-Code -e MAXBACKUPS=10 -v /path/to/config:/config -p 7777:7777/udp wolveix/satisfactory-server:latest

If you're using Docker Compose:

version: '3'
services:
    satisfactory-server:
        container_name: 'satisfactory-server'
        hostname: 'satisfactory-server'
        image: 'wolveix/satisfactory-server:latest'
        environment:
            - STEAMUSER=Your-Steam-Username
            - STEAMPWD=Your-Steam-Password
            - STEAMCODE=Your-Steam-Code
            - MAXBACKUPS=10
            - SKIP_UPDATE=true # Only possible when downloaded already. 
            - MOD_IDS=5yGWmmB8KL2Zq8:93bH5XDMFXs5fe #Smart! at latest version
        ports:
            - '7777:7777/udp'
        volumes:
            - '/path/to/config:/config'
        restart: unless-stopped

You won't need to re-obtain your Steam Guard code after the initial creation.

Experimental Branch

If you want to run a server for the Experimental version of the game, simply add a STEAMBETA=true environment variable.

How to Connect to the Server

To join the dedicated server:

  • Press WIN + R
  • Enter %localappdata%/FactoryGame/Saved/Config/WindowsNoEditor
  • Open Input.ini in notepad
  • Paste the following at the end of the file:
[/script/engine.inputsettings]
ConsoleKey=F6
ConsoleKeys=F6

Open Satisfactory, press F6 on the main menu and you should see a console appear. Run:

Open your.server.ip

It should start loading into the world almost instantly. If it doesn't, then it's probably going to timeout after 20 seconds.

How to Improve the Multiplayer Experience

The Satisfactory Wiki recommends a few config tweaks to really get the best out of multiplayer. These changes are already applied to the server, but they need to be applied to your local config too:

  • Press WIN + R
  • Enter %localappdata%/FactoryGame/Saved/Config/WindowsNoEditor
  • Copy the config data from the wiki into the respective files
  • Right-click each of the 3 config files (Engine.ini, Game.ini, Scalability.ini)
  • Go to Properties > tick Read-only under the attributes

Known Issues

  • The server is public, meaning that anyone with your server IP or hostname will be able to join your world.
  • The server log will show various errors; most of which can be safely ignored. As long as the container continues to run and your log looks similar to the example log, the server should be functioning just fine: example log

Credit

This wouldn't have been possible without the following repos: