Ever been fascinated by remote gaming? Same! Inspired by the selkies-gstreamer
project (a relic of Google Stadia's
epicness), I decided to repack their egl solution
for fun - obviously.
Introducing totally modular, Dockerized streaming service. Build it your way, whether you're on Debian or Ubuntu (I went agnostic on dependencies to keep it flexible). I revamped the structure for ultimate control, throwing in Supervisor
magic, with a dash of s6-overlay
structure.
Now it's a streaming powerhouse. Why? Just because!
Note
Minimal Debian image that utilizes software rendering (LLVMpipe), suitable for WSL / Native linux instances.
docker run -d -p 8080:8080 -p 3478:3478/udp -p 3478:3478/tcp -p 9091:9091 -e STREAMER_HOST=$(hostname -I | awk '{print $1}') ghcr.io/wsadza/metal/minimal-debian:latest && sleep 10 && echo -e "\n\tApplication: http://$(hostname -I | awk '{print $1}'):8080" && echo -e "\tSupervisor: http://$(hostname -I | awk '{print $1}'):9091\n"
This section provides guidance on deploying and configuring streaming instances using Docker, Docker Compose, and Kubernetes (K8S) manifests. It includes specific instructions for different Linux distributions and GPU acceleration.
-
$\large\color{Goldenrod}{\textbf{Usage}}$ - Usage
Docker
- Usage
Docker-Compose
- Usage
Kubernetes
- Usage
Helm
- Usage
This repository features an Ansible Playbook that guides you through a minimal setup, starting from the latest NVIDIA driver all the way to a fully functional Kubernetes cluster with GPU-MPS sharing capabilities. The Ansible playbook is self explanatory - tailored for Ubuntu and Debian distributions.
-
$\large\color{Goldenrod}{\textbf{Setup}}$ - Setup
Ansible
- Setup
Bash
- Setup
WSL
- Setup
This section highlights the critical configurations and components necessary for maximizing the performance and functionality of your media streaming and communication setup. Each configuration is tailored to improve the overall user experience. You can find all the configurations described below in the Dockerfile.
-
$\large\color{Goldenrod}{\textbf{Configuration - Monolithic}}$
This section explains how we build our software, focusing on different structures like monolithic and distributed systems. You will also find information about our development workflows, including continuous integration and delivery.
-
$\large\color{Goldenrod}{\textbf{Development - Structure}}$ - Development - Structure - Monolithic
- Development - Structure - Distributed
- Development - Structure - Repository
-
$\large\color{Goldenrod}{\textbf{Development - Workflow}}$
The "Miscellaneous" section gathers various resources and content that may not belong to a specific category but are still valuable and worth referencing. It's a place for extra tools, tips, and information that support a wide range of needs.
-
$\large\color{Goldenrod}{\textbf{Helpful Resources}}$ - Document Template
This section contains important disclaimers regarding the ownership of software and the funding sources for the project. Please review the details carefully to understand the rights associated with the software and the contributions of supporting organizations.
Copyright
I hereby declare that I do not claim any rights to the software used in this repository. All software, including any components, libraries, and dependencies, belongs to their original creators. All copyright and other intellectual property rights associated with this software remain with their respective owners. This statement is intended to clarify that I do not assert any rights to the intellectual property or any part of this software. It is recommended to review the licensing terms of each used component before using or modifying them.
Selkies-Gstreamer
This project has been developed and is supported in part by the National Research Platform (NRP) and the Cognitive Hardware and Software Ecosystem Community Infrastructure (CHASE-CI) at the University of California, San Diego, by funding from the National Science Foundation (Nbf), with awards #1730158, #1540112, #1541349, #1826967, #2138811, #2112167, #2100237, and #2120019, as well as additional funding from community partners, infrastructure utilization from the Open Science Grid Consortium, supported by the National Science Foundation (Nbf) awards #1836650 and #2030508, and infrastructure utilization from the Chameleon testbed, supported by the National Science Foundation (Nbf) awards #1419152, #1743354, and #2027170. This project has also been funded by the Seok-San Yonsei Medical Scientist Training Program (MSTP) Song Yong-Sang Scholarship, College of Medicine, Yonsei University, the MD-PhD/Medical Scientist Training Program (MSTP) through the Korea Health Industry Development Institute (KHIDI), funded by the Ministry of Health & Welfare, Republic of Korea, and the Student Research Bursary of Song-dang Institute for Cancer Research, College of Medicine, Yonsei University.