Software as a service

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

Software as a service (SaaS /sæs/[1]) is a software licensing and delivery model in which software is licensed on a subscription basis and is centrally hosted. It is sometimes referred to as "on-demand software", and was formerly referred to as "software plus services" by Microsoft.[2] SaaS is typically accessed by users using a thin client via a web browser. SaaS has become a common delivery model for many business applications, including office software, messaging software, payroll processing software, DBMS software, management software, CAD software, development software, gamification, virtualization,[3] accounting, collaboration, customer relationship management (CRM), Management Information Systems (MIS), enterprise resource planning (ERP), invoicing, human resource management (HRM), talent acquisition, learning management systems, content management (CM), Geographic Information Systems (GIS), and service desk management.[4] SaaS has been incorporated into the strategy of nearly all leading enterprise software companies.[5][6]

According to a Gartner estimate, SaaS sales in 2018 were expected to grow 23% to $72 billion.[7]

SaaS applications are also known as Web-based software, on-demand software and hosted software.[8]

The term "Software as a Service" (SaaS) is considered to be part of the nomenclature of cloud computing, along with Infrastructure as a Service (IaaS), Platform as a Service (PaaS), Desktop as a Service (DaaS),[9] managed software as a service (MSaaS), mobile backend as a service (MBaaS), and information technology management as a service (ITMaaS).

History[edit]

Centralized hosting of business applications dates back to the 1960s. Starting in that decade, IBM and other mainframe providers conducted a service bureau business, often referred to as time-sharing or utility computing. Such services included offering computing power and database storage to banks and other large organizations from their worldwide data centers.[citation needed]

The expansion of the Internet during the 1990s brought about a new class of centralized computing, called Application Service Providers (ASP). ASPs provided businesses with the service of hosting and managing specialized business applications, with the goal of reducing costs through central administration and through the solution provider's specialization in a particular business application. Two of the world's pioneers and largest ASPs were USI, which was headquartered in the Washington, DC area, and Futurelink Corporation, headquartered in Irvine, California.[10]

Software as a Service essentially extends the idea of the ASP model. The term Software as a Service (SaaS), however, is commonly used in more specific settings:

  • While most initial ASP's focused on managing and hosting third-party independent software vendors' software, as of 2012 SaaS vendors typically develop and manage their own software.
  • Whereas many initial ASPs offered more traditional client-server applications, which require installation of software on users' personal computers, SaaS solutions of today rely predominantly on the Web and only require a web browser to use.
  • Whereas the software architecture used by most initial ASPs mandated maintaining a separate instance of the application for each business, as of 2012 SaaS solutions normally utilize a multitenant architecture, in which the application serves multiple businesses and users, and partitions its data accordingly.

The acronym allegedly first appeared in an article called "Strategic Backgrounder: Software As A Service," internally published in February 2001 by the Software & Information Industry Association's (SIIA) eBusiness Division.[11]

DbaaS (Database as a Service) has emerged as a sub-variety of SaaS.[12]

Distribution[edit]

The cloud (or SaaS) model has no physical need for indirect distribution because it is not distributed physically and is deployed almost instantaneously, thereby negating the need for traditional partners and middlemen. However, as the market has grown, SaaS and managed service players have been forced to try to redefine their role.[13]

Pricing[edit]

Unlike traditional software, which is conventionally sold as a perpetual license with an up-front cost (and an optional ongoing support fee), SaaS providers generally price applications using a subscription fee, most commonly a monthly fee or an annual fee.[14] Consequently, the initial setup cost for SaaS is typically lower than the equivalent enterprise software. SaaS vendors typically price their applications based on some usage parameters, such as the number of users using the application. However, because in a SaaS environment customers' data reside with the SaaS vendor, opportunities also exist to charge per transaction, event, or other unit of value, such as the number of processors required.[15]

The relatively low cost for user provisioning (i.e., setting up a new customer) in a multitenant environment enables some SaaS vendors to offer applications using the freemium model.[15] In this model, a free service is made available with limited functionality or scope, and fees are charged for enhanced functionality or larger scope.[15] Some other SaaS applications are completely free to users, with revenue being derived from alternative sources such as advertising.[16]

