mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-11 12:03:14 +00:00

* PHRAS-4056 -fix non escaped path error in sed * PHRAS-4056 add ImageMagick variables to CMD container
186 lines
8.6 KiB
Bash
Executable File
186 lines
8.6 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
HEARTBEAT_INTERVAL=20
|
|
APP_DIR="/var/alchemy/Phraseanet"
|
|
DOCKER_DIR="./docker/phraseanet"
|
|
PHR_USER=app
|
|
|
|
mkdir -p "${APP_DIR}/tmp/locks" \
|
|
&& chown -R app:app "${APP_DIR}/tmp" \
|
|
&& chown -R app:app "${APP_DIR}/tmp/locks"
|
|
|
|
|
|
envsubst < "${DOCKER_DIR}/php.ini.worker.sample" > /usr/local/etc/php/php.ini
|
|
envsubst < "${DOCKER_DIR}/php-fpm.conf.sample" > /usr/local/etc/php-fpm.conf
|
|
|
|
if [ ${XDEBUG_ENABLED} == "1" ]; then
|
|
echo "XDEBUG is enabled. YOU MAY KEEP THIS FEATURE DISABLED IN PRODUCTION."
|
|
docker-php-ext-enable xdebug
|
|
fi
|
|
|
|
./docker/phraseanet/plugins/console init
|
|
|
|
# rm -Rf cache/*
|
|
|
|
chown -R app:app cache
|
|
echo `date +"%Y-%m-%d %H:%M:%S"` " - chown app:app on cache/ repository"
|
|
|
|
if [ -d "www/plugins/" ];then
|
|
chown -R app:app www/plugins
|
|
echo `date +"%Y-%m-%d %H:%M:%S"` " - chown app:app on plugins/ repository"
|
|
fi
|
|
|
|
# config \
|
|
# tmp \
|
|
# logs \
|
|
# www
|
|
|
|
if [ -d "plugins/" ];then
|
|
chown -R app:app plugins
|
|
echo `date +"%Y-%m-%d %H:%M:%S"` " - chown app:app on plugins/ repository"
|
|
fi
|
|
|
|
if [ -f /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml ]; then
|
|
if [ ! -d $IMAGEMAGICK_POLICY_TEMPORARY_PATH ]; then
|
|
echo "$IMAGEMAGICK_POLICY_TEMPORARY_PATH does not exist lets create it"
|
|
mkdir -p $IMAGEMAGICK_POLICY_TEMPORARY_PATH
|
|
fi
|
|
sed -i '/domain=\"resource\" name=\"memory\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"memory\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"map\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"map\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"width\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"width\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"height\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"height\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"disk\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"disk\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"area\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"area\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"temporary-path\"/s/<!--//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i '/domain=\"resource\" name=\"temporary-path\"/s/-->//g' /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"memory\" value=\".*\"/domain=\"resource\" name=\"memory\" value=\"$IMAGEMAGICK_POLICY_MEMORY\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"map\" value=\".*\"/domain=\"resource\" name=\"map\" value=\"$IMAGEMAGICK_POLICY_MAP\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"width\" value=\".*\"/domain=\"resource\" name=\"width\" value=\"$IMAGEMAGICK_POLICY_WIDTH\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"height\" value=\".*\"/domain=\"resource\" name=\"height\" value=\"$IMAGEMAGICK_POLICY_HEIGHT\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"disk\" value=\".*\"/domain=\"resource\" name=\"disk\" value=\"$IMAGEMAGICK_POLICY_DISK\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/domain=\"resource\" name=\"area\" value=\".*\"/domain=\"resource\" name=\"area\" value=\"$IMAGEMAGICK_POLICY_AREA\"/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
sed -i "s/.*domain=\"resource\" name=\"temporary-path\" value=\".*/<domain=\"resource\" name=\"temporary-path\" value=\"$(echo $IMAGEMAGICK_POLICY_TEMPORARY_PATH | sed "s/\//\\\\\//g")\" \/\>/g" /usr/local/etc/ImageMagick-$IMAGEMAGICK_POLICY_VERSION/policy.xml
|
|
fi
|
|
|
|
if [[ $NEWRELIC_ENABLED = "true" ]]; then
|
|
echo `date +"%Y-%m-%d %H:%M:%S"` " - NewRelic daemon and PHP agent setup."
|
|
sed -i -e "s/REPLACE_WITH_REAL_KEY/$NEWRELIC_LICENSE_KEY/" \
|
|
-e "s/newrelic.appname[[:space:]]=[[:space:]].*/newrelic.appname=\"$NEWRELIC_APP_NAME\"/" \
|
|
-e '$anewrelic.distributed_tracing_enabled=true' \
|
|
$(php -r "echo(PHP_CONFIG_FILE_SCAN_DIR);")/newrelic.ini
|
|
|
|
echo "setup of Newrelic agent log forward"
|
|
echo "newrelic.appname = \"$NEWRELIC_APP_NAME\"" > /etc/newrelic/newrelic.cfg
|
|
echo "newrelic.license = \"$NEWRELIC_LICENSE_KEY\"" >> /etc/newrelic/newrelic.cfg
|
|
service newrelic-daemon start
|
|
echo "Newrelic setup of daemon and PHP agent done"
|
|
else
|
|
echo `date +"%Y-%m-%d %H:%M:%S"` " - Newrelic extension deactivation."
|
|
rm -f /usr/local/etc/php/conf.d/newrelic.ini
|
|
fi
|
|
|
|
rm -rf bin/run-worker.sh
|
|
|
|
if [ ! -z "$PHRASEANET_SCHEDULER" ] ; then
|
|
command="bin/console task-manager:scheduler:run"
|
|
echo $command >> bin/run-worker.sh
|
|
echo "Phraseanet workers container will be launched in Scheduler mode with bin/console task-manager:scheduler:run"
|
|
else
|
|
if [ ! -z "$PHRASEANET_EXPLODE_WORKER" ] && [ ${PHRASEANET_EXPLODE_WORKER} == "1" ]; then
|
|
if [ ! -z "$PHRASEANET_WORKERS_LAUNCH_METHOD" ] && [ ${PHRASEANET_WORKERS_LAUNCH_METHOD} == "supervisor" ]; then
|
|
echo "Multiples Phraseanet workers will be launched by supervisor"
|
|
for i in `env | grep PHRASEANET_WORKER_ | cut -d'=' -f1`
|
|
do
|
|
worker_job_file="$(echo $i | cut -d'_' -f3).conf"
|
|
if [ ${!i} -gt "0" ] ; then
|
|
envsubst < "/var/alchemy/Phraseanet/docker/phraseanet/worker/supervisor_conf.d/$worker_job_file" > /etc/supervisor/conf.d/$worker_job_file
|
|
echo "Add worker: " $worker_job_file " -- with parallelism: (-m) " ${!i}
|
|
else
|
|
echo "No worker defined for: " $worker_job_file " -- because parallelism (-m) is set to : " ${!i}
|
|
fi
|
|
done
|
|
command="/usr/bin/supervisord -n -c /etc/supervisor/supervisor.conf"
|
|
echo $command >> bin/run-worker.sh
|
|
PHR_USER=root
|
|
else
|
|
echo "Multiples Phraseanet workers will be launched with bin/console worker:execute"
|
|
NBR_WORKERS=0
|
|
|
|
echo "bin/console worker:heartbeat --heartbeat ${HEARTBEAT_INTERVAL} &" >> bin/run-worker.sh
|
|
|
|
for i in `env | grep PHRASEANET_WORKER_ | cut -d'=' -f1`
|
|
do
|
|
queue_name="$(echo $i | cut -d'_' -f3)"
|
|
m=$i
|
|
if [ ${!m} -gt "0" ] ; then
|
|
command="bin/console worker:execute --queue-name=$queue_name -m ${!m} &"
|
|
echo $command >> bin/run-worker.sh
|
|
echo "Worker " $queue_name " defined with parallelism " ${!m}
|
|
NBR_WORKERS=$(expr $NBR_WORKERS + 1)
|
|
else
|
|
echo "No worker defined for: " $m " -- because parallelism (-m) is set to : " ${!m}
|
|
fi
|
|
done
|
|
|
|
if [ ! -z "$PHRASEANET_CMD_MODE" ] && [ ${PHRASEANET_CMD_MODE} == "1" ] ; then
|
|
apt update
|
|
apt install screen -y
|
|
echo "Worker are in custom process mode"
|
|
fi
|
|
|
|
echo $NBR_WORKERS " workers defined"
|
|
echo $NBR_WORKERS > bin/workers_count.txt
|
|
chown root:app bin/workers_count.txt
|
|
chmod 760 bin/workers_count.txt
|
|
echo "HEARTBEAT_INTERVAL=${HEARTBEAT_INTERVAL}" >> bin/run-worker.sh
|
|
echo '
|
|
NBR_WORKERS=$(< bin/workers_count.txt)
|
|
sleep 1 # let worker:heartbeat fail before process check
|
|
|
|
function check() {
|
|
nb_process=`ps faux | grep "worker:execute" | grep php | wc -l`
|
|
nb_heartbeat=`ps faux | grep "worker:heartbeat" | grep php | wc -l`
|
|
date_time_process=`date +"%Y-%m-%d %H:%M:%S"`
|
|
if [ -z $STACK_NAME ]; then
|
|
echo $date_time_process "-" $nb_process "running workers"
|
|
fi
|
|
if [ $nb_process -lt $NBR_WORKERS ]; then
|
|
echo "One or more worker:execute is not running, exiting..."
|
|
exit 1
|
|
elif [ $nb_heartbeat -lt 1 ]; then
|
|
echo "worker:heartbeat is not running, exiting..."
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
# early check
|
|
check
|
|
|
|
while true; do
|
|
sleep ${HEARTBEAT_INTERVAL}s
|
|
check
|
|
done' >> bin/run-worker.sh
|
|
fi
|
|
else
|
|
command="bin/console worker:execute"
|
|
echo $command >> bin/run-worker.sh
|
|
fi
|
|
fi
|
|
|
|
if [ ! -z "$PHRASEANET_SCHEDULER" ] ; then
|
|
tail -F "${APP_DIR}/logs/scheduler.log" &
|
|
tail -F "${APP_DIR}/logs/task.log" &
|
|
else
|
|
tail -F "${APP_DIR}/logs/worker_service.log" &
|
|
fi
|
|
|
|
runuser -u $PHR_USER -- $@
|