Linux device driver on raspberry pi 3
This blog assumes that you have dispensed your disposable and have become a proud owner of raspberry pi 3, installed raspbian on it ( or bought a kit with it pre installed). I can only imagine the interest you would garner at your local bar.
Raspbian provides a great bed for learning the inner workings of linux, yscrew it up and convince yourself that its just a stepping stone. I realize you can do it with a VM but (i’ll fill in a good reason later ). My first foray was the compilation of a simple device driver, you know that’s what the internet search said was baby steps, turns out its not that bad.
The very first step in the process is the splitter which will split a file into chunks with size of our choosing, to implement a customized splitter, we need to have a class that implements the java.util.Iterator interface. Camel will then call the next, hasNext etc for each of the camel route blocks that follow the splitter call. Since the call iterates, its an excellent way to stream in large files, for instance in our example we can stream in an xml file by node.
The processing bean acts on the body created in the splitter call, it will most likely end up putting the processed results back into the exchange body.
The aggregation process then kicks off at the tail end of the chunk processing, first camel calls the implementation of AggregationStrategy ( implemented inline as a private static class ArrayListAggregationStrategy ) , after this method execution is complete camel checks to see if there is a key/value pair in our persistence store (JDG) by calling the get method on the class implementing RecoverableAggregationRepository ( In our case this is RecoverableAggregationRepositoryImpl ). The next step in the process would be a call to the add method on the same class, Since our strategy is to keep aggregating to the Arraylist,after every call, the arraylist represents the current and transient set of results accumulated.
As the title of the blog states, persistence is achieved by implementing RecoverableAggregationRepository interface, and the methods of particular relevance are add,get,remove and confirm, what’s passed to them has to be saved, removed, retrieved etal, this is where we call the CRUD methods on JDG. One wrinkle to this is that we arent just saving what we get in the method calls, another way of putting it is that the add method expects us to save the exchange, but it would be nice to be able to see what is going on in this persistence, when was something persisted, all the exchanges meeting a certain criteria yada yada.. say hello to JDG object persistence.
JDG provides a way of storing objects in a remote server using google’s own protobuf protocol, a monster topic in itself but the singular and salient point of relevance is it can store serializable objects. You can check out some code here, if you looking for some play dough. JDG remote queries. In this case i am storing what the camel repository needs and some other metadata that would help me probe the system by inspecting the data.
Code and setup
- Download the jboss data grid server, using 6.4 for this tutorial
- Start the jboss data grid server by running the following command
- The jdg cache that we will use for this purposes is ‘default’ which comes with the installation
- I am using fuse 6.2.1 ( on EAP platform ) as the server hosting it.
- Start the fuse server by running
- The simple implementation, showing this concept is is checked into github source
- To run the program using maven, plese run mvn clean install ( it has a built in plugin that will deploy the application to localhost)
- After every 30 seconds, the scheduler gets kicked off and you can see the steps in the flow chart get executed.