27

I want to develop our new project using a PaaS provider. I'll be developing primary in PHP, but would like that the service can provide other languages too (and add-ons available too, like MongoDB, Memcached, redis, etc). I've seem some PaaS as PHPfog (and AppFog), dotCloud, orchestra.io, Red Hat's OpenShift, Pagoda Box, among others.

Of all of them, I think I like most dotCloud. But wanted to know of any reviews, recommendations and comparisons between some of the big players on PaaS.

What would you guys recommend?

1
  • 1
    Between the mentioned PaaS providers, wich one could recommend. Also, anyone who had experience with any of them that could offer some reviews/recommendation/comparison.
    – Guillermo
    Mar 3, 2012 at 6:23

5 Answers 5

33

Here is a series of blog posts that I have put together that compares most of the top PAAS providers. Most of my trials was using python, so I'm not sure how they compare with PHP.

Hopefully it helps.

PAAS Comparison:

http://kencochrane.net/blog/2011/06/django-hosting-roundup-who-wins/

OpenShift:

http://kencochrane.net/blog/2012/01/installing-django-application-on-openshift/

Stackato, built on top of CloudFoundry:

http://kencochrane.net/blog/2012/01/getting-djangocms-up-and-running-on-stackato/

Heroku:

http://kencochrane.net/blog/2011/11/developers-guide-for-running-django-apps-on-heroku/

dotCloud:

http://kencochrane.net/blog/2011/04/deploying-my-django-application-to-dotcloud/

Huge google spreadsheet with details about all of the PAAS's features:

https://docs.google.com/spreadsheet/ccc?key=0AiIXCd1D_TmGdFluZEJQakV5M0QwWXNWaXREcWR0Q0E#gid=0

8

Think about what features are important to you in a PaaS. You mention multiple language support, but what else. Be clear about what you like about dotCloud in order to help focus in on the right product.

Some of the key features that I recommend you focus on are portability, open stack, high-availability, elasticity, control and monitoring.

To prevent lock-in, you want to choose a PaaS that makes portability between clouds easy. Understand how each product facilitates the ability to change cloud provides as your needs or the environment evolves.

Many PaaS offerings dictate the stack that is available for your application, and this may significantly reduce your architecture options. You want the ability to choose languages, databases, middleware components, product versions, etc. that meet your needs. A PaaS that limits your options to a narrow menu of components is not so useful for real-world deployments.

If continuous uptime is important, then how does the PaaS monitor application health and recover from failures. Can it recover automatically. Can it dynamically scale your application based on load, provisioning new resources during peak demand and release those VMs when no longer needed.

Your application may have dependences between services which complicates deployment. Can the PaaS orchestrate and automatically manage your deployments regardless of the dependencies and complexities of your architecture. You want a PaaS that is flexible, open and extendible to be able to handle whatever your deployment requirements may be.

Finally, you want transparent monitoring at the application level. It should be easy to view the health of your application and how it is performing over time. There should be dashboards and logs available that simplify troubleshooting at the application level.

Here’s a great summary of the current landscape: http://natishalom.typepad.com/nati_shaloms_blog/2012/05/mapping-the-cloudpaas-stack.html

Norm

6

you can find a bunch of comparisons out there:

If you are looking for a multi-runtime PaaS, you will likely be interested in PaaS such as AppFog, Heroku, OpenShift, Google App Engine and CloudFoundry.com. If you are interested in JVM-based PaaS, you will most likely be interested in PaaS such as CloudBees or Jelastic.

Multi-environment PaaS tend to be more generic but on the other hand do not solve as nicely some of the hardest problems that each specific language/environment might face. Also, each PaaS covers different feature scope. CloudBees for example also provides tools for the development stage (such as continuous integration based on Jenkins).

Best thing to do is probably to test 2-3 of them and see for yourself - this is also a lot about taste and colors. This shouldn't take you too long. And if it does, then move on, it probably means this is not the right PaaS for you: the right PaaS is one where you should feel immediately at east and very productive with.

1
  • FYI OpenShift also has Jenkins integration
    – TheSteve0
    Mar 21, 2012 at 7:03
6

Cloudify (an Open PaaS Stack) that supports any lang on any cloud - it comes with builtin support for Mongo, MySQL, Solr etc.

4

i am using a silver plan on PhpFog, but i think you could try PagodaBox.com, they have better features: memcached and redis by default, ssh tunneling for mysql, and the interface is terrific!

pagodabox.com

2
  • It's been a dream working with Pagoda Box on a number of apps over the past few months. They're reasonably easy to get ahold of and bring more to the table for the price than I've found anywhere. Jun 6, 2012 at 0:27
  • I wouldn't use them, their platform is too unreliable.
    – steve0nz
    Oct 16, 2013 at 19:28

Not the answer you're looking for? Browse other questions tagged or ask your own question.