Software as a service

From Wikipedia, the free encyclopedia
(Redirected from SaaS)
Jump to navigation Jump to search

Template:Short description Template:Pp Template:Redirect-distinguish Software as a service (SaaS Template:IPAc-en[1]) is a cloud computing service model where the provider offers use of application software to a client and manages all needed physical and software resources.Template:Sfn SaaS is usually accessed via a web application. Unlike other software delivery models, it separates "the possession and ownership of software from its use".Template:Sfn SaaS use began around 2000, and by 2023 was the main form of software application deployment.

Unlike most self-hosted software products, only one version of the software existsScript error: No such module "Unsubst". and only one operating system and configuration is supported. SaaS products typically run on rented infrastructure as a service (IaaS) or platform as a service (PaaS) systems including hardware and sometimes operating systems and middleware, to accommodate rapid increases in usage while providing instant and continuous availability to customers. SaaS customers have the abstraction of limitless computing resources, while economy of scale drives down the cost. SaaS architectures are typically multi-tenant; usually they share resources between clients for efficiency, but sometimes they offer a siloed environment for an additional fee. Common SaaS revenue models include freemium, subscription, and usage-based fees. Unlike traditional software, it is rarely possible to buy a perpetual license for a certain version of the software.

There are no specific software development practices that distinguish SaaS from other application development, although there is often a focus on frequent testing and releases.

Cloud computing

Script error: No such module "Labelled list hatnote".

File:Comparison of on-premise, IaaS, PaaS, and SaaS.png
Comparison of on-premise, IaaS, PaaS, and SaaS

Infrastructure as a service (IaaS) is the most basic form of cloud computing, where infrastructure resources—such as physical computers—are not owned by the user but instead leased from a cloud provider. As a result, infrastructure resources can be increased rapidly, instead of waiting weeks for computers to ship and set up. IaaS requires time and expertise to make use of the infrastructure in the form of operating systems and applications.Template:Sfn Platform as a service (PaaS) includes the operating system and middleware, but not the applications.Template:SfnTemplate:Sfn SaaS providers typically use PaaS or IaaS services to run their applications.Template:Sfn

Without IaaS, it would be extremely difficult to make an SaaS product scalable for a variable number of users while providing the instant and continual availability that customers expect.Template:Sfn Most end users consume only the SaaS product and do not have to worry about the technical complexity of the physical hardware and operating system.Template:Sfn Because cloud resources can be accessed without any human interactions, SaaS customers are provided with the abstraction of limitless computing resources, while economy of scale drives down the cost.Template:Sfn Another key feature of cloud computing is that software updates can be rolled out and made available to all customers nearly instantaneously.Template:Sfn In 2019, SaaS was estimated to make up the plurality, 43 percent, of the cloud computing market while IaaS and PaaS combined account for approximately 25 percent.Template:Sfn

History

In the 1960s, multitasking was invented, enabling mainframe computers to serve multiple users simultaneously. Over the next decade, timesharing became the main business model for computing, and cluster computing enabled multiple computers to work together.Template:Sfn Cloud computing emerged in the late 1990s with companies like Amazon (1994), Salesforce (1999), and Concur (1993) offering Internet-based applications on a pay-per-use basis. All of these focused on a single product to seize a high market share.Template:Sfn Beginning with Gmail in 2004, email services were some of the first SaaS products to be mass-marketed to consumers.Template:Sfn The market for SaaS grew rapidly throughout the early twenty-first century.Template:SfnTemplate:Sfn Initially viewed as a technological innovation, SaaS has come to be perceived more as a business model.Template:Sfn By 2023, SaaS had become the primary method that companies deliver applications.Template:Sfn

Popular consumer SaaS products include all social media websites, email services like Gmail and its associated Google Docs Editors,Template:Sfn Skype, Dropbox,Template:Sfn and entertainment products like Netflix and Spotify.Template:Sfn Enterprise SaaS products include Salesforce's customer relationship management (CRM) software, SAP Cloud Platform, and Oracle Cloud Enterprise Resource Planning.Template:Sfn

Revenue models

