I'm please to introduce our first milestone release of MeshKeeper!
MeshKeeper is a platform of services that allow Java applications to discover, launch, coordinate, and control remote processes across a grid of computers.
My colleague Hiram Chirino and I developed MeshKeeper to assist us in creating robust distributed tests for Fuse Message Broker based on ActiveMQ. We wanted an easy, dynamic and platform agnostic mechanism for distributing test objects around a grid of machines.
At the most basic level MeshKeeper is process launching framework. It consists of a MeshKeeper control server and any number of agents listening for requests to launch processes:
But that is just a small piece of what MeshKeeper provides. The MeshKeeper API provides several different interfaces that allow you to easily work with distributed java components:
Check out the MeshKeeper website for examples relating to these interfaces (some not done yet :))
- Launching: Allows you to launch processes in a platform neutral fashion throughout the grid. This also provides mechanism for distributing your local classpath to remotely launched java applications.
- Remoting: Allows you export java objects in the grid and let's you perform RMI style invocation on them
- Registry:Allows you to discover registered objects or data in the grid (quite powerful when combined with Remoting)
- Eventing: Once you've distributed your objects in the grid, Eventing helps you coordinate their activity.
- Repository: Let's you distribute artifacts (files, jvms etc) in the grid for use by distributed components.
I could go into a lot of detail about each of these, but for the sake of brevity once it's all put together you can do things like:
public static class MyClass implements Serializable{ public Properties getSystemProperties() { return System.getProperties(); }}public void hostMyClass() throws Exception{ MeshKeeper mk = MeshKeeperFactory.createMeshKeeper(); MeshContainer container = mk.launcher().launchMeshContainer("fastbox"); //Returns a proxy version of my class using MeshKeeper Remoting //support: MyClass myClass = container.host("propFinder", new MyClass()); //We can use the proxy to print the system properties on the //target system. myClass.getSystemProperties().list(System.out); //If we don't need it anymore unhost container.unhost("propFinder"); container.kill(); }
In the above snippet, we create a MeshContainer on the agent machine called "fastbox" using your application's classpath. We then host MyClass in the container (under the covers using Remoting) ... the only requirement is that MyClass be Serializable. Once it's there we can invoke methods on it just as if it were running in our own jvm! In this example we simply get the host machine's System properties and list them locally.
Anyway, give MeshKeeper a try and let us know what you think!
Hi Colin,
ReplyDeleteExecuting client from Boston with Control Server and Agent running in DC takes 7 minutes to download classes from Boston to DC.
The jar downloaded to DC is 100mb.
And this is occurring every time a container is launched even though nothing has changed in the config.
Anyway to tell Meshkeeper what jar to reuse?
I went with MeshProcess.write to avoid the situation but I would like to be able to instantiate classes in DC from Boston.
Low priority.
Thanks.
Mike
MeshKeeper: The best distributed API
User error. My test was downloading everything from the target/test-classes directory which contained .bz2 files. Removing the .bz2 files and the download from Boston to DC is 30 seconds.
ReplyDeleteMike