mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-05 02:39:33 +02:00
Live supports object storage
* Sync live files (segments, master playlist, resolution playlist, segment sha file) into object storage * Automatically delete them when the live ends * Segment sha file is now a file on disk, and not stored in memory anymore
This commit is contained in:
parent
9c0cdc5047
commit
cfd57d2ca0
21 changed files with 615 additions and 307 deletions
|
@ -1,9 +1,10 @@
|
|||
import { pathExists, readdir, remove } from 'fs-extra'
|
||||
import { basename, join } from 'path'
|
||||
import { logger } from '@server/helpers/logger'
|
||||
import { MStreamingPlaylist, MVideo } from '@server/types/models'
|
||||
import { MStreamingPlaylist, MStreamingPlaylistVideo, MVideo } from '@server/types/models'
|
||||
import { VideoStorage } from '@shared/models'
|
||||
import { listHLSFileKeysOf, removeHLSFileObjectStorage, removeHLSObjectStorage } from '../object-storage'
|
||||
import { getLiveDirectory } from '../paths'
|
||||
import { LiveSegmentShaStore } from './live-segment-sha-store'
|
||||
|
||||
function buildConcatenatedName (segmentOrPlaylistPath: string) {
|
||||
const num = basename(segmentOrPlaylistPath).match(/^(\d+)(-|\.)/)
|
||||
|
@ -11,8 +12,8 @@ function buildConcatenatedName (segmentOrPlaylistPath: string) {
|
|||
return 'concat-' + num[1] + '.ts'
|
||||
}
|
||||
|
||||
async function cleanupPermanentLive (video: MVideo, streamingPlaylist: MStreamingPlaylist) {
|
||||
await cleanupTMPLiveFiles(video)
|
||||
async function cleanupAndDestroyPermanentLive (video: MVideo, streamingPlaylist: MStreamingPlaylist) {
|
||||
await cleanupTMPLiveFiles(video, streamingPlaylist)
|
||||
|
||||
await streamingPlaylist.destroy()
|
||||
}
|
||||
|
@ -20,32 +21,51 @@ async function cleanupPermanentLive (video: MVideo, streamingPlaylist: MStreamin
|
|||
async function cleanupUnsavedNormalLive (video: MVideo, streamingPlaylist: MStreamingPlaylist) {
|
||||
const hlsDirectory = getLiveDirectory(video)
|
||||
|
||||
// We uploaded files to object storage too, remove them
|
||||
if (streamingPlaylist.storage === VideoStorage.OBJECT_STORAGE) {
|
||||
await removeHLSObjectStorage(streamingPlaylist.withVideo(video))
|
||||
}
|
||||
|
||||
await remove(hlsDirectory)
|
||||
|
||||
await streamingPlaylist.destroy()
|
||||
|
||||
LiveSegmentShaStore.Instance.cleanupShaSegments(video.uuid)
|
||||
}
|
||||
|
||||
async function cleanupTMPLiveFiles (video: MVideo) {
|
||||
const hlsDirectory = getLiveDirectory(video)
|
||||
async function cleanupTMPLiveFiles (video: MVideo, streamingPlaylist: MStreamingPlaylist) {
|
||||
await cleanupTMPLiveFilesFromObjectStorage(streamingPlaylist.withVideo(video))
|
||||
|
||||
LiveSegmentShaStore.Instance.cleanupShaSegments(video.uuid)
|
||||
await cleanupTMPLiveFilesFromFilesystem(video)
|
||||
}
|
||||
|
||||
export {
|
||||
cleanupAndDestroyPermanentLive,
|
||||
cleanupUnsavedNormalLive,
|
||||
cleanupTMPLiveFiles,
|
||||
buildConcatenatedName
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
|
||||
function isTMPLiveFile (name: string) {
|
||||
return name.endsWith('.ts') ||
|
||||
name.endsWith('.m3u8') ||
|
||||
name.endsWith('.json') ||
|
||||
name.endsWith('.mpd') ||
|
||||
name.endsWith('.m4s') ||
|
||||
name.endsWith('.tmp')
|
||||
}
|
||||
|
||||
async function cleanupTMPLiveFilesFromFilesystem (video: MVideo) {
|
||||
const hlsDirectory = getLiveDirectory(video)
|
||||
|
||||
if (!await pathExists(hlsDirectory)) return
|
||||
|
||||
logger.info('Cleanup TMP live files of %s.', hlsDirectory)
|
||||
logger.info('Cleanup TMP live files from filesystem of %s.', hlsDirectory)
|
||||
|
||||
const files = await readdir(hlsDirectory)
|
||||
|
||||
for (const filename of files) {
|
||||
if (
|
||||
filename.endsWith('.ts') ||
|
||||
filename.endsWith('.m3u8') ||
|
||||
filename.endsWith('.mpd') ||
|
||||
filename.endsWith('.m4s') ||
|
||||
filename.endsWith('.tmp')
|
||||
) {
|
||||
if (isTMPLiveFile(filename)) {
|
||||
const p = join(hlsDirectory, filename)
|
||||
|
||||
remove(p)
|
||||
|
@ -54,9 +74,14 @@ async function cleanupTMPLiveFiles (video: MVideo) {
|
|||
}
|
||||
}
|
||||
|
||||
export {
|
||||
cleanupPermanentLive,
|
||||
cleanupUnsavedNormalLive,
|
||||
cleanupTMPLiveFiles,
|
||||
buildConcatenatedName
|
||||
async function cleanupTMPLiveFilesFromObjectStorage (streamingPlaylist: MStreamingPlaylistVideo) {
|
||||
if (streamingPlaylist.storage !== VideoStorage.OBJECT_STORAGE) return
|
||||
|
||||
const keys = await listHLSFileKeysOf(streamingPlaylist)
|
||||
|
||||
for (const key of keys) {
|
||||
if (isTMPLiveFile(key)) {
|
||||
await removeHLSFileObjectStorage(streamingPlaylist, key)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue