Tuesday, November 22, 2011

What's PaaS?

One of the models used to explain the cloud computing service offerings - derived from the NIST model -  shows the service models arranged as a stack. Implicit in this model is a usage hierarchy (explicitly shown in the diagram below) , that is BPaaS will use SaaS, SaaS uses PaaS to provide an abstraction from underlying computing resources and IaaS provides the basic resources. This seems to make a lot of sense to software architects who recognise a familiar pattern.  
  However, one of the problems I face when talking about PaaS is that many have different preconceptions as to what it is, usually derived from what is currently being provided by various cloud vendors. These range from:
Provided PaaS Services
Example Provider
A set of services for resource allocation in a IaaS service model.Amazon EC2, Rackspace
Basic middleware and data storage services.Amazon Web Services (AWS)
A set of application services.Goggle App Engine (GAE)
Model driven development platforms in the cloud.force.com
Application development framework for cloud computing.vFabric, Heroku
A process development framework in the cloud.Cordys Process Factory,
IBM Blueworks Live
Platforms that provide a set of business functionality that can be built upon.CRM functionality, platforms that provide document management and process automation etc..  PaaS at this level seems to be a underdeveloped model.
Looking at this suggests that the simple model as proposed by the NIST is, in fact too simplistic. So what should the model look like?  

One possibility I like, is to place the PaaS service model to the side of the others and show that they are used by two different roles, i.e.:











PaaS is then a set of functionality that can cover the development needs for the complete spectrum from IaaS to BPaaS, but in practice each cloud service provider will only cover a limited set.

(Update: I've been having some problems with the images displaying. Reloaded them so hopefully it works now.)  









No comments: