Estoy intentando ejecutar aerender
(el procesador de línea de comandos de After Effects) a través de launchd
para procesar un video en un intervalo de tiempo. El comando funciona bien en la Terminal. En launchd
, incluso cuando uso screen -d -m ...
, siempre sale antes. Aquí está mi configuración.
Salta al final de las cosas que ya he probado.
plist para launchd
:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>com.home.VideoGenerator</string>
<key>ProgramArguments</key>
<array>
<string>/Users/home/Developer/VideoGenerator/exec/render.sh</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>KeepAlive</key>
<false/>
<key>StartInterval</key>
<integer>300</integer>
<key>StandardErrorPath</key>
<string>/var/log/com.home.VideoGenerator.err.log</string>
<key>StandardOutPath</key>
<string>/var/log/com.home.VideoGenerator.out.log</string>
</dict>
</plist>
render.sh
script:
#!/bin/bash
/Applications/Adobe\ After\ Effects\ CC\ 2018/aerender -project /Users/home/Developer/VideoGenerator/resource/video.aep -comp ExportMe -output /Users/home/Developer/VideoGenerator/output/video.mov -OMtemplate Output
Output:
Aquí es cómo se ve la salida normal, cuando ejecuto ./render.sh
desde la línea de comando:
aerender version 15.0.1x73
PROGRESS: Launching After Effects...
PROGRESS: ...After Effects successfully launched
PROGRESS: Adding specified comp to Render Queue
PROGRESS: 4/2/18 8:41:57 AM PDT: Starting composition ExportMe.
...
Esto está truncado. También genera ajustes de composición y progreso de render, siempre exitoso. Nada útil para este propósito.
Aquí está el resultado registrado cuando lo ejecuto desde launchd
:
aerender version 15.0.1x73
PROGRESS: Launching After Effects...
PROGRESS: ...After Effects successfully launched
Y eso es todo. (En realidad, estoy ejecutando esto en un contexto donde puedo registrar el código de salida y siempre es 0. Para este propósito, he simplificado drásticamente el proyecto a lo que ves aquí, y aún no se ejecuta).
Cosas que he probado:
- Establezca
KeepAlive
entrue
en el plist- Esto simplemente relanza el proceso después de que sale
- Agregue
/dev/null
comoStandardInPath
en el plist (de acuerdo con mismo post que arriba )- El comando no se ejecuta
- Establezca
AbandonProcessGroup
entrue
en el plist- Todavía sale temprano
- Agregue
&
para poner la tarea en segundo plano- Salida de silencios
- Lanzar
aerender
conscreen -d -m ...
- Usando el indicador -L y verificando el registro, la salida es la misma; se detiene después de que
aerender
inicie After Effects y luego se cierra antes de renderizar.
- Usando el indicador -L y verificando el registro, la salida es la misma; se detiene después de que
La ejecución de ps aux | grep aerender
muestra más de 20 procesos en ejecución (probablemente de todas las veces que ejecuté el script), la mayoría de ellos aerendercore
. Pero no hay salida, no hay video.
¿Qué estoy haciendo mal?