Skip to content

wsadza/metal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


Metal

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!

$\large\color{Goldenrod}{\textbf{TL;DR}}$

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"

Preview

It was easy, right?

Table Of Contents:

Usage

(Back to Top)

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.

Table Of Contents:

Preview

Want to play with others?

Setup

(Back to Top)

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.

Table Of Contents:

Preview

Mobile!

Configuration

(Back to Top)

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.

Table Of Contents:

Preview

Steam? No Problem!

Development

(Back to top)

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.

Table Of Contents:

  • $\large\color{Goldenrod}{\textbf{Development - Structure}}$
  • $\large\color{Goldenrod}{\textbf{Development - Workflow}}$
    • Development - Workflow - CI
    • Development - Workflow - CD

Miscellaneous

(Back to top)

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.

Table Of Contents:

Disclaimers

(Back to top)

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.