InfoQ

News

New Thin Server Architecture and SOFEA Working Group Web Site Launched

Posted by Steven Robbins on Mar 28, 2008

Community
Architecture
Topics
Design ,
Web Frameworks ,
Rich Internet Apps
Tags
GWT ,
AJAX ,
Dojo ,
XAML ,
XUL ,
Web 2.0
Peter Svensson, Ganesh Prasad, and Mario Valente have teamed up to create the Thin Server Architecture Working Group and launched the group's web site. The site included several resources about Thin Server Architecture (TSA) and Service Oriented Front End Applications (SOFEA) as well as insight into the philosophy behind the technology.

Thin Server Architecture, SOFEA, and other related approaches to applications are primarily about separating client and server concerns and ultimately placing the "View" code in the client. This architectural style has in three primary positive results:
1. The server-side developer can focus on the business logic
2. The application becomes less complex as the client is developed separately.
3. Communication between server and client use a protocol, which can be used to export, import or present data to other, or future system (SOA).
The Articles section of the working group site contains information and articles from each of the the three authors. Included in the articles is "Life Above the Service Tier", the seminal SOFEA paper by Ganesh Prasad, Rajat Taneja and Vikrant Todankar. The section also includes Peter's series on "The End of Web Frameworks" and Mario's series about the "Future of Web Applications." All of the material on the working group site drives to the central goal of pushing client responsibilities out of the server and into the client. This presentation also provides insight into the background and advantages of the thin server approach.

The Resources section of the TSA site has an extensive list of technologies that can be useful for building web-based applications in the Thin Server approach. The site includes links to IDE resources as well as development and runtime components. The development technologies listed include such tools as GWT, XUL, SilverLight/XAML, and Adobe Flex. They are classified by
  1. DHTML/AJAX frameworks for Current Browsers
  2. XML Dialects for Advanced Browsers
  3. Java frameworks
  4. Adobe Flash-­based frameworks
Ganesh has pointed out that TSA and SOFEA focus on eliminating server-side driven presentation. This frees the client to take responsibility for the View aspect, which can be "thin", "rich", or in between. He also said that the options for mechanisms for delivery to the client (called "Application Download" with respect to SOFEA) occupy a very broad spectrum of choices when this architectural style is applied. With respect to developers and technologies for implementing applications in the TSA style, Mario and Peter have used several. They recommended Ajax/JavaScript with Dojo 1.x, AppJet , jQuery and JavascriptMVC as the current frontrunners.

All three authors seem to agree that the biggest hurdle to adopting the TSA or SOFEA approach to building web applications is getting past the developer's discomfort. That is to say that the thin server applications currently lack a lot of IDE integration and tools and typically need to incorporate disparate languages and skillsets for developing the server and client components. However, recent technology advances in serverside JavaScript may allow of language unification in TSA-syle applications.
Great article! by Justin Meyer Posted Apr 2, 2008 4:00 AM
  1. Back to top

    Great article!

    Apr 2, 2008 4:00 AM by Justin Meyer

    SOFEA is a big part of the future of web development.

Educational Content

Brian Marick on 4 Challenges and 5 Guiding Values of Agile Software Development

Brian Marick takes us through a quick tour of the most important values and challenges to adopting Agile successfully (they aren't the typical challenges and values we hear in the community).

Are You a Software Architect?

The line between development and architecture is tricky. Does it exist at all? Is an ivory tower actually needed? There's a balance in the middle, but how do you move from developer to architect?

Agile – A Way of Life and Pragmatic Use of Authority

The word 'authority' sometimes produces an allergic response in hard-line agilists. Freedom and authority – both are bad if misused and both are good if used in right spirit for a noble cause.

Getting Started with Grails, Second Edition

"Getting Started with Grails" brings you up to speed on this modern web framework. Companies as varied as LinkedIn, Wired, and Taco Bell are all using Grails. Are you ready to get started as well?

Using ITIL V3 as a Foundation for SOA Governance

Those familiar with only ITIL V2 often scoff at the thought that ITIL could serve as a governance framework for SOA. With ITIL V3, the focus of the framework shifted towards service-orientation.

Adrian Colyer on AspectJ, tc Server and dm Server

SpringSource CTO Adrian Colyer discusses AspectJ, SpringSource's dm Server and tc Server products, OSGi and Scrum.

Adam Wiggins on Heroku

Heroku's Adam Wiggins talks about Rails, Background Jobs, Add-Ons, Ruby, and how Heroku manages to work around Ruby's inefficiencies using Erlang and other languages.

SOA as an Architectural Pattern: Best Practices in Software Architecture

For Grady Booch the foundation of a good architecture is patterns, SOA being just one of many patterns. In this Second Life presentation, Booch attempts to bring more clarity on what architecture is.