YOUR FEEDBACK
the usr wrote: So... how about your prediction that SCO would prevail? 11/20/2008 565 - FINAL...
Cloud Computing Conference
November 19-21 San Jose, CA
Register Today and SAVE !..


2008 East
DIAMOND SPONSOR:
Data Direct
Frontiers in Data Access: The Coming Wave in Data Services
PLATINUM SPONSORS:
Red Hat
The Opening of Virtualization
Intel
Virtualization – Path to Predictive Enterprise
Green Hills
IT Security in a Hostile World
JBoss / freedom oss
Practical SOA Approach
GOLD SPONSORS:
Software AG
The Art & Science of SOA: How Governance Enables Adoption
PlateSpin
Effective Planning for Virtual Infrastructure Growth
Fujitsu
Automated Business Process Discovery & Virtualization Service
Ceedo
Workspace Virtualization
Click For 2007 West
Event Webcasts

2008 East
PLATINUM SPONSORS:
Appcelerator
Think Fast: Accelerate AJAX Development with Appcelerator
GOLD SPONSORS:
DreamFace Interactive
The Ultimate Framework for Creating Personalized Web 2.0 Mashups
ICEsoft
AJAX and Social Computing for the Enterprise
Kaazing
Enterprise Comet: Real–Time, Real–Time, or Real–Time Web 2.0?
Nexaweb
Now Playing: Desktop Apps in the Browser!
Sun
jMaki as an AJAX Mashup Framework
POWER PANELS:
The Business Value
of RIAs
What Lies Beyond AJAX?
KEYNOTES:
Douglas Crockford
Can We Fix the Web?
Anthony Franco
2008: The Year of the RIA
Click For 2007 Event Webcasts
SYS-CON.TV
TOP LINKS YOU MUST CLICK ON


Can You Use Flex Communication Protocols for Mission-Critical Trading Applications?
Answering James Gosling's Flash Player Comments

Redmond Developer News has published an interview with Dr. James Gosling, creator of the Java language, where among other things, he talks about JavaFX and  competing technologies. And he made a comment I can’t agree with. Here’s the quote from that interview:

As organizations think about building rich Internet applications or rich client applications, when should developers look at JavaFX over competing technologies? If you look at something like Flash, when you get to the much more advanced stuff -- richer interfaces, more complex network protocols, more complex APIs -- it really falls short. We've had a platform for years that can build rich Internet applications that are extremely sophisticated.”

Before even going into technical details explaining why this statement is wrong,  let me tell you that if someone would ask me to name a dozen of the most respected people in the industry, James Gosling would be one of them. Because of him, I live in a nice house and drive a nice car – I’ve been doing Java for the last 10 years.  If James had not invented Java, I’d be probably still working with PowerBuilder, writing that it’s the best thing since sliced bread. 

But let’s go to the essence of the accusations. Dr. Gosling does not attack the presentation and delivery abilities of Flash Player because Flash Player is today’s leading delivery mechanism  for rich Internet applications. He addresses network protocols, something that may not be as easy to argue. So let’s talk protocols.

In 2007, my colleague and I were invited by a financial company (a Java shop) to assess if they could create an Internet version of their trading application using Flex. They did not have any doubts the GUI part should be done in Flex and delivered to their customers by Flash Player. Using AJAX for such an application would be crazy.

Sun’s long history of ignoring Java as a platform for delivering Internet applications ruled Java applets out. A dancing Duke made his short appearance in 1995 and was forgotten by Sun for the next 10 years. Can you imagine Amazon or Google using Java as a front end for their applications? It’d be insane – they’d lose half of their customers trying to persuade them to use Java applets - each of them has different version of JRE and installing the right one requires a college degree in computers.  I hope this situation will change with the introduction of the Consumer JRE later this year, but we are not there yet.

Anyway, this financial company was not sure if the communication protocols offered by Flex were robust enough to provide reliable and guaranteed message delivery and could be extended to accommodate the specific needs of this application, such as adding the application-specific quality of service (QoS) information right to the packets sent over the network from the Flash client to Java server-side application. They wanted some other things too, such as message throttling in case of network congestion and more.

Flex offers a server-side piece called LiveCycle Data Services ES, which comes  with a couple of fast communication protocols: AMF – a binary protocol that makes calls over HTTP from client to server (polling), and RTMP – real time messaging protocol that supports real time push from the server to the Flash client.  By the way, AMF goes open source in a month or so (see BlazeDS).  Security is similar to Java applets (sandbox) and you can use RTMPS instead of RTMP. Java offers RMI protocol for RPC and JMS for messaging.  RTMP is easy to integrate with other messaging systems via JMS. RTMP is built using Java non-blocking IO and it supports the data push needed in most Web applications.

Under the hood,  AMF and RTMP protocols implement object serialization,  so an instance of a Java object gets serialized on one end and is re-created as an instance of the ActionScript object on the client inside Flash Player, which is nothing else but a VM. On the way back, an ActionScript object is serialized on the client and gets re-created in the server’s JVM as a Java object.

One of the most important features of the Flex framework is that it’s extendable. The server side of the implementation of these protocols is written in Java, and the client side in ActionScript 3. To make the story short, we were able to extend the communication channels, end points, message consumers and producers to enrich RTMP protocols to the client's specification. Now the messages about trading orders and executions travel happily between the Flash client and Java server.  We've also added a two-way RPC-over-messaging in a symmetrical way. 