A key driver of SaaS growth is SaaS vendors' ability to provide a price that is competitive with on-premises software. This is consistent with the traditional rationale for outsourcing IT systems, which involves applying economies of scale to application operation, i.e., an outside service provider may be able to offer better, cheaper, more reliable applications.[citation needed]

Common Examples[edit]

A list of popular software as a service.

Architecture[edit]

The vast majority of SaaS solutions are based on a multitenant architecture. With this model, a single version of the application, with a single configuration (hardware, network, operating system), is used for all customers ("tenants"). To support scalability, the application is installed on multiple machines (called horizontal scaling). In some cases, a second version of the application is set up to offer a select group of customers access to pre-release versions of the applications (e.g., a beta version) for testing purposes. This is contrasted with traditional software, where multiple physical copies of the software — each potentially of a different version, with a potentially different configuration, and often customized — are installed across various customer sites.[17] In this traditional model, each version of the application is based on a unique code.[18]

Although an exception rather than the norm, some SaaS solutions do not use multitenancy, or use other mechanisms—such as virtualization—to cost-effectively manage a large number of customers in place of multitenancy.[19] Whether multitenancy is a necessary component for software as a service is a topic of controversy.[20]

There are two main varieties of SaaS:

Vertical SaaS
Software which answers the needs of a specific industry (e.g., software for the healthcare, agriculture, real estate, finance industries).
Horizontal SaaS
The products which focus on a software category (marketing, sales, developer tools, HR) but are industry agnostic.[21]

Characteristics[edit]

Although not all software-as-a-service applications share all traits, the characteristics below are common among many SaaS applications:

Configuration and customization[edit]

SaaS applications similarly support what is traditionally known as application configuration. In other words, like traditional enterprise software, a single customer can alter the set of configuration options (a.k.a. parameters) that affect its functionality and look-and-feel. Each customer may have its own settings (or: parameter values) for the configuration options. The application can be customized to the degree it was designed for based on a set of predefined configuration options.

For example, to support customers' common need to change an application's look-and-feel so that the application appears to be having the customer's brand (or—if so desired—co-branded), many SaaS applications let customers provide (through a self service interface or by working with application provider staff) a custom logo and sometimes a set of custom colors. The customer cannot, however, change the page layout unless such an option was designed for.

Accelerated feature delivery[edit]

SaaS applications are often updated more frequently than traditional software,[22] in many cases on a weekly or monthly basis. This is enabled by several factors:

  • The application is hosted centrally, so an update is decided and executed by the provider, not by customers.
  • The application only has a single configuration, making development testing faster.
  • The application vendor does not have to expend resources updating and maintaining backdated versions of the software, because there is only a single version.[23]
  • The application vendor has access to all customer data, expediting design and regression testing.
  • The solution provider has access to user behavior within the application (usually via web analytics), making it easier to identify areas worthy of improvement.

Accelerated feature delivery is further enabled by agile software development methodologies.[24] Such methodologies, which have evolved in the mid-1990s, provide a set of software development tools and practices to support frequent software releases.

Open integration protocols[edit]

Because SaaS applications cannot access a company's internal systems (databases or internal services), they predominantly offer integration protocols[25] and application programming interfaces (APIs) that operate over a wide area network. Typically, these are protocols based on HTTP, REST, and SOAP.

The ubiquity of SaaS applications and other Internet services and the standardization of their API technology has spawned development of mashups, which are lightweight applications that combine data, presentation and functionality from multiple services, creating a compound service. Mashups further differentiate SaaS applications from on-premises software as the latter cannot be easily integrated outside a company's firewall.

Collaborative (and "social") functionality[edit]

Inspired by the success of online social networks and other so-called web 2.0 functionality, many SaaS applications offer features that let their users collaborate and share information.

