Hazelcast Groovyness
by RJ Salicco on Dec.10, 2009, under Development
Data distribution is a pretty cool topic. Recently, I have been working with Hazelcast, which is an open source clustering and data distribution platform for Java. Well, I really like what I have seen so far and I figured why not have some fun with Hazelcast and Groovy.
I started by adding the Hazelcast 1.7.1 jar to $GROOVY_HOME/lib. Hazelcast, at an introductory level, provides distributed implementations of java.util { Queue, List, Set, Map }. I can run a Groovy script on multiple JVM’s and I can share a Map of customers on each instance. For example:
def customersMap = Hazelcast.getMap("customers")
Now, I have an instance of Map and I can add values using Hazelcast’s distributed id generator:
def idGen = Hazelcast.getIdGenerator("customer-ids")
def id = idGen.newId()
customersMap.put(id, "Customer $id")
So, that was pretty simple, right? Here is the entire Groovy script HazelcastGroovynessAdd.groovy:
import com.hazelcast.core.Hazelcast
import com.hazelcast.core.IdGenerator
def customersMap = Hazelcast.getMap("customers")
def idGen = Hazelcast.getIdGenerator("customer-ids")
def id = idGen.newId()
customersMap.put(id, "Customer $id")
I can open up a few different command prompts and enter:
> groovy HazelcastGroovynessAdd.groovy
Now, the customers Map has a few customers in it and our Groovy scripts are still running. Let’s add an com.hazelcast.core.EntryListener to the customers Map so we can detect a com.hazelcast.core.EntryEvent. Here is HazelcastGroovyness.groovy:
import com.hazelcast.core.Hazelcast
import com.hazelcast.core.EntryListener
import com.hazelcast.core.EntryEvent
def listener = [
entryAdded: { EntryEvent ev ->
println "key $ev.key was added with value $ev.value to $ev.name"
Hazelcast.getMap("customers").values().each {
println it
}
},
entryUpdated: { EntryEvent ev -> },
entryRemoved: { EntryEvent ev -> },
entryEvicted: { EntryEvent ev -> }
] as EntryListener
def customersMap = Hazelcast.getMap("customers")
customersMap.addEntryListener(listener, true)
In the above code, we define listener which implements com.hazelcast.core.EntryListener. I now start up HazelcastGroovyness.groovy at a new command prompt(s):
> groovy HazelcastGroovyness.groovy
We can go back to our original HazelcastGroovynessAdd.groovy script and open (re-open) a few more command prompts and run the script that adds customers to the Map. Now in each running instance of HazelcastGroovyness.groovy we see something like:
key 2000001 was added with value Customer 2000001 to c:customers Customer 2000001 Customer 1000001 Customer 1
Hazelcast is very cool, easy to use technology that provides distributed data with a few lines of code, especially with Groovy. More information can be found at Hazelcast’s website and at the project site at Google Code.
Grails on JBoss AS 5.1.0 GA
by RJ Salicco on Nov.03, 2009, under Development
Grails is changing the way Java developers approach Web development. If you are not familiar with Grails, it is a Web application platform for the agile and dynamic language, Groovy, that runs on the Java Virtual Machine. There are plenty of available books on Groovy and Grails and there is a plethora of blog posts and online documentation to help you get started with your first Groovy and Grails project. This article will discuss creating a simple Grails application for JBoss AS 5.1.0 GA and demonstrate how simple Java Web development can be.
I have taken some time to explore developing a simple Grails 1.2-M3 application and deploying it on JBoss AS 5.1.0GA. Grails is all about productivity. In a few short steps, I create a simple Web application, generate a Web archive (.war) file and deploy it on JBoss AS 5.1.0 GA.
After Grails 1.2-M3 is installed and properly setup, I open a command prompt and enter
> grails create-app
and when I am prompted, I enter a name for my application.
> demo
A directory is created with the same name as my application. I then navigate to that directory.
> cd demo
Next, I create two domain classes to represent the solution to my business problem, storing company information in a database.
> grails create-domain-class org.axiomaticit.model.Company > grails create-domain-class org.axiomaticit.model.Address
The above commands create two .groovy files in the directory grails-app/domain/org/axiomaticit/model/, Company and Address. Here is what the Company.groovy file looks like:
package org.axiomaticit.model
class Company {
static constraints = {
}
}
Next I open the Company.groovy and Address.groovy files in a text editor or IDE and add some detail. Here is the Company.groovy file after I add some fields and constraints:
package org.axiomaticit.model
class Company {
String name
String website
static hasOne = [address:Address]
static constraints = {
name(blank:false)
website(blank:false, url:true)
address(nullable:true)
}
String toString() {
"$name"
}
}
And here is the Address.groovy file:
package org.axiomaticit.model
class Address {
Company company
String street1
String street2
String city
String state
String postalCode
static constraints = {
company(nullable:false)
street1(blank:false)
street2(blank:true)
city(blank:false)
state(blank:false)
postalCode(blank:false)
}
String toString() {
"$street1 $city, $state"
}
}
If you are not familiar with Groovy and the conventions of Grails, this might be a little weird to look at. If you are a Java developer, some of the above code looks a lot like what you already know, right? Let’s talk about what I just did. I created two classes to represent company information. First, I created a company class with a few important fields like ‘name’ and ‘website’.
String name
String website
Then I created another class, Address, to represent standard US address data.
String street1
String street2
String city
String state
String postalCode
I also added an Address to the Company class,
static hasOne = [address:Address]
and a Company to the Address class.
Company company
Don’t get too wrapped up in all the details if you are new to Grails, but what you should understand is that I am building a domain model and creating properties and relationships between persistent entities. The Grails documentation is quite detailed and the user community is also very helpful if you get stuck with the Grails conventions and semantics of Groovy.
Now that I have my domain model, I want to create the controllers and views for my Web application. Controllers and views? Think MVC (Model, View, Controller). So, I go back to my command prompt and enter each command:
> grails generate-all org.axiomaticit.model.Company
> grails generate-all org.axiomaticit.model.Address
The commands above will create a few things based the domain model objects; they create default controllers and views that will support basic CRUD (Create, Read, Update, Delete) functionality. The controllers will be in grails-app/controllers/org/axiomaticit/model/ and the views will exist in grails-app/views/company and grails-app/views/address respectively for each domain model object Company and Address. Let’s go ahead and see what I have created and run the application from the command line.
> grails run-app
Once the application starts up, I browse to http://127.0.0.1:8080/demo and test out the application. It might not be everything I wanted, but I have a great starting point, right? Let’s deploy this on JBoss AS 5.1.0 GA. Back to the command line to create a Web archive (.war) file.
> grails war
If everything builds properly, I have just created a file, demo-0.1.war, that I can drop into the JBoss deploy directory. I can start up JBoss and point the browser at http://127.0.0.1/demo-0.1 and test out the application. Wow, that took about 10-20 minutes and now I have a fully-functional Web application. Grails is a great platform for proof-of-concept work but because it is based on proven technologies like Spring and Hibernate, many developers are moving Grails applications right into production. Combine Grails with an enterprise level application server like JBoss AS 5.1.0 and you have productivity built on top of dependability.
This is a copy of what I posted at Jboss.org.
Spring Roo at the Tampa JUG
by RJ Salicco on Oct.27, 2009, under Presentations
Just got home from presenting Spring Roo at the Tampa JUG. Everything went pretty smooth; basically did a demo of building a simple app with a few JPA entities. Then I imported the the project into Spring Tools Suite and ran it on tc Server. I created a few entities, did some updates and then opened up Spring Insight. People were impressed with what Insight has to offer. Vladimir Vivien contributed to the presentation by discussing some details of the internals of Roo and we both discussed the advantage of having something like Grails or Roo when looking for paths to productivity. Most of the JUG members in attendance were impressed with Roo but there still was this feeling of uncertainty about code generation and the ‘magical’ things happening in the background. All I know is that productivity is something that Spring Roo brings to table and the ‘magical’ things happen to reduce Java complexity so we can focus on getting the job done. Thanks to all of the JUG members who attended.

Simplifying Java EE with Grails
by RJ Salicco on Oct.29, 2009, under Commentary
I usually don’t like to just post a link to another blog post or article on the web, but I couldn’t help myself here. If you or a colleague haven’t seen a presentation on Grails by the project lead, Graeme Rocher, you should definitely check this out.
http://www.infoq.com/presentations/Web-Development-Grails-Graeme-Rocher
This is a great presentation to get you started with Grails. Watch this presentation, download Grails and create your own application in about 1.5 hours.