Simple video transcoding application for Django framework
Project description
django-video-transcoding
Simple video transcoding application for Django Framework
Installation
System requirements
In case of latest Ubuntu LTS (20.04):
- ffmpeg-4.x
$> sudo apt install ffmpeg
- mediainfo
$> sudo apt install mediainfo
- RabbitMQ
$> sudo apt install rabbitmq-server
django-video-transcoding
pip install django-video-transcoding
Configure Django
Edit your project settings.py
INSTALLED_APPS += ['video_transcoding']
Env
Common env variables used in django web server and celery
DJANGO_SETTINGS_MODULE=YOUR_PROJECT.settings
VIDEO_TRANSCODING_CELERY_BROKER_URL=amqp://guest:guest@rabbitmq:15672/
Web-server-only env variables:
VIDEO_DOWNLOAD_SOURCE=0
VIDEO_EDGES='http://edge-1.localhost,http://edge-2.localhost'
Celery-only env variables:
VIDEO_TEMP_DIR=/tmp
VIDEO_TRANSCODING_CELERY_CONCURRENCY=2
VIDEO_ORIGINS='http://origin-1.localhost/video,http://origin-2.localhost/video'
Start celery worker
$> celery worker -A video_transcoding.celery
Demo project
Run admin, storage and celery worker
docker-compose up
- http://localhost:8000/admin/ - Django admin (credentials are
admin:admin
) - http://storage.localhost:8080/videos/ - WebDAV for sources & results
- http://storage.localhost:8080/hls/ - HLS stream endpoint
Transcode something
curl -T cat.mp4 http://storage.localhost:8080/videos/sources/cat.mp4
- Create new video with link above
- Wait till video will change status to DONE.
- On video change form admin page there is a sample video player.
Develop
Tests
src/manage.py test
Type checking
$> pip install mypy django-stubs
$> cd src && /data/dvt/virtualenv/bin/dmypy run -- \
--config-file ../mypy.ini video_transcoding
TBD:
- travis-ci
- sphinx docs - autodoc + manual
- coverage
- typing
- badges
- video hosting demo project with docker-compose, nginx and player demo
Production
Graceful shutdown
- if you are running transcoder in docker, make sure that celery master process has pid 1 (docker will send SIGTERM to it by default)
- when using separate celery app, send SIGUSR1 from master to workers to trigger
soft shutdown handling
(see
video_transcoding.celery.send_term_to_children
)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for django_video_transcoding-0.3.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 75fe8fd5ebad76b88ab4f4d463978ebb5f51db1e0d7f84f917418940f7070062 |
|
MD5 | 2bc1b81276f8a4469cf343d0955ef21e |
|
BLAKE2b-256 | 3e68e20a4435c2e2805cfc4b4737bab854cc50cd3a5cc1d21f0fde9c5e2ed3d9 |
Close
Hashes for django_video_transcoding-0.3.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 66f06f84e19993d1d381beec32f9931b4643b03ca27200429bce34b1949e1fc9 |
|
MD5 | ebb9aa92c066c3ec3d80bb322226399e |
|
BLAKE2b-256 | 24e7bb163006490a2245dce4b2a52c9cdc2ece4b51d7e01ba0a8b657ff67bcf6 |