Skip to content

Latest commit

 

History

History
73 lines (56 loc) · 4.67 KB

File metadata and controls

73 lines (56 loc) · 4.67 KB

camel-jbossdatagrid-fuse: Example Using Infinispan Cache on Camel Routes

  • Author: Vijay Chintalapati, Thomas Qvarnstrom
  • Level: Intermediate
  • Technologies: Infinispan, Camel
  • Summary: The camel-jbossdatagrid-fuse quickstart demonstrates how to use Infinispan cache through camel-jbossdatagrid component on JBoss Fuse.
  • Target Product: JDG
  • Product Versions: JDG 7.x, Fuse 6.2
  • Source: /~https://github.com/infinispan/jdg-quickstart

What is it?

The camel-jbossdatagrid-fuse quickstart will deploy two bundles local_datagrid_producer and local_datagrid_consumer on Fuse, one on each container child1 and child2 respectively.

  • local_datagrid_producer : Scans a folder (/tmp/incoming) for incoming CSV files of the format "id, firstName, lastName, age". If a file is dropped with entries in the given format, each entry is read and transformed into a Person POJO and stored in the data grid
  • local_datagrid_consumer : Lets you query for a POJO using a RESTful interface and get back a JSON representation of the Person POJO stored in the data grid for the given key

The bundles reside in two different containers and the reason why the consumer is able to extract what the producer has put in, is because of the use of same configuration in files: infinispan.xml and jgroups.xml on both sides. The infinispan.xml file has a REPL (replicated) datagrid definition by the name camel-datastore and this is the datagrid with which the producer and consumer interact

System requirements

All you need to build this project is Java SDK 1.8 or better, Maven 3.0 or better.

The application this project produces is designed to be run on JBoss Fuse 6.2.0 or later.

Configure Maven

If you have not yet done so, you must Configure Maven before testing the quickstarts.

Setup the quickstart

  1. Download the Fuse binary jboss-fuse-karaf-6.3.0.redhat-187.zip from either http://www.jboss.org/products or from Red Hat's Customer portal
  2. Export the path to the folder where the CSV files will be placed by running the command of the form export incomingFolderPath=[Full path to the CSV folder]
  3. Run mvn clean install -DincomingFolderPath=$incomingFolderPath in the root folder of the quickstart
  4. Set the following two environment variables in the same shell:
  5. export FUSE_INSTALL_PATH = [Full path to the folder into where Fuse will be installed]
  6. export FUSE_BINARY_PATH = [Full path to the Fuse binary file]
  7. (Optional) Set the path to your local JDG maven repository: export JDG_MAVEN_REPO=/path/to/unzipped/jdg/maven/repository
  8. While in the root folder of the quickstart, run ./setupEverythingOnFuse.sh

Setup Verification

  1. Verify your access to the [Fuse Hawtio Console] (http://127.0.0.1:8181/hawtio/index.html#/login). The username/password is admin/admin.
  2. If the Fuse Fabric is created right, you should be able to access the containers here
  3. Verify if you see two containers created by the names child1 and child2. Also note if root/child1/child2 are all in green, if they are not click on their names andcapture the logs displayed.

Testing

  1. Open index.html in a browser (Note: index.html is a local file that is located in the camel-jbossdatagrid-fuse directory)
  2. Click on connect
  3. Add the best football (soccer) players 2015 by executing $ cp best-footballplayers-2015.csv $incomingFolderPath/
  4. Check that the players were added to the table in the browser
  5. Add another player by executing $ echo "99,Diego,Maradona,75" > $incomingFolderPath/sample.csv
  6. Verify that another player was added to the table in the browser

It's also possible to open multiple browsers and connect them and verify that all clients get the same updates!

How does it work

  1. The local_datagrid_producer will listen to incoming files in the folder $incomingFolderPath. It will transform each line in the CSV to Java object and store them in the local datagrid.
  2. The local_datagrid_consumer will react to events that an entry has been added to the datagrid and will retrieve the Java object, transform it to JSON and push it to WebSocket clients that are connected.