steam-headless
steam-headless
Docker app from Josh.5's Repository
Overview
Headless Steam Service
Remote Game Streaming Server. Play your games either in the browser with audio or via Steam Link or Moonlight. Play from another Steam Client with Steam Remote Play.
- Steam Client configured for running on Linux with Proton
- Moonlight compatible server for easy remote desktop streaming
- Easily install additional launchers like EmulationStation, Heroic and Lutris
- Full video/audio noVNC web access to a Xfce4 Desktop
- NVIDIA, AMD and Intel GPU support
- Full controller support
- Support for Flatpak and Appimage installation
- Root access
- Based on Debian Bookworm
If you wish to install additional applications, you can generate a
script inside the ~/init.d directory ending with ".sh". This will be executed on the container startup.
Everything that you wish to save in this container should be stored in the home directory or a docker container mount that you have specified. All files that are store outside your home directory are not persistent and will be wiped if there is an update of the container or you change something in the template.
GAMES LIBRARY:It is recommended that you mount your games library to /mnt/games/GameLibrary/SteamLibrary and configure Steam to add that path.
In this container, Steam is configured to automatically start. If you wish to add additional services to automatically start, add them under Applications > Settings > Session and Startup in the Web UI.
NETWORK MODE:If you want to use the container as a Steam Remote Play (previously "In Home Streaming") host device you should set the "Network Type:" to "Host". This is a requirement for controller hardware to work and to prevent traffic being routed through the internet since Steam thinks you are on a different network.
NVIDIA GPU:To enable NVIDIA GPU support, ensure that you have installed the Nvidia-Driver plugin and add the "--runtime='nvidia'" parameter added to "Extra Parameters:"
AMD GPU:To enable AMD GPU support, ensure that you have installed the Radeon-TOP plugin.
AMD OR INTEL HW ACCELERATED VIDEO ENCODING:To enable support for VAAPI HW Accelerated Video Encoding, add the "--device='/dev/dri'" parameter added to "Extra Parameters:"
USING HOST INPUT DEVICES:If you wish to connect a keyboard/mouse to this container, you should run it with the "Privileged:" flag "On".
Likewise if you have issues with remote controllers, try toggling this on.
If your host is already running X, you can just use that. To do this, be sure to configure:
- DISPLAY=:0
(Variable) - Configures the sceen to use the primary display. Set this to whatever your host is using - MODE=secondary
(Variable) - Configures the container to not start an X server of its own - HOST_DBUS=true
(Variable) - Optional - Configures the container to use the host dbus process - /run/dbus:/run/dbus:ro
(Mount) - Optional - Configures the container to use the host dbus process
Requirements
**Nvidia-Driver plugin** (nVidia Support)
**Radeon-TOP plugin** (AMD Support)
Runtime arguments
- Web UI
http://[IP]:[PORT:8083]/- Network
host- Shell
bash- Privileged
- false
- Extra Params
--hostname='SteamHeadless' --add-host='SteamHeadless:127.0.0.1' --restart='unless-stopped' --shm-size='2G' --ipc='host' -v '/tmp/.X11-unix/':'/tmp/.X11-unix/':'rw' -v '/tmp/pulse/':'/tmp/pulse/':'rw' --ulimit='nofile=1024:524288' --device='/dev/fuse' --device='/dev/uinput' --device-cgroup-rule='c 13:* rmw' --cap-add='NET_ADMIN' --cap-add='SYS_ADMIN' --cap-add='SYS_NICE' --security-opt='seccomp=unconfined'
Template configuration
Default user home directory. All application software and configuration will be saved into this directory. Any files saved outside of this path will be cleared if the container image this templated is updated.
- Target
- /home/default
- Default
- /mnt/user/appdata/steam-headless
- Value
- /mnt/user/appdata/steam-headless
Option path to your games. This path will need to also be configured in Steam after the first boot.
- Target
- /mnt/games
- Default
- /mnt/user/Games
- Value
- /mnt/user/Games
The password for this container. Note: This password will also be used for the root user. However, the default user has sudo access.
- Target
- USER_PASSWORD
- Default
- password
- Value
- password
Enter your local timezone. You can find a full list of supported timezones in: '/usr/share/zoneinfo' (eg: 'Etc/UTC' or 'Australia/Melbourne',...)
- Target
- TZ
- Default
- Pacific/Auckland
- Value
- Pacific/Auckland
Enter your prefered locales. You can find a full list of supported languages in: '/usr/share/i18n/SUPPORTED' (eg: 'en_US.UTF-8 UTF8' or 'de_DE.UTF-8 UTF-8',...)
- Target
- USER_LOCALES
- Default
- en_US.UTF-8 UTF-8
- Value
- en_US.UTF-8 UTF-8
Set with a commit sha or branch name from the https://github.com/keylase/nvidia-patch project. This will download the patch and apply it to the NVIDIA drivers. Leave blank to disable this feature and not patch the drivers.
Options: ['vnc', 'neko', 'none']. Select a Web UI to run. Each has their own pros/cons. Set to 'none' to disable the Web UI. Note: The Web UI is disabled if the container is run in 'secondary' mode.
- Target
- WEB_UI_MODE
- Default
- vnc
- Value
- vnc
For users with multiple GPUs, add the ID found under the
- Target
- NVIDIA_VISIBLE_DEVICES
- Default
- all
- Value
- all
- Target
- NVIDIA_DRIVER_CAPABILITIES
- Default
- all
- Value
- all
Set the X display. To use the host X server, set this to :0 (or whatever your host is currently running in /tmp/.X11-unix/X*)
- Target
- DISPLAY
- Default
- :55
- Value
- :55
Options: ['primary', 'secondary']. Most of the time this should be set to 'primary' on a headless server. If your server is already running an X server that you wish to use, set this to 'secondary'.
- Target
- MODE
- Default
- primary
- Value
- primary
- Target
- PORT_NOVNC_WEB
- Default
- 8083
- Value
- 8083
Enable Web UI Audio. This creats a opus encoded audio websocket that will tie into the VNC Web UI. Disable this if your browser is incompatible or you do not wish for this additional process overhead.
- Target
- ENABLE_VNC_AUDIO
- Default
- true
- Value
- false
Options: ['true', 'false']. Enable Keyboard and Mouse Support (Including Passthrough). This will configure the X server to catch all evdev events for Keyboard, Mouse, etc.
- Target
- ENABLE_EVDEV_INPUTS
- Default
- true
- Value
- true
Categories
Download Statistics
Total Downloads Over Time
Details
josh5/steam-headless:latestRun steam-headless on Unraid.
steam-headless is listed in Community Apps for Unraid OS. Explore Unraid to build a flexible home server, NAS, or homelab.