Enterprise Initiatives

This blog focuses on Enterprise IT topics such as Enterprise Architecture, Portfolio Management, Change Management, Business Process Management, and recaps various technology events and news.


I just read a post on ZDNet where Lawson's CEO Harry Debes claims that SaaS is a failure and that it will die in two years. He also comments that people (meaning me and you) "are stupid" and "make the same mistakes over and over". Another great comment is that he complains how SaaS does not allow vendors to lock in its customers:

Getting signed up as a SaaS customer is fast, but getting out is just as fast. Whereas traditional software is like cocaine--you're hooked. It's too difficult and expensive to switch providers once you've invested in one.

Wow! How customer focused is this guy? I guess this explains why the previous version of Lawson required users to have a Unix login and a telnet session and why the product was still based on Cobol. I worked at a place that used Lawson and I was stunned by how far behind the product was from an architectural standpoint. Now I understand why.

The criticism that this guy makes towards the technology is that same old resistance to change that stalls innovation. We see it with SOA, Cloud Computing, and other initiatives that are innovative and require people to change their ways. There are leaders, followers, and stragglers. This guy is definitely a straggler and may severely hurt his company and his shareholders with his closed minded approach to technology, especially if he is wrong!

In closing, my favorite comment in response to the article is by CEO John Grabski of ClearMomentum....
I hope there are more CEOs out there with the same view. Taking their customers is like shooting fish in a barrel.
As a great leader said recently, "Enough!"



Introduction

Over the past two decades, most companies have embraced the World Wide Web as a standard platform for delivering applications to consumers, partners, customers, and even internal end users. The web offers companies easier deployments, a standard browser interface that requires minimal training, and access anywhere in the world at anytime and on any device. The downside of web applications is the limitations of HTML and the ability to deliver rich content that compares to desktop applications. Enter RIA (rich internet applications) which gives web applications the richness of desktop applications with all the benefits of web. Adobe has been the leader in the space for years. Flex was first released in 2004. They have dominated the market place against various competitors, both commercial and open source. In 2007, Microsoft introduced their Silverlight product. Silverlight is the first real threat to Adobe’s Flex. The rest of this document will focus on the pros and cons of these technologies, possible outcomes, and what the impact of this RIA race will mean to vendors, companies, and consumers.


History of Flex and Silverlight

To provide a fair comparison of these two products, it is important to become familiar with the history of the Adobe Flex and Microsoft Silverlight products. Without understanding the different releases and product roadmaps, it becomes extremely challenging to perform an apples to apples comparison.


Flex version 1.0 was first released in March of 2004. Flex requires Macromedia’s Flash runtime which is a virtual machine that runs on any operating system. In 2006, Adobe released three Beta versions of Flex 2.0 before delivering the final 2.0 version in June of the same year. The new version was based on Eclipse, an open source development platform that is popular among most Java development environments. Coinciding with this release was a new release of ActionScript 3. ActionScript is the core development language of the popular Flash Player. In 2007, Adobe released three Beta versions of Flex 3.0 with the final production 3.0 release delivered on February 25, 2008. The most significant change in this release was to make the Flex SDK an open source product. Now developers were free to contribute to the SDK which was well received by the developer community. In addition to major enhancements including integration with Adobe’s Creative Suites products, Adobe also released the first version of their own runtime called Adobe Air (formerly called Apollo). The next version (4.0) is scheduled for release in 2009. We can expect a Beta release late this year. The features have not yet been announced but one can assume that they will be addressing some of the areas that Silverlight has an advantage, including better integration with .Net.


Silverlight is a web browser plug-in that marks the first Microsoft product that is truly cross platform and cross browser compatible. The first release of Silverlight was delivered in April 2007. The focus in this release was more geared towards multimedia and lacked many features that Flex 2.0 and the 3.0 Beta version had at that time. Silverlight 1.0 depends on XAML as the underlying development language. XAML is an extendable XML language that was created by Microsoft and used extensively with the Windows .Net 3.0 framework. The next version of Silverlight, version 2.0 is targeted for late summer/early fall of 2008. The first Beta version was released in March of this year. The big news for 2.0 is the integration with Visual Studio. Now developers can use development languages that they are familiar with like C# and Visual Basic. Another much needed feature is the addition of robust debugging functionality and full set of controls for developers.


