Cloud Computing – What is it and why is it important?
Cloud Computing has a few varied meanings from API services such as twitter to web-based (read cloud-based) email services such as gmail and yahoo.
An even bigger tectonic shift is happening though, in the area of infrastructure and hosting, to cloud based solutions. No longer is provisioning a slow ordering process, followed by a multi-year contract and commitment with an associated high price tag. Now computing resources can be provisioned and "spin-up" in seconds, even allowing for auto-scaling, bringing new computing resources online dynamically as seasonal traffic patterns demand.
- uniquely suited to applications with seasonal traffic requirements
- supports disaster recovery effectively for free
- allows temporary provisioning of test environments
- facilitates auto-scaling of bare metal servers
- no huge budgetary outlay, pay for only what you use
- bring up resources in seconds - supports true agile development
What's more since cloud resources are all provisioned in software through an API, it encourages the treatment of infrastructure as a whole as software. Now the scripts to completely rebuild all of your systems, from spin-up, to package configuration to application configuration can all be done in software, and managed in version control.
Sean Hull asks the question on Quora: What is Cloud Computing?
Website Optimization – What is it and why is it important?
When you enter a website name in your browser or click on a google result, you start a cascade of events to unfold. Your request various pieces and components that make up the webpage from a remote server which hosts that website. Those pieces are sent back to you, and your browser assembles them.
There are many moving parts in that process. Anywhere along the way you can hit a snag, slowing down the overall process of that page displaying. Website Optimization attempts to identify all of those processes and components, and organize them by slowest to fastest. This allows us to focus our attention on the slowest part of the process. Like a physician looking at your vascular system, it allows the performance expert to identify and then fix those pipes that are slowing you down.
Since website performance has been shown to directly influence customer retention, conversion, and user experience, overall website performance and optimization are key to your business success.
Sean Hull asks on Quora: What is website optimization and why is it important?
SQL – What is it and why is it important?
The What:
SQL is a difficult acronym for a difficult language, but what it does is shuttle information into and out of your database in an organized manner. Your web applications and developers have to speak it, and your database - whether Oracle, MySQL, Postgres or some other will return information back using this computing dialect.
The Why:
Since every movement on your website, from page to page (sessions) and purchase to purchase all involve interaction using these queries, writing them well can have a huge impact on your website performance. How big? We've fixed queries by adding indexes or rewriting them and seen improvements by as much as 100x. That's converting pages that take ten seconds to ones that take 1/10 of a second. Be especially vigilant about those queries generated by Object Relational Mappers like Active Record, Ruby's ORM layer.
Open Source – What is it and why is it important?
Open Source, a term understood well by the technology set, but not enough by everyone.
Open Source for the software industry is like generic drugs for the pharmaceutical industry. It enables more players to come to the table, it is a huge driving force behind internet infrastructures, which are built on Linux, Apache and many other technologies. It is the backbone of companies like google, and facilitates cloud services from the likes of Amazon EC2, Joyent, Rackspace and many others.
It is the rising tide that lifts all boats, if you will.
Professional Deployments Use Puppet For Configuration Management
Puppet is a configuration management tool that can be used to great advantage managing the configurations of a large fleet of servers in an enterprise.
My first thought upon finishing Turnbull & McCune's book was that it could well have been titled Pro Deployments, for it covers a whole host of topics, integrating Puppet with a lot of other related tools.
Some of the advanced topics it covers in depth include:
- integrating Puppet with version control such as git
- setup of the standard dev, test and production environments
- conditional application of generalized configs
- managing nagios & load balancer configs to automatically add new nodes
- capitalizing on puppet forge modules (like rpm packages)
- testing your puppet configs with cucumber
- reporting with the dashboard and the command line
Amazon EC2 Outage – Failures, Lessons and Cloud Deployments
Now that we've had a chance to take a deep breath after last week's AWS outage, I'll offer some comments of my own. Hopefully just enough time has passed to begin to have a broader view, and put events in perspective.
Despite what some reports may have announced, Amazon wasn't down, but rather a small part of Amazon Web Services went down. A failure, yes. Beyond their service level agreement of 99.95% yes also. Survivable, yes to this last question too.
Learning From Failure
The business management conversation du jour is all about learning from failure, rather than trying to avoid it. Harvard Business Review's April issue headlined with "The Failure Issue - How to Understand It, Learn From It, and Recover From It". The economist's April 16th issue had some similarly interesting pieces one by Schumpeter "Fail often, fail well",
and another in April 23rd issue "Lessons from Deepwater Horizon and Fukushima".
With all this talk of failure there is surely one takeaway. Complex systems will fail and it is in the anticipation of that failure that we gain the most. Let's stop howling and look at how to handle these situations intelligently.
How Do You Rebuild A Website?
In the cloud you will likely need two things. (a) scripts to rebuild all the components in your architecture, spinup servers, fetch source code, fetch software and configuration files, configure load balancers and mount your database and more importantly (b) a database backup from which you can rebuild your current dataset.
Want to stick with EC2, build out your infrastructure in an alternate availability zone or region and you're back up and running in hours. Or better yet have an alternate cloud provider on hand to handle these rare outages. The choice is yours.
Mitigate risk? Yes indeed failure is more common in the cloud, but recovery is also easier. Failure should pressure the adoption of best practices and force discipline in deployments, not make you more of a gunslinger!
Want to see an extreme example of how this can play in your favor? Read Jeff Atwood's discussion of so-called Chaos Monkey, a component whose sole job it is to randomly kill off servers in the Netflix environment at random. Now that type of gunslinging will surely keep everyone on their toes! Here's a Wired article that discusses Chaos Monkey.
George Reese of enStratus discusses the recent failure at length. The I would argue calling Amazon's outage the Cloud's Shing Moment, all of his points are wisened and this is the direction we should all be moving.
Going The Way of Commodity Hardware
Though it is still not obvious to everyone, I'll spell it out loud and clear. Like it or not, the cloud is coming. Look at these numbers.
Furthermore the recent outage also highlights how much and how many internet sites rely on cloud computing, and Amazon EC2.
Way back in 2001 I authored a book on O'Reilly called "Oracle and Open Source". In it I discussed the technologies I was seeing in the real world. Oracle on the backend and Linux, Apache, and PHP, Perl or some other language on the frontend. These were the technologies that startups were using. They were fast, cheap and with the right smarts reliable too.
Around that time Oracle started smelling the coffee and ported it's enterprise database to Linux. The equation for them was simple. Customers that were previously paying tons of money to their good friend and confidant Sun for hardware, could now spend 1/10th as much on hardware and shift a lot of that left over cash to - you guessed it Oracle! The hardware wasn't as good, but who cares because you can get a lot more of it.
Despite a long entrenched and trusted brand like Sun being better and more reliable, guess what? Folks still switched to commodity hardware. Now this is so obvious, no one questions it. But the same trend is happening with cloud computing.
Performance is variable, disk I/O can be iffy, and what's more the recent outage illustrates front and center, the servers and network can crash at any moment. Who in their right mind would want to move to this platform?
If that's the question you're stuck on, you're still stuck on the old model. You have not truely comprehended the power to build infrastructure with code, to provision through automation, and really embrace managing those components as software. As the internet itself has the ability to route around political strife, and network outages, so too does cloud computing bring that power to mom & pop web shops.
Conclusions
- Have existing investments in hardware? Slow and cautious adoption makes most sense for you.
- Have seasonal traffic variations? An application like this is uniquely suited to the cloud. In fact some of the gaming applications which can autoscale to 10x or 100x servers under load, are newly solveable with the advent of cloud computing.
- Are you currently paying a lot for disaster recovery systems that primarily lay idle. Script your infrastructure for rebuilding from bare metal, and save that part of the budget for more useful projects.
Migrating Business To The Cloud – Advantages and Challenges
Cloud Computing Use Cases
Cloud Computing may not make sense for all application types. But as with the adoption of commodity hardware and Linux over a decade ago, economic considerations will continue to pressure adoption.
** Original article -- Intro to EC2 Cloud Deployments **
What types of applications do fit well in the cloud?
- Applications with Seasonal Traffic Patterns
- Proof-of-concept Applications
- Quick Temporary Dev & Test Environments
- CPU Intensive Applications
- On-Demand or Unknown Future Demand
Seasonal Traffic Patterns
