JavaOne Days 3-4: Mashups and garbage collection
If you are surprised that I am talking about mashups and garbage collection in the same post, well, so was I. But if one can talk about implementing servers in JavaScript, I most definitely can talk about mashups and garbage collection in the same breath.
Day 1 was primarily scripting, day 2 hardcore java. Days 3 and 4 saw sessions on the entire gamut of Java technologies - from garbage collection to mashups. I discuss some of them here.
Blueprints for Mashups
This was arguably the most informative session for me by far at this year's JavaOne. Kudos to Greg, Mark and Sean for putting together a to-the-point, practical and readily-usable session together. Personally, this session validated the REST and JSON concepts I had gathered over the past few months. I'll recommend this session to anybody interested in building mashups, REST services, AJAX and a whole lot more. (No, they haven't paid me to say this.)
Anybody building REST services should design their system with JavaScript in mind. In today's mashup world the browser (and hence JavaScript) is your first class client. XML and JSON are the typical content types returned by REST services. To get over the browser's cross-domain restrictions, there are 2 possible solutions:
- Server-side proxy: Clients always send requests to the server that is hosting the page. The server in turn acts as a proxy, sends your request to the (remote) mashup service and returns the data it gets from the mashup service to you.
- Dynamic script tags: Browsers allow script tags to communicate with cross domain servers. This opens up the opportunity for you to issue requests to any mashup service by generating dynamic script tags.
JSON has of course gained immense popularity of late. Although JSON is technically a serialized JavaScript object, the JSON format is highly portable and language independent. In addition to returning JSON, you can also support wrapping the JSON object in a JavaScript callback method (they called it jsonp - JSON with padding). This enables clients to specify a callback method which can readily work with the JSON that the server returns.
Various options are available for securing your REST services:
- User tokens
- Session based hash
- URL based API key
- Authentication headers
- Use namespaces
- Use CSS for applying styles
- Don't add to the prototype of common JavaScript objects
- Setting the
innerHTML
property is easier / better than DOM manipulation
- A server-side service
- A client-side JavaScript API / library
- A client-side CSS for applying styles
- Document the API
- Create simple examples enabling a simple cut-and-paste approach to learning your API
Phobos - A Server-side JavaScripting framework
While JS clients are ubiquitous and obviously here to stay, for the life of me, I have not yet come to terms to implementing my server in JS as well. The 2 reasons they cited - impedance mismatch and all-you-need-is-an-F5 to redeploy - didn't quite do it for me. May be in another life I'll grow up to JavaScript servers, but not for now. And if at all that day were to come, there should be a JavaScriptOne and no JavaOne.
Garbage collection
If there was one objective of this session, it was to clear the GC myths out there. Some of the finest Java minds were refuting the urban legends out there and when they talk you listen:
- Object allocation is cheap. Reclaiming young objects is also cheap.
- Small, short-lived immutable objects are good. Large, long-lived mutable objects are bad.
- Nulling references rarely helps - except when it comes to arrays.
- Avoid finalizers - in most cases there are better alternatives possible.
- Avoid
System.gc()
- except between well-defined application phases and when the load on your system is low. - Object pooling is not required in today's VMs. It is a legacy of older VMs. Exceptions are objects that are expensive to allocate / initialize or objects that represent scarce resources.
- Consider using reference-objects for limited interactivity with the garbage collector.
Certain memory-leak pitfalls:
- Objects in wrong scope
- Lapsed listeners
- Metadata mismanagement
They strongly advocated FindBugs for finding such pitfalls as well as other potential bugs.
1 comment:
Nice blog thankss for posting
Post a Comment