Bindings, Platforms, and Innovation
This presentation focuses on the Internet and separating myth from fact, history from the future, and the mundane from the imaginative. Bob Frankston presents a vision of what could and should be.
Tracking change and innovation in the enterprise software development community
Posted by Scott Delap on Jul 31, 2006 04:34 AM
The RIFE Java web framework has released version 1.5. RIFE is a full-stack web application framework with tools and APIs to implement most common web features. Each of its toolkits is usable by itself or together as a full application stack. The RIFE framework promotes itself as having many key differentiators versus other Java web frameworks including:
Highlights in version 1.5 include:
InfoQ recently caught up with Geert Bevin, RIFE project lead, to ask him about this latest release.
The Java web framework space is very crowded with project such as Struts, Spring MVC, Tapestry, etc. Geert commented on RIFE compared to other frameworks:
RIFE is pretty unique in the Java landscape in that it has a solution for every major layer in the stack without introducing any dependencies. The fact that the layers have been designed with interoperability in mind makes it possible to dramatically reduce boiler-plate code and offer unique meta-programming features. You are however still able to use any other Java library for each layer, it will just be less integrated and the features will differ.
Specifically in regards to SEAM and the Web Beans JSR:
I don't know the details of what their exact advantages are, but it seems to me that they externalize flow handling as a BPM solution with an accent on orchestration and long-lived flows. RIFE takes quite an opposite approach, native Java continuations allow a developer to leverage the power of Java without having to learn anything new. You can look at this as implicit and internalized flow support. We however also support externalized flows through data links and flow links in RIFE's site structure. These are designed to make it as easy as possible to create RESTful applications, while still relying on continuations-like state handling and program execution (similar to Spring Web Flow). Again however, the external flow is driven through Java inside your controllers instead of through an externalized flow scripting language. Also, Seam builds on top of JSF. For any functionalities that are not part of Seam, you need to learn and rely on JSF. The JSF programming model doesn't seem to be suitable for many people since they focus more on toolability than on developer comfort. The latter is one of RIFE's main focusses throughout the entire stack.
One of RIFE's key features it is its support of continuations. Geert explained how this works in respect to RIFE:
Continuations allow you to leverage the Java language to write your web application flow. You can literally write a user-interactive program in a similar fashion as when writing DOS programs years ago. Whenever you need input, you just request it and the execution will pause. When the user submits data, you'll receive it and your program will continue exactly where it left off, having preserved it's local state. All this happens over the HTTP barrier and works seamlessly with the browser back button.
When asked about the usage sweet spot for RIFE, Geert responded that in his opinion the full stack nature of RIFE provides "90% of what all the others deliver with 10% of the effort". RIFE revisits numerous concepts redesigning them with web application development in mind adding features such as "...continuations, run-time POJO-driven CRUD generation, scalable component-oriented architecture, state handling without sessions, etc". Geert sees RIFE as well suited for public web sites that are developed by a team of people who want to deliver quickly.
Open Source Middleware Reference Architecture Whitepaper
Velociti Partners Customer Survey
The Agile Business Analyst: Skills and Techniques needed for Agile
Thanks for having posted our release announcement and my interview here. For those that are interested in reading about recent user testimonials, some were posted at the release announcement at TheServerSide
This presentation focuses on the Internet and separating myth from fact, history from the future, and the mundane from the imaginative. Bob Frankston presents a vision of what could and should be.
This article explores the use of JBoss and jBPM to implement design solutions that effectively address the issue of orchestrating long running activities.
This presentation covers the use of graph databases as an optimal solution for data that is difficult to fit in static tables, rapidly evolving data or data that has a lot of optional attributes.
This session introduces Real Options and shows how it can help in running your project. Real Options is a decision-making process that can be used to manage risk.
This article discusses the use of bindings on services and references (including the instance of non-configured bindings) as the means to implement SCA communications in a Web and SOA environment.
After a short introduction to DSLs, Scott Davis plays with the keyboard showing how to approach the creation of a DSL by typing working snippets of Groovy code that get executed.
IBM Rational and InfoQ present, Scaling Agile with C/ALM, an eBook showing organizations how to become “finely tuned software delivery machines” by enabling team integration and scaling.
Amanda Laucher presents a real life enterprise application written in F#. She shows actual code snippets, explaining design decisions and suggesting how to use some of the F# constructs.
1 comment
Watch Thread Reply