1

Wand 経由で PDF を JPG/PNG に変換しようとしています。

これはコードです(編集)

os.path.isfile(os.path.join(settings.PROJECT_PATH, "file.pdf"):
    with Image(filename=os.path.join(settings.PROJECT_PATH, "file.pdf", resolution=100) as image:
        image.save(filename=os.path.join(settings.PROJECT_PATH, "file.jpg")

これは、ローカルの開発サーバー、運用サーバーの開発サーバー、および manage.py シェル (運用サーバー) で完全に動作します。

ただし、プロダクション スーパーバイザー/guncicorn セットアップ経由で使用すると、次のエラーが発生します。

DelegateError at /finance/api/v1/receipt/
Postscript delegate failed `/webapps/bab/bab/Beenie-Man-1.pdf': No such file or directory @ error/pdf.c/ReadPDFImage/677

これが起動スクリプトです。

#!/bin/bash

NAME="bab"                                  # Name of the application
DJANGODIR=/webapps/bab/bab             # Django project directory
SOCKFILE=/webapps/bab/run/gunicorn.sock  # we will communicte using this unix socket
USER=bab                                        # the user to run as
GROUP=webapps                                     # the group to run as
NUM_WORKERS=1                                     # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=bab.settings             # which settings file should Django use
DJANGO_WSGI_MODULE=bab.wsgi                     # WSGI module name

echo "Starting $NAME as `whoami`"

# Activate the virtual environment
cd $DJANGODIR
source ../bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec ../bin/gunicorn ${DJANGO_WSGI_MODULE}:application \
  --name $NAME \
  --workers $NUM_WORKERS \
  --user=$USER --group=$GROUP \
  --log-level=debug \
  --bind=unix:$SOCKFILEchris@python:/webapps/bab$ 

完全なデバッグサーバーとシェルの両方を実行して、実稼働サーバーでテストを実行していたとき、正しいユーザーアカウントと正しいvirtualenvで実行されていました(それがなくてもまったく機能するわけではありません)

それは環境変数の問題でしょうか?それともある種の許可のこと?

4

0 に答える 0