Some SaaS providers offer free services to consumers that are funded by means such as advertising, affiliate marketing, or selling consumer data.Template:Sfn One of the most popular models for Internet start-ups and mobile apps is freemium, where the company charges for continued use or a higher level of service. Even if the user never upgrades to the paid version, it helps the company capture a higher market share and displace customers from a rival.Template:Sfn However, the company's hosting cost increases with the number of users, regardless of whether it is successful at enticing them to use the paid version.Template:Sfn Another common model is where the free version only provides demonstration (crippleware). Online marketplaces may charge a fee on transactions to cover the SaaS provider costs.Template:Sfn It used to be more common for SaaS products to be offered for a one-time cost, but this model is declining in popularity.Template:Sfn A fewTemplate:Sfn SaaS products have open source code, called open SaaS. This model can provide advantages such as reduced deployment cost, less vendor commitment, and more portable applications.Template:Sfn

The most common SaaS revenue models involve subscription and pay for usage.Template:Sfn For customers, the advantages include reduced upfront cost, increased flexibility, and lower overall cost compared to traditional software with perpetual software licenses.Template:Sfn In some cases, the steep one-time cost demanded by sellers of traditional software were out of the reach of smaller businesses, but pay-per-use SaaS models makes the software affordable.Template:Sfn Usage may be charged based on the number of users, transactions, amount of storage spaced used, or other metrics.Template:Sfn Many buyers prefer pay-per-usage because they believe that they are relatively light users of the software, and the seller benefits by reaching occasional users who would otherwise not buy the software.Template:Sfn However, it can cause revenue uncertainty for the seller and increases the overhead for billing.Template:Sfn

The subscription model of SaaS offers a continuing and renewable revenue stream to the provider, although vulnerable to cancellation.Template:Sfn If a significant number are cancelled, the viability of the business can be placed in jeopardy.Template:Sfn The ease of canceling a subscription and switching to a competitor leave customers with the leverage to get concessions from the seller.Template:Sfn While recurring revenues can help the business and attract investors, the need for customer service skills in convincing the customer to renew their subscription is a challenge for providers switching to subscription from other revenue models.Template:Sfn

Adoption

SaaS products are typically accessed via a web browser as a publicly available web application.Template:SfnTemplate:Sfn This means that customers can access the application anywhere from any device without needing to install or update it.Template:SfnTemplate:Sfn SaaS providers often try to minimize the difficulty of signing up for the product.Template:Sfn Many capitalize on the service-oriented structure to respond to customer feedback and evolve their product quickly to meet demands. This can enable customers to believe in the continued improvement of the product and help the SaaS provider get customers from an established traditional software company that likely can offer a deeper feature set.Template:SfnTemplate:Sfn

Although on-premises software is often less secure than SaaS alternatives,Template:Sfn security and privacy are among the main reasons cited by companies that do not adopt SaaS products.Template:Sfn SaaS companies have to protect their publicly available offerings from abuse, including denial-of-service attacks and hacking.Template:Sfn They often use technologies such as access control, authentication, and encryption to protect data confidentiality.Template:Sfn Nevertheless, not all companies trust SaaS providers to keep sensitive data secured.Template:Sfn The vendor is responsible for software updates, including security patches, and for protecting the customers' data.Template:Sfn SaaS systems inherently have a greater latency than software run on-premises due to the time for network packets to be delivered to the cloud facility. This can be prohibitive for some uses, such as time-sensitive industrial processes or warehousing.Template:Sfn

The rise of SaaS products is one factor leading many companies switched from budgeting for IT as a capital expenditure to an operating expenditure.Template:Sfn The process of migration to SaaS and supporting it can also be a significant cost that must be accounted for.Template:SfnTemplate:Sfn

Development

File:SaaS architecture.jpg
A SaaS architecture. All customers are running the same version of the software on the same platform.Template:Sfn

A challenge for SaaS providers is that demand is not known in advance. Their system must have enough slack to be able to handle all users without turning any away, but without paying for too many resources that will be unnecessary. If resources are static, they are guaranteed to be wasted during non-peak time.Template:Sfn Sometimes cheaper off-peak rates are offered to balance the load and reduce waste.Template:Sfn The expectation for continuous service is so high that outages in SaaS software are often reported in the news.Template:Sfn

