機能的には互換性を維持しつつ、様々な画像形式のデコードに対応
ほとんどの画像読み書きにimage crate v0.25を使用しています
docker run -itd -p 12766:12766 ghcr.io/yojo-art/media-proxy-rs:main
例(x86_64/amd64)
curl -L https://github.com/yojo-art/media-proxy-rs/releases/download/nightly/media-proxy-rs_linux-amd64.gz | gzip -d > ./media-proxy-rs
chmod u+x ./media-proxy-rs
./media-proxy-rs
利用するプラットフォームに応じて適切なバイナリを選択してください。ファイル名のリストを示します
media-proxy-rs_linux-386.gz
media-proxy-rs_linux-amd64.gz
media-proxy-rs_linux-arm-v6.gz
media-proxy-rs_linux-arm-v7.gz
media-proxy-rs_linux-arm64.gz
media-proxy-rs_linux-riscv64.gz
環境変数MEDIA_PROXY_CONFIG_PATH
を設定する事でファイルの場所を指定できます
デフォルト値は$(pwd)/config.json
です
十分に強力なマシンではencode_avif
をtrue
に変更することでAVIFエンコードを利用する事ができます
- x86_64-unknown-linux-musl
- aarch64-unknown-linux-musl
- armv7-unknown-linux-musleabihf
- arm-unknown-linux-musleabihf
- i686-unknown-linux-musl
- riscv64gc-unknown-linux-musl
Dockerを使用する場合はbuildxとqemuによるクロスコンパイルが利用できます
ビルド対象プラットフォームはtarget supportの項目を参照してください
git clone https://github.com/yojo-art/media-proxy-rs && cd media-proxy-rs
docker build -t media-proxy-rs .
この方法ではx86_64-unknown-linux-gnu
向けにビルドします
すべてを静的に組み込むmusl系とは異なる共有ライブラリを必要とする場合があります
- https://www.rust-lang.org/ja/tools/install に従ってrustをインストール
apt-get install -y meson ninja-build pkg-config nasm git
git clone https://github.com/yojo-art/media-proxy-rs && cd media-proxy-rs
cargo build --release
- AVIF(dav1d)
- BMP
- DDS
- Farbfeld
- GIF
- HDR
- ICO(png+rgba not support)
- JPEG
- EXR
- PNG
- PNM
- QOI
- TGA
- TIFF
- WebP
- JPEG XL(jxl-oxide)
- JPEG 2000(openjp2)
- JPEG XR(jxrlib)