This project was an example of a nice marriage between  Flex and Java in a Wall Street application. If Flex has weak spots, it’s slow compiler and a mediocre (by Java standards)  Eclipse-based IDE. Since Flex is open sourced now,  I hope that some third-party company will create a better IDE and improve the compiler.

But as of now, I’m pretty happy with using both Java and Flex technologies, and the good part is that it’s not an either-or situation – just use the right tools for the job. There is no need to lobby for any particular language. As for JavaFX, I wish it would start competing with Flex and Silverlight as soon as possible. The more the merrier.

Some time ago I said to my kids, “Even if, God forbid, you commit a crime, Mom and I will still love you and will try to protect you to the very end. You are our kids and we love you regardless of your achievements and personal qualities.” It seems that James Gosling has the same principles and protects his baby no matter what. I respect this but have my reservations.

James Gosling's fan,
Yakov Fain

About Yakov Fain
Yakov Fain is a managing principal of Farata Systems, consulting, training and product company. He has authored several Java books, dozens of technical articles. SYS-CON Books released his latest co-authored book , "Rich Internet Applications with Adobe Flex and Java: Secrets of the Masters" in Spring 2007. Sun Microsystems has nominated and awarded Yakov with the title Java Champion. He leads the Princeton Java Users Group. He is an Adobe Certified Flex Instructor. Currently Yakov works on the book for O'Reilly "Enterprise Application Development with Flex".

YOUR FEEDBACK
steve ballmer wrote: PopFly+Silverlight makes Flash Obsolete! At the web 2.0 thingy we gave a preview of "Microsoft Online Composition Media Aggregation Layout Toolset", at the time I wasn't exactly 100% so I couldn't remember the name, so I just told them it was named PopFly. I don't know what made made say that name, but it has gone over well. So, PopFly! PopFly! PopFly! Adobe has been an annoyance to me for years, we have tried everything we could to dislodge them but they just keep cranking out good products. We even tried a few sabotage .dll's, but they always figure it out in no time at all and issue a patch. But I think we now have the right Combination, PopFly and Silverlight. Here's my plan: Those companies who will not adopt these technologies will be "downlisted" at MS. IE8 will require it's installation. The booby-trap .dll's will come out weekly. Adobe will be marginalized! It's a beautiful...
John Bailo wrote: Gosling is absolutely right! I have thought the same thing myself. Flash does not make "rich applications", it is useful for very graphically rich applications. To me, a rich application is one where the whole space is available for interaction. Yeah, you could make the page one gigantic Flash "graphic", but that's not the point. I want all the elements at my disposal, from the lowliest HTML element, to the most magnificent control -- but I want absolute programmer direction of each thing. Java is good enough to do it all -- I think we'll see some real consolidation (and some real needed growth for Sun Microsystems (JAVA)) in the coming ten years.
ByStander wrote: > I've been doing some variation of AJAX for over 4 > years now and can say that aside from vector > graphics, AJAX can do anything that Flex can. An AJAX vs Flex dicussion at AJAXWorld would be cool, are you giving a session, Dave?
DaveS wrote: Surprise, surprise, Yakov disses on AJAX again. I've been doing some variation of AJAX for over 4 years now and can say that aside from vector graphics, AJAX can do anything that Flex can. Based on Yakov's prior comments regarding AJAX, he has very little experience with advanced JavaScript and DOM scripting.
LATEST ECLIPSE STORIES . . .
ILOG has announced ILOG JViews 8.5, the latest version of ILOG’s Java-based visualization suite, with new features that enhance the creation of Rich Internet Applications as well as desktop applications. ILOG JViews 8.5 adds support for the Eclipse platform including the new ILOG JVi...
"More than a half dozen conferences and events targeting Virtualization and Cloud Computing canceled in the past two months," said Fuat Kircaali, CEO of SYS-CON Media. "We predicted that this would be the outcome for many competing shows due to the current economic conditions," he adds...
The new LISA Eclipse Edition offers deep integration with many aspects of the platform, including the IDE, Source Control, Lifecycle Management, SWT interface elements, and other tools that operate inside of Eclipse. LISA test case documents can be stored and executed within the workfl...
There is much debate raging over whether cloud computing and grid computing are one and the same. In fact, there are many similarities and one key difference separating these burgeoning fields. Both cloud and grid propose an architecture that masks the complexity of managing thousands ...
XAware has announced its upgraded support for Eclipse 3.4. This enhancement gives developers and architects the ability to use the latest version of the Eclipse development environment as they create composite data services for service-oriented architecture (SOA), rich Internet applica...
On Monday October 20 in San Jose, California, the top Rich Internet Applications event of the Fall opens its doors: the 6th International AJAX World RIA Conference & Expo, with top industry keynotes from Microsoft's Silverlight supremo Scott Guthrie and Adobe's Chief Technology Officer...
SUBSCRIBE TO THE WORLD'S MOST POWERFUL NEWSLETTERS
SUBSCRIBE TO OUR RSS FEEDS & GET YOUR SYS-CON NEWS LIVE!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021


SYS-CON FEATURED WHITEPAPERS

MOST READ THIS WEEK
ADS BY GOOGLE