There are not specific software development practices that differentiate SaaS from other application development.Template:Sfn SaaS products are often released early and often to take advantage of the flexibility of the SaaS delivery model.Template:Sfn Agile software development is commonly used to support this release schedule.Template:Sfn Many SaaS developers use test-driven development, or otherwise emphasize frequent software testing, because of the need to ensure availability of their service and rapid deployment.Template:Sfn Domain-driven design, in which business goals drive development, is popular because SaaS products must sell themselves to the customer by being useful.Template:Sfn SaaS developers do not know in advance which devices customers will try to access the product from—such as a desktop computer, tablet, or smartphone—and supporting a wide range of devices is often an important concern for the front-end development team.Template:Sfn Progressive web applications allow some functionality to be available even if the device is offline.Template:Sfn

SaaS applications predominantly offer integration protocols and application programming interfaces (APIs) that operate over a wide area network.Template:Sfn

Architecture

SaaS architecture varies significantly from product to product.Template:Sfn Nevertheless, most SaaS providers offer a multi-tenant architecture.Template:Sfn With this model, a single version of the application, with a single configuration (hardware, network, operating system), is used for all customers ("tenants").Template:Sfn This means that the company does not need to support multiple versions and configurations.Template:Sfn The architectural shift from each customer running their own version of the software on their own hardware affects many aspects of the application's design and security features.Template:Sfn In a multi-tenant architecture, many resources can be used by different tenants or shared between multiple tenants.Template:Sfn

File:Application and control planes of a SaaS product.png
Application and control planes of a SaaS product

The structure of a typical SaaS application can be separated into application and control planes.Template:Sfn SaaS products differ in how these planes are separated, which might be closely integrated or loosely coupled in an event- or message-driven model.Template:Sfn The control plane is in charge of directing the system and covers functionality such as tenant onboarding, billing, and metrics, as well as the system used by the SaaS provider to configure, manage, and operate the service.Template:Sfn Many SaaS products are offered at different levels of service for different prices, called tiering. This can also affect the architecture for both planes, although it is commonly placed in the control plane.Template:Sfn Unlike the application plane, the services in the control plane are not designed for multitenancy.Template:Sfn

File:Tenant routing for SaaS example.png
An example architecture where some services are shared, while others are allocated on a per-tenant basisTemplate:Sfn

The application plane—which varies a great deal depending on the nature of the product—implements the core functionality of the SaaS product.Template:Sfn Key design issues include separating different tenants so they cannot view or change other tenants' data or resources.Template:Sfn Except for the simplest SaaS applications, some microservices and other resources are allocated on a per-tenant basis, rather than shared between all tenants.Template:Sfn Routing functionality is necessary to direct tenant requests to the appropriate services.Template:Sfn

File:Example SaaS deployment architecture.png
Example SaaS deployment architecture that offers complete siloing on a premium tier and mixed microservice deployment to other tenantsTemplate:Sfn

Some SaaS products do not share any resources between tenants—called siloing. Although this negates many of the efficiency benefits of SaaS, it makes it easier to migrate legacy software to SaaSTemplate:Sfn and is sometimes offered as a premium offering at a higher price.Template:Sfn Pooling all resources might make it possible to achieve higher efficiency,Template:Sfn but an outage affects all customers so availability must be prioritized to a greater extent.Template:Sfn Many systems use a combination of both approaches, pooling some resources and siloing others.Template:Sfn Other companies group multiple tenants into pods and share resources between them.Template:Sfn

Legal issues

In the United States, constitutional search warrant laws do not protect all forms of SaaS dynamically stored data. The result is that governments may be able to request data from SaaS providers without the owner's consent.[2][3]

Certain open-source licenses such as GPL-2.0 do not explicitly grant rights permitting distribution as a SaaS product in Germany.Template:Sfn

References

Template:Reflist

Sources

Template:Refbegin

  • Script error: No such module "Citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
    • Script error: No such module "citation/CS1".
    • Script error: No such module "citation/CS1".
    • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "Citation/CS1".

Template:Refend

Further reading

  • Script error: No such module "citation/CS1".

Script error: No such module "Navbox". Template:Cloud computing

  1. Script error: No such module "citation/CS1".
  2. Script error: No such module "citation/CS1".
  3. Script error: No such module "citation/CS1".