Development repo for brender 2.0 (the original version is here https://github.com/oenvoyage/brender)
Basic requirement at the moment are:
- Python 2.7
- gevent (awesome lib for concurrency)
- peewee (ORM library)
- PHP 5 (for the web interface)
- Apache (for the web interface)
To install gevent on OSX, check this docs out:
- http://stackoverflow.com/questions/7630388/how-can-i-install-python-library-gevent-on-mac-osx-lion
- Install libevent (brew install libevent)
- Install gevent (easy_install gevent)
- Install peewee (easy_install peewee)
At the moment there are two main files and one folder:
- master.py - the server that handles all the client connections and dispatches orders
- client.py - a client that connects to the master and waits for orders
- dashboard - contains a simple web application that provides a GUI for managing server and clients
It is possible to connect to the master via telnet using the command telent localhost 6000
.
A command prompt will appear and it will be possible to talk to the master (at the moment some basic commands are still usable, but the idea is to make it support only normal API strings - see the syntax below).
The next milestone for the development is to achieve a solid system for enabling and disabling clients (both via command line interface and web interface). This will be achieved in several steps:
- develop a versatile attributes CRUD API for the objects (both via CLI and WI)
- integrate an ORM such as
pewee
for handling a mirrored database with all the clients, jobs, etc - create the foundation for the web interface and implement the basic client enable and disable features
Complete the project, sequence, shot, frames, job management system, including a documentation of the functions involved, as well as the API calls.
Here we will write a list of the future steps to be taken (this includes design goals and features). Will be updated soon.
The idea is to use a light PHP framework that will allow the user to connect to the master and give inputs. All the database work related to the farm will not be directly accessible by the client. Web interface and master.py will talk to each other via sockets using JSON strings. This allows to keep data centralized and share an API across different interfaces (could be a native iOS/Android application for example). After some quite intense research we dropped the idea of using CodeIgniter as a framweork and built ourselves a simpler one. The current framework provides:
- fully configurable url routing
- web interface with dataTables and data loaded via AJAX
- JSON data output (was a pain to get it working because we forgot to close the socket once the query was completed)
It's quite simple. The web interface is situated in the folder called dashboard
. Set the Apache home directory in that folder and you should be able to see it via the web browser. Here is a list of the main files and folders:
- config.php - basic configuration (server address and port)
- index.php - sets up the routing and point to the webroot folder
- lib - contains any library used by the application (currently only one functions.php file)
- pages - content of each page of the application
- tpl - templates used to wrap page contents
- webroot - contains all the frontend elements (css, javascript, images and icons)
Frameworks and tools used by the interface are:
- jQuery
- bootstrap
- dataTables
Here we explain how the software works in some of its most important parts.
Before we start running the server we load from the database a list of clients and run them through an initialize_runtime_client function that create the client object we use in the application. These objects are appended to the runtime_clients list. We do this because accessing clients from memory is much faster!
When a client connects we check if it was there before (if it is in the runtime_clients list loaded from the database at startup). If it's there we enable it, if not, we:
- first create a new entry in the database
- extract the entry and use the id to
- initialize a new runtime_client
- we append the client to the runtime_clients list and use it
When we shut down brender we must save the current status of the runtime clients in the database. There is a save_to_database function that does that. At the moment that function is very slow, compared to the load_from_database, why? This has to be investigated.
The brender API consists in the exchange of JSON strings between a client and the server. At the moment it works like this:
- Open a connection to the server (new socket)
- Send data to the server (as JSON)
- Get response
- Eventually close the connection
We build the JSON request by defining item, action, filter and values. Item and action are mandatory, whereas filter and values depend on the action. Here you have an example:
{'item': 'client', 'action': 'update', 'filter': 'enabled', 'values': 'disabled'}
The following table gives a better overview of the JSON string components.
Key | Type | Included | Example |
---|---|---|---|
item | string | ALWAYS | 'clients' |
action | string | ALWAYS | 'update' |
filters | dictionary | Read Update Delete | {'status': 'enabled'} |
values | dictionary | Create Update | {'status': 'disabled'} |
###Communication between server and client In order to get clear communication between server and clients, we have setup a JSON based protocol there too.
{'type': 'system', 'command': 'mac_address'}
At the moment the only types available are:
- system: for system specific command (get memory usage, MAC address, etc)
- render: a render order (with several parameters, such as blender path, chunk start and end, etc)
We have the convention that an order
is a JONS string going from the server to the client, while a response
is a JSON string going from client to server.
No real commands are currently available. At the moment only test inputs are available, but this is a list of possible inputs:
clients
- lists all available clients (could support filtering arguments, such asall
,enabled
, etc.)enable
(plus filtering arguments) - enables selected clientsdisable
(plus filtering arguments) - disables selected clients