-
Notifications
You must be signed in to change notification settings - Fork 28
Transient Services
Until now, to run a distributed transient program it was necessary to distribute manually the same copy of the program, compiled for the architecture of the node, then connect
each node to a node of the cloud.
A transient program is a single monadic expression that can execute a distributed program seamlessly among many nodes.
This is great for composability, maintainability and readability. But it has two disadvantages:
- It is necessary to distribute, execute and connect manually the application in each computer and
- The program must be almost identical in all nodes, or at least must read the same closure variables which are interchanged to transport closure information (it can even be written in different languages, theoretically)
These two problems are eliminated with transient services. Services can be installed and executed remotely on demand, at runtime by a monitor process. This means that if a program being executed need a service, the cloud will be asked for a suitable node that would install it. If necessary, from sources in a git repository.
After the installation, the application will continue his execution. So the first problem is solved.
A program can invoke services which are completely different programs. So the second problem is solved.
The interaction is with all the effects of the transient monad: It can stream in both directions. A transient service, for example a database, when called by a program, can send messages reactively to the calling program whenever a record is updated. This is not possible with REST services, if not with special web callbacks (webhooks)(*) that must be set at installation time. This generates a callback hell at the distributed level that precludes composability.
So transient services permits to split an application in independent distributed pieces without loosing power and composability and make fully reactive architectures.
Currently this functionality is under development.
(*Note: A REST service with webhooks can be transformed as a transient service by inverting the callback using react
.
| Intro
| How-to
| Backtracking to undo IO actions and more
| Finalization: better than exceptions
| Event variables: Publish Suscribe
| Checkpoints(New), suspend and restore
| Remote execution: The Cloud monad
| Clustering: programming the cloud
| Mailboxes for cloud communications
| Distributed computing: map-reduce