2020-05-31 00:25:46 +00:00
2020-04-03 18:58:46 -06:00
2020-04-03 18:58:46 -06:00
2020-04-03 18:58:46 -06:00
2020-04-03 18:58:46 -06:00
2020-04-03 18:58:46 -06:00
2020-04-03 18:58:46 -06:00
2020-04-04 00:01:51 +00:00
2020-05-31 00:25:46 +00:00

Build Status

Cyclescaler

Containerized, distributed blender rendering - cloud-native alternative to Blender's network based rendering.

What is Cyclescaler

Cyclescaler is an easily scalable rendering system for the Cycles 3D rendering engine built into Blender. It's incredibly easy to spin up instances on all platforms which support containers including all the good cloud providers. You can also easily run it on premises with a Kubernetes cluster or as standalone containers with docker-compose (examples provided). It will even run on ARM processors. The idea is that you can use the scalability of cloud providers which allows you spin up thousands of instances momentarily to quickly render the job in parallel.

Cyclscaler is built on the following technologies:

The project is broken into two parts:

  • Master - This can be thought of as the server, it's the portal that users interact with to upload .blend files and tweak render parameters.
  • Slave - This can be thought of as a client, and it handles rendering the images which get stitched together to create an animation. There can be as many instances of the slave as you want, the more slaves, the more simultaneous frames can be rendered.

Why Containers?

That's the secret sauce of the whole operation. Containers provide a unit of deployment. What does that give you? It gives you an easy way to launch an application, anywhere, across as many machines as you need to. Sign up for a cloud provider, most support running containers natively. Many providers make it as easy as pasting in the URL to download your container from a registry, and putting a number for how many instances you want to run.

You can also run containers on your own equipment utilizing an orchestrator such as Kubernetes.

Web interface

When you run the master, it listens on port 8097. Here's a screenshot of the web interface on the status page for an ongoing render job:

alt text

Description
A scalable containerized 3D rendering system
Readme 7.6 MiB
Languages
Go 68.7%
HTML 28.3%
Dockerfile 3%