It is important to understand the major feature sets of each release. There is heavy debate on which product is best. Many Adobe fans compare Flex 3.0 to Silverlight 1.0. There is no comparison. Silverlight 1.0 was focused on getting a product out in the market place while the development team focused on creating a more robust version (now named 2.0). The Microsoft supporters, however, talk about the features in 2.0 that do not exist yet. This is not a fair comparison either since Flex also has a very promising feature set in their future release. For the remainder of this document, I will focus on Flex 3.0 versus Silverlight 2.0.


Strengths and weaknesses of Flex

Adobe Flex has a huge advantage over Microsoft Silverlight in product maturity, developer community following, and production deployments. The biggest advantage, however, is that the Flash runtime is installed on well over 90% of all PCs and laptops across the world (see Figure 1).

Figure 1

The Flash runtime also works on a variety of platforms (Windows, Mac, Linux, Solaris, HP-UX, Pocket PC, OS/2, and several others). Flash is viewable in over 85% of all browsers. Since Flex runs on the Flash Player, it is truly a cross platform, cross browser product with world wide acceptance. There is also a strong developer community and the Flex products are mature since they have been through three major release cycles. Another advantage that Flex has is that many major vendors are using Flex to deliver rich content. Microstrategy leverages Flex to deliver robust, drillable result sets and even Flash based emails to end users. Google (Google Maps), Yahoo (Messenger), IBM, SAP, E-Trade, and Business Objects are just a few of the major vendors and service providers who rely on Flex to deliver rich user experiences to their customers.


Another big benefit of Flex is that the SDK is now open source. This creates several benefits. First, testing of Flex now has thousands more eyes that can find bugs and submit them back into the community. Going open source also allows the Flex community to help drive the products direction and feature sets. Making Flex open source is also a good way to combat Microsoft, who is the nemesis of most open source advocates.


One of the biggest complaints I have heard about Flex is the learning curve required for developers. Flex uses ActionScript 3 which is a proprietary language that is required for running on the Flash Player. This is yet another language that developers must learn and is not as intuitive as Java and C#. This can lead to high costs for hiring companies and must be considered when calculating the total cost of ownership.


Strengths and weaknesses of Silverlight

Microsoft is putting together a great product to compete with Flex. In my opinion, they are still a couple of years away from matching Flex in features and community strength. However, Microsoft’s marketing capabilities coupled with their ability to target developers can help Microsoft make major gains in market share in the near future. Silverlight 2.0 allows developers to code in C# and VB which greatly reduces the learning curve. This can be a major selling point to companies that are planning to invest in RIA technologies in the future. Many companies already rely heavily on Microsoft technologies and may see Silverlight as a natural extension to their existing development stack. Microsoft also has an incredible amount of cash available to them to steer this product in whatever direction they see fit. They have already partnered with Major League Baseball and the Olympics which has created a tremendous amount of positive marketing and brand recognition.


The weaknesses of Silverlight are plenty, but when put into perspective of how long they have been in the RIA space (first release in April 2007) they have made tremendous strides in this area. First of all, Microsoft is the new kid on the block and does not have the track record of stability, performance, and maturity of the well established Flex product line. The biggest challenge Microsoft faces is trying to get the Silverlight plug-in installed on at least 80% of the PCs and laptops in the market place. If you look at Figure 1 above, you will see that the top Microsoft product installed on PCs is Windows Media Player which is slightly over 80%. This product has been out for several years so it would be unrealistic to expect the Silverlight plug-in to reach critical mass any time soon.


Silverlight currently only runs on Windows and the Mac, although an open source project called Moonlight is underway to allow it to run on Linux. Back in May of this year, Roger Magoulas from O’Reilly shared this chart (Figure 2).


Figure 2

This chart shows that book sales of Flash are selling 6-7 times higher then Silverlight. In March of this year, Eric Lai of Computerworld wrote an article comparing job postings for Flash versus Silverlight on the major job boards. His study showed that Flash skills were in demand about 41 times higher than Silverlight. Both the study on books and jobs are not extremely scientific by any means, but what they do show is that Silverlight has a long way to go to become mainstream.