For example, many project management applications delivered in the SaaS model offer—in addition to traditional project planning functionality—collaboration features letting users comment on tasks and plans and share documents within and outside an organization. Several other SaaS applications let users vote on and offer new feature ideas.

Although some collaboration-related functionality is also integrated into on-premises software, (implicit or explicit) collaboration between users or different customers is only possible with centrally hosted software.

OpenSaas[edit]

OpenSaaS refers to software as a service (SaaS) based on open source code. Similar to SaaS applications, Open SaaS is a web-based application that is hosted, supported and maintained by a service provider. While the roadmap for Open SaaS applications is defined by its community of users, upgrades and product enhancements are managed by a central provider. The term was coined in 2011 by Dries Buytaert, creator of the Drupal content management framework.[26]

Andrew Hoppin, a former Chief Information Officer for the New York State Senate, has been a vocal advocate of OpenSaaS for government, calling it "the future of government innovation." He points to WordPress and Why Unified as a successful example of an OpenSaaS software delivery model that gives customers "the best of both worlds, and more options. The fact that it is open source means that they can start building their websites by self-hosting WordPress and customizing their website to their heart’s content. Concurrently, the fact that WordPress is SaaS means that they don’t have to manage the website at all -- they can simply pay WordPress.com to host it."[27]

Drupal Gardens, a free web hosting platform based on the open source Drupal content management system, offers another example of what Forbes contributor Dan Woods calls a "new open source model for SaaS". According to Woods, "Open source provides the escape hatch. In Drupal Gardens, users will be able to press a button and get a source code version of the Drupal code that runs their site along with the data from the database. Then, you can take that code, put it up at one of the hosting companies, and you can do anything that you would like to do."[28]

Adoption drivers[edit]

Several important changes to the software market and technology landscape have facilitated acceptance and growth of SaaS solutions:

  • The growing use of web-based user interfaces by applications, along with the proliferation of associated practices (e.g., web design), continuously decreased the need for traditional client-server applications. Consequently, traditional software vendor's investment in software based on fat clients has become a disadvantage (mandating ongoing support), opening the door for new software vendors offering a user experience perceived as more "modern".
  • The standardization of web page technologies (HTML, JavaScript, CSS), the increasing popularity of web development as a practice, and the introduction and ubiquity of web application frameworks like Ruby on Rails or Laravel (PHP) gradually reduced the cost of developing new SaaS solutions, and enabled new solution providers to come up with competitive solutions, challenging traditional vendors.
  • The increasing penetration of broadband Internet access enabled remote centrally hosted applications to offer speed comparable to on-premises software.
  • The standardization of the HTTPS protocol as part of the web stack provided universally available lightweight security that is sufficient for most everyday applications.
  • The introduction and wide acceptance of lightweight integration protocols such as REST and SOAP enabled affordable integration between SaaS applications (residing in the cloud) with internal applications over wide area networks and with other SaaS applications.

Adoption challenges[edit]

Some limitations slow down the acceptance of SaaS and prohibit it from being used in some cases:

  • Because data is stored on the vendor's servers, data security becomes an issue.[29]
  • SaaS applications are hosted in the cloud, far away from the application users. This introduces latency into the environment; for example, the SaaS model is not suitable for applications that demand response times in the milliseconds.
  • Multitenant architectures, which drive cost efficiency for SaaS solution providers, limit customization of applications for large clients, inhibiting such applications from being used in scenarios (applicable mostly to large enterprises) for which such customization is necessary.
  • Some business applications require access to or integration with customer's current data. When such data are large in volume or sensitive (e.g. end users' personal information), integrating them with remotely hosted software can be costly or risky, or can conflict with data governance regulations.
  • Constitutional search/seizure warrant laws do not protect all forms of SaaS dynamically stored data. The end result is that a link is added to the chain of security where access to the data, and, by extension, misuse of these data, are limited only by the assumed honesty of 3rd parties or government agencies able to access the data on their own recognizance.[30][31][32][33][34]
  • Switching SaaS vendors may involve the slow and difficult task of transferring very large data files over the Internet.
  • Organizations that adopt SaaS may find they are forced into adopting new versions, which might result in unforeseen training costs, an increase in probability that a user might make an error, or instability from bugs in the newer software.
  • Should the vendor of the software go out of business or suddenly EOL the software, the user may lose access to their software unexpectedly, which could destabilize their organization's current and future projects, as well as leave the user with older data they can no longer access or modify.
  • Relying on an Internet connection means that data are transferred to and from a SaaS firm at Internet speeds, rather than the potentially higher speeds of a firm’s internal network.[35]
  • Can the SaaS hosting company guarantee the uptime level agreed in the SLA (Service Level Agreement)?

