A CLI application which is responsible mainly for actual job processing and rendering,
communication with the nexrender-server
, and serves mainly as a consumer in the nexrender network model.
Windows, macOS
Installed licensed/trial version of Adobe After Effects
You can download binaries directly from the releases section
$ nexrender-worker \
--host=https://my.server.com:3050 \
--secret=myapisecret
Note: its recommended to run
nexrender-worker -h
at least once, to read all useful information about available options.
Install the @nexrender/worker
$ npm install @nexrender/worker --save
And then load it, and run it
const { start } = require('@nexrender/worker')
const main = async () => {
const serverHost = 'http://localhost:3000'
const serverSecret = 'mysecret'
await start(serverHost, serverSecret, {
workpath: '/Users/myname/.nexrender/',
binary: '/Users/mynames/Applications/aerender',
skipCleanup: true,
tagSelector: false,
addLicense: false,
debug: true,
actions: {
"custom-action": (job, settings, {input, params}, type) => {
// Custom action code
}
},
onRenderProgress: function(job) {},
onRenderError: function(job, err) {},
onFinished: function(job) {},
onError: function(job, err) {},
})
}
main().catch(console.error);
Available settings (almost same as for nexrender-core
):
workpath
- string, manually set path to working directory where project folder will be created, overrides default one in system temp folderbinary
- string, manually set path pointing to the aerender(.exe) binary, overrides auto found onedebug
- boolean, enables or disables debug mode, false by defaultskipCleanup
- boolean, providing true will prevent nexrender from removing the temp folder with project (false by default)skipRender
- boolean, providing true will prevent nexrender from running actual rendering, might be useful if you only want to call scriptsmultiFrames
- boolean, providing true will attmpt to use aerender's built-in feature of multi frame rendering (false by default)multiFramesCPU
- integer between 1-100, the percentage of CPU used by multi frame rendering, if enabled (90 by default)reuse
- boolean, false by default, (from Adobe site): Reuse the currently running instance of After Effects (if found) to perform the render. When an already running instance is used, aerender saves preferences to disk when rendering has completed, but does not quit After Effects. If this argument is not used, aerender starts a new instance of After Effects, even if one is already running. It quits that instance when rendering has completed, and does not save preferences.maxMemoryPercent
- integer, undefined by default, check original documentation for more infoimageCachePercent
- integer, undefined by default, check original documentation for more infoaddLicense
- boolean, providing false will disable ae_render_only_node.txt license file auto-creation (true by default)forceCommandLinePatch
- boolean, providing true will force patch re-installationstopOnError
- boolean, stop the pick-up-and-render process if an error occurs (false by default)exitOnEmptyQueue
- boolean, stop the worker if too many empty queues are detected (false by default)tolerateEmptyQueues
- number, amount of empty queues to tolerate before exiting (defults to zero).If specified will be used instead of NEXRENDER_TOLERATE_EMPTY_QUEUES env variablepolling
- number, amount of miliseconds to wait before checking queued projects from the api, if specified will be used instead of NEXRENDER_API_POLLING env variableheader
- string, Define custom header that the worker will use to communicate with nexrender-server. Accepted format follows curl or wget request header definition, eg.--header="Some-Custom-Header: myCustomValue"
.tagSelector
- string, (optional) provide the string tags (exampleprimary,plugins,halowell
: comma delimited) to pickup the job with specific tags. Leave it false to ignore and pick a random job from the server with no specific tags. Tags name must be an alphanumeric.wslMap
- string, drive letter of your WSL mapping in WindowsaeParams
- array of strings, any additional params that will be passed to the aerender binary, a name-value parameter pair separated by a space,noAnalytics
- boolean, enables or disables built-in fully-anonymous analytics, false by defaultactions
- an object with keys corresponding to themodule
field when defining an action, value should be a function matching expected signature of an action. Used for defining actions programmatically without needing to package the action as a separate packagecache
- boolean or string. Set the cache folder used by HTTP assets. Iftrue
will use the default path of${workpath}/http-cache
, if set to a string it will be interpreted as a filesystem path to the cache folder.name
- string. An unique name (or not) to thenexrender-worker
, and it will be identified in thenexrender-server
. It can be used as an executor name on picked job(s) as well.