Another problem Microsoft is facing is consumer trust. Many consumers have heard all of Microsoft’s promises of cross platform capabilities before only to see them not deliver on their promise. Microsoft’s cash cow for years has been their operating system. Many consumers simply can’t trust any message from Microsoft which goes against their core strategy of tying customers to their platform. Security is another issue. Microsoft does not have the greatest reputation for secure software. How many corporations are willing to roll out another Microsoft product to all of their desktops? Some may argue that Flash is no more secure, but it is already on almost every machine out there.


Possible Outcomes

There are four possible outcomes that I see. The first is that Flex will continue to dominate the market place due to the maturity of their existing products, the widespread use and acceptance of Flash, and the large investments made by major software vendors in Flex technology. Microsoft will steal some market share but in the end it will be another failed attempt to conquer the web. I feel that this is the most likely scenario. Microsoft is already losing market share in the browser war and the operating system war, although they still have a tremendous lead over their competitors. Google is becoming a dominant force on the web and open source technologies are dominating the Web 2.0 world. In every aspect of computing, Microsoft is dealing with stronger competition then they have ever seen before. RIA will be even more challenging because they are not the leader in this space.


The second most likely option that I see is that Silverlight matches Flex’s market share. The big advantage that Microsoft has is the development environment and the fact that Flex currently does not integrate with .Net backends (although they are working on it). Microsoft already has a huge developer community and many of these people can easily be persuaded to adopt Silverlight as their RIA of choice. For companies that produce consumer facing content or control the end user client machines, the Silverlight plug-in issue is not that big of a deal. Many consumers are willing to download Silverlight plug-in just as well as they will download Flash, QuickTime, and others. It is the companies that deliver applications to other enterprises that will have the challenge. As a chief architect for a medium size company, one of our criteria for selecting vendor tools is that the tool is zero-footprint or requires no installation of software on client PCs. Many other IT shops will have the same constraint because of the B2B nature of their applications. If you have no control over the client’s desktop, forcing clients to push software out on their network can be a huge show stopper.


A third possible outcome is Silverlight will fail to gain any significant market share. I find this highly unlikely. Microsoft has a ton of money and smart people behind this product. Their product vision appears to be very solid on the surface and their initial product offering is impressive for the short amount of time that they have been in the RIA space. They should easily capitalize on the numerous loyal Microsoft shops that are already in place today and I expect them to strike several more big partnerships similar to the MLB deal. I think that over the next 2-3 years Silverlight will capture about 20-30% of the market share but no more.


A fourth possible outcome is that more competition will flood the market and other products will also compete heavily for market share. JavaFx and open source project Open Laszlo are already competing, but I believe this will be a two horse race between Flex and Silverlight.



What is the impact?


This fierce competition means different things to different constituents. First let’s look at the impact to the vendors. Software vendors must keep a close eye on this RIA race. Those supporting Flex today need to make a decision whether or not they want to add support for Silverlight as well. Supporting both obviously increases the cost of developing and supporting their products. Since Flash is everywhere, they need to consider how strategic it will be to support Silverlight. Some vendors are already making the jump but others will wait and see how widely accepted Silverlight is before they assign resources to making their products support Silverlight.


Non-software companies also have a big decision to make. For companies already using Flex, there must be some compelling reasons to switch. For those evaluating RIA for the first time, they have a tough decision to make. Do they play it safe and go with the proven product in Flex, or do they buy into the marketing hype and go with the promises of Silverlight. Silverlight does have a compelling TCO by enabling developers to leverage Visual Studio as opposed to having to learn ActionScript 3.


The consumer is the least impacted. For consumers it is simply a matter of downloading the plug-in or not. The people that won’t download the plug-in are typically anti Microsoft anyway. So Microsoft will continue to target popular providers of rich content for partnerships to get more installs of the Silverlight plug-in throughout the world.


Conclusion

I expect Silverlight to gain market share over the next two to three years but still see Flex prevailing as the industry leader in the long run. The best news is that the competition will force both products to be more innovative. Both products will aggressively address their weaknesses and combat any new features that their competitor offers. This is great news for vendors, companies, and consumers. We should expect to see huge advancements of features and functionality from both of these products over the next few years. We should also expect to see improvements in speed, security, ease of use as both Flex and Silverlight battle for the RIA throne.




