documentation/content/docs/architecture/index.md

45 lines
1.2 KiB
Markdown
Raw Normal View History

2021-02-06 15:59:00 +00:00
---
2021-02-07 15:38:23 +00:00
title: "Architecture"
2021-02-06 15:59:00 +00:00
weight: 4
2021-02-07 15:38:23 +00:00
summary: How is Piped architectured?
2021-02-06 15:59:00 +00:00
---
2021-02-07 15:38:23 +00:00
## How is Piped's architecture?
2021-02-06 15:59:00 +00:00
Piped has 3 components:
2021-02-07 15:38:23 +00:00
- A frontend in VueJS
- A backed in Java which uses NewPipeExtractor
- A proxy in Golang
2021-02-06 15:59:00 +00:00
links: https://github.com/TeamPiped/Piped\, https://github.com/TeamPiped/Piped-Backend and, https://github.com/FireMasterK/http3-ytproxy
## Frontend
2021-02-07 15:38:23 +00:00
- Uses videojs
- Uses a router for a single page application.
2021-02-06 15:59:00 +00:00
## Backend
2021-02-07 15:38:23 +00:00
- Uses Java 11
- Uses the native HTTP client introduced in Java 9
- Uses netty-reactor to acheive maximum performance and a low footprint.
- Supports OpenJ9
- Each running instance should configure their own proxy, thus allowing multi-gigabit content delivery.
- Uses ~70-130 MB of ram. (on OpenJ9)
2021-02-06 15:59:00 +00:00
# Proxy
2021-02-07 15:38:23 +00:00
- Uses Golang
- Has HTTP/2 support. (HTTP/3 is unstable in the current library)
- Low memory footprint and high throughput.
- Can be used to replace the proxy in various other frontends.
2021-02-06 15:59:00 +00:00
# Server-Side Caching
Caching is done at a Reverse-Proxy/CDN level to reduce the load to the backend. This also makes it more scalable.
# LBRY
2021-02-07 15:38:23 +00:00
LBRY streams are automatically added to stream content via LBRY if the same video is available there.