The standard model also has limitations:

  • Compatibility with hardware, other software, and operating systems.[36]
  • Licensing and compliance problems (unauthorized copies of the software program putting the organization at risk of fines or litigation).
  • Maintenance, support, and patch revision processes.

Engineering applications[edit]

Engineering simulation software, traditionally delivered as an on-premises solution through the user's desktop, is an ideal candidate for SaaS delivery. The market for SaaS engineering simulation software is in its infancy, but interest in the concept is growing for similar reasons as interest in SaaS is growing in other industries. The main driver is that traditional engineering simulation software required a large up-front investment in order to access the simulation software. The large investment kept engineering simulation inaccessible for many startups and middle market companies who were reluctant or unable to risk a large software expenditure on unproven projects.[37]

Healthcare applications[edit]

According to a survey by HIMSS Analytics, 83% of US IT healthcare organizations are now using cloud services with 9.3% planning to, whereas 67% of IT healthcare organizations are currently running SaaS-based applications.[38]

Data escrow[edit]

Software as a service data escrow is the process of keeping a copy of critical software-as-a-service application data with an independent third party. Similar to source code escrow, where critical software source code is stored with an independent third party, SaaS data escrow is the same logic applied to the data within a SaaS application. It allows companies to protect and insure all the data that resides within SaaS applications, protecting against data loss.[39]

There are many and varied reasons for considering SaaS data escrow including concerns about vendor bankruptcy[40][41] unplanned service outages and potential data loss or corruption. Many businesses are also keen to ensure that they are complying with their own data governance standards or want improved reporting and business analytics against their SaaS data. A research conducted by Clearpace Software Ltd. into the growth of SaaS showed that 85 percent of the participants wanted to take a copy of their SaaS data. A third of these participants wanted a copy on a daily basis.[42]

Criticism[edit]

One notable criticism of SaaS comes from Richard Stallman of the Free Software Foundation referring to it as Service as a Software Substitute (SaaSS).[43] He considers the use of SaaS to be a violation of the principles of free software.[44] According to Stallman:

With SaaSS, the users do not have even the executable file that does their computing: it is on someone else's server, where the users can't see or touch it. Thus it is impossible for them to ascertain what it really does, and impossible to change it.

Not all SaaS products face this problem. In 2010, Forbes contributor Dan Woods noted that Drupal Gardens, a web hosting platform based on the open source Drupal content management system, is a "new open source model for SaaS". He added:

Open source provides the escape hatch. In Drupal Gardens, users will be able to press a button and get a source code version of the Drupal code that runs their site along with the data from the database. Then, you can take that code, put it up at one of the hosting companies, and you can do anything that you would like to do.[45]

Similarly, MediaWiki, WordPress and their many extensions are increasingly used for a wide variety of internal applications as well as public web services. Obtaining the code is relatively simple, as it is an integration of existing extensions, plug-ins, templates, etc. Actual customizations are rare, and usually quickly replaced by more standard publicly available extensions. There is additionally no guarantee the software source code obtained through such means accurately reflects the software system it claims to reflect.

Andrew Hoppin, a former Chief Information Officer for the New York State Senate, refers to this combination of SaaS and open source software as OpenSaaS and points to WordPress as another successful example of an OpenSaaS software delivery model that gives customers "the best of both worlds, and more options. The fact that it is open source means that they can start building their websites by self-hosting WordPress and customizing their website to their heart’s content. Concurrently, the fact that WordPress is SaaS means that they don’t have to manage the website at all – they can simply pay WordPress.com to host it."[46] The cloud (or SaaS) model has no physical need for indirect distribution because it is not distributed physically and is deployed almost instantaneously, thereby negating the need for traditional partners and middlemen.