I wrote a post a week ago about lessons learned from the Dot-Com bust. In the 1990's, startups were a dime a dozen and VC money was flowing endlessly. Back then, startups were requiring huge sums of money just to get their infrastructure in place. Many of these companies could not afford the initial funding to build scalability into their infrastructure...a huge risk!

Now it's 2008 and VC money isn't as easy to come by, especially at the enormous amounts we saw in the Dot-Com days. The challenge many startups have is keeping the company small to control costs, but at the same time quickly bringing a product or service to market. These two goals can conflict. One approach is to limit your startup costs in your initial infrastructure build out by outsourcing your infrastructure needs to a PaaS (Platform as a Service) provider. This meets both objectives; control costs and quicker deployment. Let's discuss how.

Control Costs
On the surface, the cost of infrastructure in the cloud may sound very expensive. But let's not get stuck on the "sticker price". Instead, let's talk about total cost of ownership (TCO). If I am running a new startup with the requirements of hosting web based products or services that require 99% uptime, the startup costs are huge. Here is a short list of things I would have to shell out money for:

  • Servers
  • Routers
  • Firewalls
  • Software licenses
  • Load balancers
  • Lease or buy data center floor space
  • Business continuity and disaster recovery capabilities
  • Data storage devices
  • Cooling
  • Operations and Systems Administration personnel
  • Capital funds for the projects to put all of this infrastructure in place
The PaaS approach, often called utility computing, allows you to run your infrastructure as a collection of virtual machines at world class data centers strategically located in several locations across the globe. In addition, their core competency is in providing reliable, secure, and scalable infrastructure. Companies tend to invest heavily in their core competencies and excel at it. For many startups, infrastructure is a necessary evil, not a company wide focus. So don't look at the sticker price, look at the TCO.

Quicker to Market
In addition to all of these costs, the time it takes for a new team of people to assemble all of this infrastructure is not minimal. For startups who stick to standards and refrain from using proprietary technology solutions, they can have their infrastructure up and running in the cloud in just a few weeks or even days. The PaaS providers will say hours, but I am including the time it takes the company to validate and tweak the environment accordingly. Here are some of the time killers that can be avoided:
  • Long vendor assessment initiatives for the various hardware and software vendors
  • Multiple procurement processes for each vendor
  • Multiple hardware and software installations
  • Recruiting and hiring costs coupled with ongoing payroll costs
  • Leasing or purchasing of real estate for datacenter(s)
  • Time and costs for telecommunications and security efforts
Most startups strive to minimize the size of their staff. This is especially true in the early days when it might be a while before the company is cash flow positive. PaaS doesn't eliminate the need for full time employees but it does greatly reduce it.

One thing that I am not saying is that security doesn't matter. It matters more then ever when you outsource your data management. What I am saying is that you don't need to invest the time and money upfront to build out a highly secure infrastructure. Instead, you need to do a thorough vendor evaluation and choose the best provider to meet your infrastructure requirements. Then you have to manage your vendor and ensure that all of your agreed upon SLAs are being met.

Startups better suited for PaaS then established companies
Startups have a huge advantage over companies that have been around a while. It is much easier to start in the clouds then it is to move legacy systems and infrastructure into the clouds. I wrote a post on CIO.com last week about how SOA can get you to the clouds quicker. Startups who can see the benefits of cloud computing should take a service-oriented approach in the development of their products and services. The more abstract and loosely coupled their software is, the more agile and flexible they will become. It will also allow them to switch PaaS providers if they are not getting the level of service or support that they want. Another advantage is it can allow the startup to actually leverage two PaaS providers to eliminate the risk of downtime in case one provider fails. Having this option gives a startup the ability to load balance across PaaS vendors and send the majority of the traffic to the lower cost provider. I haven't seen this done but it is a great opportunity to use leverage on the vendors.

Summary
In summary, startups can reduce their upfront costs of infrastructure and staff by starting in the cloud. Long term (5 to 10 years), PaaS or utility computing will likely be the norm. So get a head start and launch in the clouds today. Focus on your core competency while your competition continues to spend millions to keep the lights on.