See also[edit]

References[edit]

  1. ^ Panker, Jon; Lewis, Mark; Fahey, Evan; Vasquez, Melvin Jafet (August 2007). "How do you pronounce IT?". TechTarget. Retrieved 24 May 2012.
  2. ^ "Microsoft describes software plus services". InfoWorld. 26 July 2007. Retrieved 7 February 2017.
  3. ^ "IT Channel Glossary". CompuBase. March 2013. Retrieved 13 February 2013.
  4. ^ "What is Software as a Service (SaaS)? – Simplified". Set a Time. Retrieved 30 December 2018.
  5. ^ "IBM cloud strategy". www.ibm.com. Archived from the original on 2015-03-13.
  6. ^ Fox, A.; Patterson, D. (3 Jan 2014). Engineering Software as a Service: An Agile Approach Using Cloud Computing. Strawberry Canyon LLC. ASIN B00CCEHNUM.
  7. ^ "Hype Cycle for Software as a Service". Gartner. 31 July 2018. Retrieved 7 February 2019.
  8. ^ "What is Software as a Service (SaaS): A Beginner's Guide - Salesforce". Salesforce.com. Retrieved 2018-09-27.
  9. ^ Cimpl. "What is Everything-as-a-Service (XaaS)?". Retrieved 2016-07-26.
  10. ^ Gaw, Jonathan (Oct 20, 1999). "Ladouceur Named CEO of FutureLink". Los Angeles Times.
  11. ^ "Software As A Service: Strategic Backgrounder" (PDF). Washington, D.C.: Software & Information Industry Association. 28 February 2001. Archived from the original (PDF) on 27 September 2011. Retrieved 24 April 2011.
  12. ^ Ferrari, Elena (2010). Access Control in Data Management Systems. Synthesis Lectures on Data Management. Morgan & Claypool Publishers. p. 77. ISBN 978-1-60845-375-7. Retrieved 2012-02-13. [...] a new emerging option is represented by the Database as a Service (DbaaS) paradigm [...]. DbaaS is regulated by the same principles as Software as a Service (SaaS) and basically means the delivery of the typical functionalities of a database management system in the cloud.
  13. ^ "The year of Cloud adoption by the Channel". compuBase. March 2013. Retrieved February 13, 2013.
  14. ^ Levinson, Meridith (2007-05-15). "Software as a Service (SaaS) Definition and Solutions". CIO. Retrieved 2015-03-24.
  15. ^ a b c Byron Deeter and Ryan Jung (July 2013). "Software as a Service Pricing Strategies" (PDF).
  16. ^ Jain, Shalin. "Pricing your SaaS Application". Tenmiles Blog.
  17. ^ Hacigümüş, Hakan; Balakrishna, R. Iyer; Chen, Li; Mehrotra, S. (2002). "Executing SQL over encrypted data in the database-service-provider model". Proceedings of the 2002 ACM SIGMOD international conference on Management of data: 216–227. doi:10.1145/564691.564717.
  18. ^ Lebrun, Caroline. "The Benefits of Multi-tenancy to Manage IT & Communication Expenses". Retrieved 2016-07-26.
  19. ^ Wainewright, Phil (19 October 2007). "Workstream prefers virtualization to multi-tenancy". ZDNet (World Wide Web log). CBS Interactive. Retrieved 22 January 2016.
  20. ^ Carraro, Gianpaolo (21 June 2008). "I can't believe we are still talking about whether saas == multi-tenancy..." MS Developer network (blog). Microsoft. Retrieved 24 April 2011.
  21. ^ "7 Trends that will shape the SaaS industry in 2016".
  22. ^ Creese, Guy (18 May 2010). "SaaS vs. Software: The Release Cycle for SaaS Is Usually (Not Always) Faster". Blog. Gartner. Retrieved 24 April 2011.
  23. ^ "Benefits of SaaS". SaaSMarket. 10 December 2016. Retrieved 10 December 2016.
  24. ^ Kuhnen, Eric (8 January 2008). "Jumping to SaaS? Take Agile Software Development Along with You". DevX. QuinStreet. Retrieved 24 April 2011.
  25. ^ Cimpl. "The Arguments for Software-as-a-Service (SaaS)". Retrieved 2016-07-26.
  26. ^ Buytaert, Dries (24 January 2011). "Acquia product strategy and vision". Dries Buytaert weblog. Retrieved 5 October 2014.
  27. ^ Hoppin, Andrew (9 January 2014). "OpenSaaS and the future of government innovation". OpenSource.com. Retrieved 21 September 2014.
  28. ^ Woods, Dan (9 November 2010). "A New Open-Source Model For SaaS". Forbes. Retrieved 21 September 2014.
  29. ^ Lisserman, Miroslaw (20 December 2010). "SaaS And The Everlasting Security Concerns". Community. Forrester Research. Retrieved 24 April 2011.
  30. ^ Arthur, Charles (2010-12-14). "Google's ChromeOS means losing control of the data, warns GNU founder Richard Stallman". The Guardian. UK. Retrieved 2012-02-16.
  31. ^ Adhikari, Richard (2010-12-15). "Why Richard Stallman Takes No Shine to Chrome". Linux Insider. Retrieved 2015-03-24.
  32. ^ Stallman, Richard (2011-09-20). "Who does that server really serve?". Boston Review. GNU Project. Retrieved 15 January 2012.
  33. ^ Hill, Benjamin Mako (1 Feb 2009). "Show Me the Code". Revealing Errors. Retrieved 15 January 2012.
  34. ^ Assange, Julian (April 9, 2011). "Wikileaks revelations". RT (Interview). London. Retrieved 15 January 2012. Facebook, Google, Yahoo – all these major US organizations have built-in interfaces for US intelligence. It’s not a matter of serving a subpoena. They have an interface that they have developed for US intelligence to use.
  35. ^ Gallaugher, John. "Information Systems: A Manager's Guide to Harnessing Technology". Catalog. Flat World Knowledge. Retrieved 2012-04-21.
  36. ^ "Cloud Software as a Service (SaaS) in Cloud Computing. This is not right. Services". CloudComputingSec. 2011. Retrieved 2011-12-15.
  37. ^ Klein, Cristian (July 2, 2015). "Things SaaS providers worry about so you don't have to". . Retrieved July 14, 2015.
  38. ^ "Forbes.com".
  39. ^ Wilson, Deborah R; BonaPart, Alexa (7 August 2009). "Develop a Framework for SaaS Application Business Continuity Risk Mitigation". Gartner. Retrieved 24 April 2011.
  40. ^ May, Richard. "Software Escrow whitepaper" (PDF). UK: Virtual DCS.
  41. ^ "Software Escrow: Is Escrow dead?". 2012-06-14. Retrieved 2016-09-06.
  42. ^ "SaaS Data Escrow International Report" (PDF). RainStor. Gloucester, England: Clearpace Software. 14 December 2009. Retrieved 24 April 2011. Only 15 per cent of those who currently use, or plan to use, SaaS have no inclination to keep a copy of their data.
  43. ^ Stallman, Richard. "Who does that server really serve?". GNU Operating System. The Free Software Foundation. Retrieved 2015-03-24.
  44. ^ Stallman, Richard (18 March 2010). "Who Does That Server Really Serve?". Boston Review. Retrieved 6 July 2013.
  45. ^ Woods, Dan (9 November 2010). "A New Open-Source Model For SaaS". CIO Central. Forbes. Retrieved 21 September 2014.
  46. ^ Hoppin, Andrew (9 January 2014). "OpenSaaS and the future of government innovation". Government. OpenSource. Retrieved 21 September 2014.