I just finished a research paper on the history of the Dot-Com bust for my MBA studies. By the way, I am finally finished next week after three long years! Also this week, I have been doing extensive research on Cloud Computing, specifically Platform-as-a-Service, SOA, and Social Software. What I have noticed is some striking similarities to the Dot-Com hype of the 90's and the hype that is going on today.

What caused the Dot-Com bubble to burst?
In the early 1990’s, former Vice President Al Gore coined the term “Information Superhighway” and discussed expanding the Internet far beyond its current use. The media ran with this vision and suddenly the world was infatuated with the idea, or should I say fantasy, of creating a $200B eCommerce industry overnight (Krueger, 2007).

Suddenly, startup companies called dot-coms started appearing everywhere. The big problem was that many of these startups did not have a sound business model. Instead, they were betting on brand recognition and market share. They borrowed money from venture capitalists and generated millions from IPOs. Many of the dot-coms had a business model that was not geared towards profit, but towards how much traffic they could generate on their web site. Investors put aside best practices and jumped in head first by throwing tons of cash at these “paper” rich companies. Even worse, many of these companies put aside best practices of business and IT management to be the first one in the marketplace to capture users.

What is happening today?

Just like in the 1990’s, the media is making their living by excessively hyping key technologies like SOA, Cloud Computing, Web 2.0, and many others. Do I believe that these technologies are all difference makers? Yes, they are key technologies just like the Internet and Web 1.0 was in the Dot-Com era. But many of the promises of the Dot-Com era are starting to be realized today. This is a result of the learnings from the early pioneers who dove into the Web head first. The same will hold true for today's hyped technologies. The pioneers will stumble through trial and error and over time these technologies will mature to the point where the masses can take advantage of it at a lower cost.


But history tells us that it takes more then a cool technology to make real money. It also takes a sustainable business model, and a combination of sound business and technology management best practices to execute against the business model.


What has changed?

One of the positive things that came out of the bust was huge advancements in technology. Back then, there were major limitations in bandwidth and web functionality. Since those times, enough fiber optical cable has been laid to circle the world over several 100 times. This has paved the way for greater bandwidth and for new functionality that now makes web browsers capable of creating rich user experiences that are equal to desktop applications. Throw in globalization and the early Dot-Com vision is becoming a reality.

The biggest difference today is the amount of capital it takes to start a Web company. Back in the Dot-Com days, startups were ripping through 10’s to 100’s of millions of VC funding and IPO money. Today, a startup can quickly leverage open source technologies, run their entire infrastructure in the cloud, and leverage a combination of SaaS and mashups to quickly get a product up and running in months. The cost of entry is minimal.


But it’s all still the same

But I still see VCs investing in strange companies with questionable business models. Google the words "Web 2.0 Startups" and you will see a few announcements a week were some bizarre company has just secured Series A or Series B funding. Check this link from last year and some of these companies make me start thinking about the Pets.com sock puppet. The Web is getting so crowded with niche social networking sites (LonelyGirl.Com, NurseLinkup.com, BestPartyEver.com, etc.) but VCs are still buying. I guess investing $3-5M is not that risky to the VC firms, especially when their Dot-Com investments were 10 to 100 times larger.

It’s not the technology

What is getting lost in the sea of hype and madness is that these companies are founded on the technologies of the future. Like it or not, we will be operating primarily in the cloud several years from now. The PC will be irrelevant since there will be no need for local disk and CPU intensive processing by the client. The Client will simply be our window to the Web where everything is virtualized, broken down in functional services, and truly independent of the technology and location from where it is being executed. The problem is, the media and vendors are convincing us that we must do this now or we will fall behind. The challenge will be for IT executives to apply these technologies to solve real business problems, not to feed the pockets of vendors and media types.


References

Krueger, S. (2007). The Rise and Fall of the Dot-Com Bubble (Part 1). Retrieved on August 1, 2008 from http://www.entityarts.net/blog/steve_krueger/08-05-2007/rise_and_fall_dot_com_bubble_part_1

Subscribe to: Posts (Atom)

My favorite sayings

"If you don't know where you're going, any road will get you there"

"Before you build a better mouse trap, make sure you have some mice"