Cloud Computing
Cloud Computing
Cloud computing is a general term for anything that involves delivering hosted services over the
internet. Cloud computing is an abstraction of compute, storage, and network infrastructure
assembled as a platform on which applications and systems can be deployed quickly and scaled
on the fly. Crucial to cloud computing is self-service: Users can simply fill in a web form and get
up and running.
Cloud infrastructure involves the hardware and software components required for proper
implementation of a cloud computing model. Cloud computing can also be thought of as utility
computing or on-demand computing. The name cloud computing was inspired by the cloud
symbol that's often used to represent the internet in flowcharts and diagrams.
The goal of cloud computing is to allow users to take benefit from all of these technologies,
without the need for deep knowledge about or expertise with each one of them. The cloud aims
to cut costs and helps the users focus on their core business instead of being impeded by IT
obstacles. The main enabling technology for cloud computing is virtualization. Virtualization
software separates a physical computing device into one or more "virtual" devices, each of which
can be easily used and managed to perform computing tasks.
The history and evolution of cloud computing date back to the 1950s and 1960s.
In the 1950s, companies started to use large mainframe computers, but it was too expensive to
buy a computer for each user. So, during the late 1950s and early 1960s, a process called time
sharing was developed to make more efficient use of expensive processor time on the central
mainframe.
The origins of delivering computing resources using a global network are, for the most part,
rooted in 1969 when American computer scientist J.C.R. Licklider helped create the Advanced
Research Projects Agency Network, the so-called precursor to the internet. Licklider's goal was
to connect computers across the globe in a way that would enable users to access programs and
information from any location.
In the 1970s, cloud computing began taking a more tangible shape with the introduction of the
first VMs, enabling users to run more than one computing system within a single physical setup.
The functionality of these VMs led to the concept of virtualization, which had a major influence
on the progress of cloud computing.
In the 1970s and 1980s, Microsoft, Apple and IBM developed technologies that enhanced the
cloud environment and advanced the use of the cloud server and server hosting. Then, in 1999,
Salesforce became the first company to deliver business applications from a website.
In 2006, Amazon launched AWS, providing such services as computing and storage in the cloud.
Following suit, the other major tech players, including Microsoft and Google, subsequently
launched their own cloud offerings to compete with AWS.
How does cloud computing work?
Cloud computing works by enabling client devices to access data and cloud applications over the
internet from remote physical servers, databases and computers.
An internet network connection links the front end, which includes the accessing client device,
browser, network and cloud software applications, with the back end, which consists of
databases, servers and computers. The back end functions as a repository, storing data that is
accessed by the front end.
Front-end- The front-end constituent of cloud computing is visible to the users or the clients of
the cloud. For instance, the display page of a website is visible to the users who visit the website,
and perhaps it is the front-end of the cloud.
 
Backend- The back-end constituent of the server is what goes behind the curtains and is visible
to the operators or those who design the remote server. Unlike the front-end of the cloud, the
backend is not visible to the users or the clients of a cloud. 
The backend of the cloud refers to the group of computers, data, and other servers that together
work in order to give way to a remote cloud or a virtual space. For instance, the coding language,
the interconnected links, and other technical constituents form the backend of a website. The
working of cloud computing architecture can be understood through the lens of its two
constituents- front end and back end technologies. In a cloud computing network, various
elements together work to make way for a cloud that is visible to the client. 
Instead of working the traditional way, companies prefer to keep everything protected with
online servers that makes their work hassle-free and less complicated.
The database storage is the reservoir of information or content that gets published on the
front-end. The information contributed to the database storage comes from various computer
networks and application servers that together build the backend. All these elements- database
storage, application servers, computer networks are connected to a control node that is the
connecting link between the front-end and backend. 
Communications between the front and back ends are managed by a central server. The central
server relies on protocols to facilitate the exchange of data. The central server uses both software
and middleware to manage connectivity between different client devices and cloud servers.
Typically, there is a dedicated server for each individual application or workload.
Cloud computing relies heavily on virtualization and automation technologies. Virtualization
enables the easy abstraction and provisioning of services and underlying cloud systems into
logical    entities    that    users     can     request   and     utilize.   Automation      and
accompanying orchestration capabilities provide users with a high degree of self-service to
provision resources, connect services and deploy workloads without direct intervention from the
cloud provider's IT staff.
Cloud computing can be separated into three general service delivery categories or forms of
cloud computing:
1. IaaS. IaaS providers, such as Amazon Web Services (AWS), supply a virtual server instance
    and storage, as well as application programming interfaces (APIs) that let users migrate
    workloads to a virtual machine (VM). Users have an allocated storage capacity and can start,
    stop, access and configure the VM and storage as desired. IaaS providers offer small,
    medium, large, extra-large, and memory- or compute-optimized instances, in addition to
    enabling customization of instances, for various workload needs. The IaaS cloud model is
    closest to a remote data center for business users.
2. PaaS. In the PaaS model, cloud providers host development tools on their infrastructures.
    Users access these tools over the internet using APIs, web portals or gateway software. PaaS
    is used for general software development, and many PaaS providers host the software after
    it's developed. Common PaaS products include Salesforce's Lightning Platform, AWS Elastic
    Beanstalk and Google App Engine.
3. SaaS. SaaS is a distribution model that delivers software applications over the internet; these
    applications are often called web services. Users can access SaaS applications and services
    from any location using a computer or mobile device that has internet access. In the SaaS
    model, users gain access to application software and databases. One common example of a
    SaaS application is Microsoft 365 for productivity and email services.
In the public cloud model, a third-party cloud service provider (CSP) delivers the cloud service
over the internet. Public cloud services are sold on demand, typically by the minute or hour,
though long-term commitments are available for many services. Customers only pay for the
central processing unit cycles, storage or bandwidth they consume. Leading public CSPs include
AWS, Microsoft Azure, IBM and Google Cloud Platform (GCP), as well as IBM, Oracle and
Tencent.
A hybrid cloud is a combination of public cloud services and an on-premises private cloud, with
orchestration and automation between the two. Companies can run mission-critical workloads or
sensitive applications on the private cloud and use the public cloud to handle workload bursts or
spikes in demand. The goal of a hybrid cloud is to create a unified, automated, scalable
environment that takes advantage of all that a public cloud infrastructure can provide, while still
maintaining control over mission-critical data.
Cloud computing has been around for several decades now, and today's cloud computing
infrastructure demonstrates an array of characteristics that have brought meaningful benefits for
businesses of all sizes. Some of the main characteristics of cloud computing are the following:
● Self-service provisioning. End users can spin up compute resources for almost any type of
   workload on demand. An end user can provision computing capabilities, such as server time
   and network storage, eliminating the traditional need for IT administrators to provision and
   manage compute resources.
● Elasticity. Companies can freely scale up as computing needs increase and scale down again
   as demands decrease. This eliminates the need for massive investments in local
   infrastructure, which might or might not remain active.
● Pay per use. Compute resources are measured at a granular level, enabling users to pay only
   for the resources and workloads they use.
These characteristics support a variety of important benefits for modern business, including the
following:
● Data and workload mobility. Storing information in the cloud means that users can access
   it from anywhere with any device with just an internet connection. That means users don't
   have to carry around USB drives, an external hard drive or multiple CDs to access their data.
   Users can access corporate data via smartphones and other mobile devices, enabling remote
   employees to stay up to date with co-workers and customers. End users can easily process,
   store, retrieve and recover resources in the cloud. In addition, cloud vendors provide all the
   upgrades and updates automatically, saving time and effort.
● Business continuity and disaster recovery (BCDR). All organizations worry about data
   loss. Storing data in the cloud guarantees that users can always access their data even if their
   devices, e.g., laptops or smartphones, are inoperable. With cloud-based services,
   organizations can quickly recover their data in the event of emergencies, such as natural
   disasters or power outages. This benefits BCDR and helps ensure that workloads and data are
   available even if the business suffers damage or disruption.
Regardless of the kind of service, cloud computing services provide users with a series of
functions including:
   ● Email
   ● Storage, backup, and data retrieval
   ● Creating and testing apps
   ● Analyzing data
   ● Audio and video streaming
   ● Delivering software on demand
Cloud computing is still a fairly new service but is being used by a number of different
organizations from big corporations to small businesses, nonprofits to government agencies, and
even individual consumers.
When it comes to providing services, the big players in the corporate computing sphere include:
   ● Google Cloud
   ● Amazon Web Services (AWS)
   ● Microsoft Azure
    ● IBM Cloud
    ● Alibaba Cloud
Amazon Web Services is 100% public and includes a pay-as-you-go, outsourced model. Once
you’re on the platform you can sign up for apps and additional services. Microsoft Azure allows
clients to keep some data at their own sites. Meanwhile, Alibaba Cloud is a subsidiary of the
Alibaba Group.
    2. Flexible Functioning
      Another benefit of cloud computing is its flexible functioning. While it can be a tiresome
      task for a company to hire a distinct team for managing IT affairs, cloud computing
      agencies offer the same services. Perhaps it becomes flexible for the company to extend its
      IT operations to cloud computing agencies that can work on updates, elimination of errors,
      etc. in no time. 
 
    3. Rapid Remote Management
      There is no doubt that cloud computing is rapid in terms of speed. Rapid remote
      management is one of the many benefits of cloud computing that enables a company and
      its employees to conduct IT affairs in a remote environment but with much rapidity. 
 
    4. All-around Connectivity
      The global pandemic has driven everyone to their homes where work has to be managed
      from houses. While offices remain shut down, it is important for the employees to access
      data that is available at their doorstep. 
       
      Cloud computing has made that utterly easier for the whole world as it continues to
      provide all-around connectivity. Perhaps one can access data from any spot in the world
      and still be able to work efficiently. Thanks to cloud computing, all-round connectivity is
      no more an issue, unlike traditional servers that required employees to be in the offices all
      year round. 
 
    5. Secure services
      Last but not least, cloud computing is secure and reliable. How? Well, the cloud computing
      agencies that a company hires are under the lens of IT laws and are required to comply
      with numerous laws and rules established for proper functioning. 
      Moreover, these services are secure as data is restored on the backend, getting it backed up
      every single time a user accesses it. This makes cloud computing more secure than
      personal server set-ups. 
Despite the clear upsides to relying on cloud services, cloud computing carries its own
challenges for IT professionals:
● Cloud security. Security is often considered the greatest challenge facing cloud computing.
   When relying on the cloud, organizations risk data breaches, hacking of APIs and interfaces,
   compromised credentials and authentication issues. Furthermore, there is a lack of
   transparency regarding how and where sensitive information entrusted to the cloud provider
   is handled. Security demands careful attention to cloud configurations and business policy
   and practice.
● Cost unpredictability. Pay-as-you-go subscription plans for cloud use, along with scaling
   resources to accommodate fluctuating workload demands, can make it tough to define and
   predict final costs. Cloud costs are also frequently interdependent, with one cloud service
   often utilizing one or more other cloud services -- all of which appear in the recurring
   monthly bill. This can create additional unplanned cloud costs.
● Compliance with industry laws. When transferring data from on-premises local storage into
   cloud storage, it can be difficult to manage compliance with industry regulations through a
   third party. It's important to know where data and workloads are actually hosted in order to
   maintain regulatory compliance and proper business governance.
● Vendor lock-in.  Switching between cloud providers can cause significant issues. This
    includes technical incompatibilities, legal and regulatory limitations and substantial costs
    incurred from sizable data migrations.
Cloud computing has evolved and diversified into a wide array of offerings and capabilities
designed to suit almost any conceivable business need. Examples of cloud computing
capabilities and diversity include the following:
● Google Docs, Microsoft 365. Users can access Google Docs and Microsoft 365 through the
    internet. Users can be more productive because they can access work presentations and
    spreadsheets stored in the cloud at anytime from anywhere on any device.
● Zoom. Zoom is a cloud-based software platform for video and audio conferencing that
    records meetings and saves them to the cloud, enabling users to access them anywhere and at
    any time. Another common communication and collaboration platform is Microsoft Teams.
● AWS Lambda. Lambda enables developers to run code for applications or back-end services
    without having to provision or manage servers. The pay-as-you-go model constantly scales
    with an organization to accommodate real-time changes in data usage and data storage. Other
   major cloud providers also support serverless computing capabilities, such as Google Cloud
   Functions and Azure Functions.
The myriad services and capabilities found in modern public clouds have been applied across
countless use cases, such as the following:
● Production workload hosting. Organizations are using the public cloud to host live
   production workloads. This requires careful design and architecture of cloud resources and
   services needed to create an adequate operational environment for the workload and its
   required level of resilience.
● Big data analytics. Remote data centers through cloud storage are flexible and scalable and
   can provide valuable data-driven insights. Major cloud providers offer services tailored to
   big data projects, such as Amazon EMR and Google Cloud Dataproc.
● IaaS. IaaS enables companies to host IT infrastructures and access compute, storage and
   network capabilities in a scalable manner. Pay-as-you-go subscription models can help
   companies save on upfront IT costs.
● PaaS. PaaS can help companies develop, run and manage applications in an easier and more
   flexible way, at a lower cost than maintaining a platform on premises. PaaS services can also
   increase development speed for applications and enables higher-level programming.
● Hybrid cloud. Organizations have the option to use the appropriate cloud -- private or public
   -- for different workloads and applications to optimize cost and efficiency according to the
   circumstance.
● Multi-cloud. Using multiple different cloud services from separate cloud providers can help
   subscribers find the best cloud service fit for diverse workloads with specific requirements.
● Storage. Large amounts of data can be stored remotely and accessed easily. Clients only
   have to pay for storage that they actually use.
● DR. Cloud offers faster recovery than traditional on-premises DR. Furthermore, it is offered
    at lower costs.
● Data backup. Cloud backup solutions are generally easier to use. Users do not have to worry
    about availability and capacity, and the cloud provider manages data security.
Given the many different services and capabilities of the public cloud, there has been some
confusion between cloud computing and major uses, such as web hosting. While the public cloud
is often used for web hosting, the two are quite different. A cloud service has three distinct
characteristics that differentiate it from traditional web hosting:
1. Users can access large amounts of computing power on demand. It is typically sold by the
    minute or the hour.
2. It is elastic -- users can have as much or as little of a service as they want at any given time.
3. The service is fully managed by the provider -- the consumer needs nothing but a personal
    computer and internet access. Significant innovations in virtualization and distributed
    computing, as well as improved access to high-speed internet, have accelerated interest in
    cloud computing.
   ● Lower IT costs: Cloud lets you offload some or most of the costs and effort of
       purchasing, installing, configuring, and managing your own on-premises infrastructure. 
   ● Improve agility and time-to-value: With cloud, your organization can start using
       enterprise applications in minutes, instead of waiting weeks or months for IT to respond
       to a request, purchase and configure supporting hardware, and install software. Cloud
       also lets you empower certain users—specifically developers and data scientists—to help
       themselves to software and support infrastructure.
   ● Scale more easily and cost-effectively: Cloud provides elasticity—instead of purchasing
       excess capacity that sits unused during slow periods, you can scale capacity up and down
       in response to spikes and dips in traffic. You can also take advantage of your cloud
       provider’s global network to spread your applications closer to users around the world.
The cloud service market has no shortage of providers. The three largest public CSPs that have
established themselves as dominant fixtures in the industry are the following:
1. AWS
2. GCP
3. Microsoft Azure
1. Apple
2. Citrix
3. IBM
4. Salesforce
5. Alibaba
6. Oracle
7. VMware
8. SAP
9. Joyent
10. Rackspace
When considering a cloud service vendor, certain considerations should be taken. First, the
actual suite of services can vary between providers, and business users must select a provider
that offers services -- such as big data analytics or artificial intelligence (AI) services -- that
support the intended use case.
Though cloud services typically rely on a pay-per-use model, different providers often have
variations in their pricing plans to consider. Furthermore, if the cloud provider will be storing
sensitive data, physical location of the provider's servers should also be considered.
Security remains a primary concern for businesses contemplating cloud adoption -- especially
public cloud adoption. Public CSPs share their underlying hardware infrastructure between
numerous customers, as the public cloud is a multi-tenant environment. This environment
demands significant isolation between logical compute resources. At the same time, access to
public cloud storage and compute resources is guarded by account login credentials.
Many organizations bound by complex regulatory obligations and governance standards are still
hesitant to place data or workloads in the public cloud for fear of outages, loss or theft. However,
this resistance is fading, as logical isolation has proven reliable and the addition of
data encryption and various identity and access management tools have improved security within
the public cloud.
Ultimately, the responsibility for establishing and maintaining a secure cloud environment falls
to the individual business user that is responsible for building the workload's architecture -- the
combination of cloud resources and services in which the workload runs -- and implementing the
security features that the cloud provider offers.
Over 30% of enterprise IT decision-makers identified public cloud as their top priority in 2019,
according to the "RightScale 2019 State of the Cloud Report." Still, enterprise adoption of the
public cloud, especially for mission-critical applications, hasn't been happening as quickly as
many experts predicted.
Today, however, organizations are more likely to migrate mission-critical workloads to public
clouds. One of the reasons for this shift is that business executives who want to ensure that their
companies can compete in the new world of digital transformation are demanding the public
cloud.
Business leaders are also looking to the public cloud to take advantage of its elasticity,
modernize internal computer systems, and empower critical business units and their DevOps
teams.
Additionally, cloud providers, such as IBM and VMware, are concentrating on meeting the needs
of enterprise IT, in part by removing the barriers to public cloud adoption that caused IT
decision-makers to shy away from fully embracing the public cloud previously.
Generally, when contemplating cloud adoption, many enterprises have been mainly focused on
new cloud-native applications -- that is, designing and building applications specifically intended
to use cloud services. They haven't been willing to move their most mission-critical apps into the
public cloud. However, these enterprises are now beginning to realize that the cloud is ready for
the enterprise if they select the right cloud platforms, i.e., those that have a history of serving the
needs of the enterprise.
Cloud providers are locked in ongoing competition for cloud market share, so the public cloud
continues to evolve, expand and diversify its range of services. This has led public IaaS
providers to offer far more than common compute and storage instances.
For example, serverless, or event-driven, computing is a cloud service that executes specific
functions, such as image processing and database updates. Traditional cloud deployments require
users to establish a compute instance and load code into that instance. Then, the user decides
how long to run -- and pay for -- that instance.
With serverless computing, developers simply create code, and the cloud provider loads and
executes that code in response to real-world events so users don't have to worry about the server
or instance aspect of the cloud deployment. Users only pay for the number of transactions that
the function executes. AWS Lambda, Google Cloud Functions and Azure Functions are
examples of serverless computing services.
Public cloud computing also lends itself well to big data processing, which demands enormous
compute resources for relatively short durations. Cloud providers have responded with big data
services, including Google BigQuery for large-scale data warehousing and Microsoft Azure Data
Lake Analytics for processing huge data sets.
Another crop of emerging cloud technologies and services relates to AI and machine learning.
These technologies provide a range of cloud-based, ready-to-use AI and machine learning
services for client needs. Amazon Machine Learning, Amazon Lex, Amazon Polly, Google
Cloud Machine Learning Engine and Google Cloud Speech API are examples of these services.
According to  NASSCOM Insight report,  an exponential growth in cloud investments across the
globe and in India:
   1. Global Public Cloud spend, currently valued at $332 bn as of 2021, is projected to grow
       by 20% YoY till 2022
   2. SaaS remains the largest global market segment at 39% share; PaaS, IaaS are expected to
       grow exponentially
   3. Investments in Cloud Management, Storage Networks, Security & Back-up services are
       expected to grow by 31% YoY till 2022; reflecting demand for Cloud-enabled
       infrastructural upgradations
   4. Hybrid Cloud adoption in Indian organizations is set to grow by 49% in the next 3 years
“The demand for digital skills today (including cloud) is around 8-10X higher than the supply
that exists in India. To make India the first cloud-nation, NASSCOM Insights has worked on the
report to understand the existing cloud talent landscape in India and the demand-supply analysis
by 2025. We could then realize the full potential of cloud and in the process, make India the
talent nation for the digital world,” says Debjani Ghosh, NASSCOM President.
   1. The Indian Government’s increasing cloud adoption through GI Cloud (MeghRaj), the
       National and State Service Delivery Gateways, development of a Cloud-based AI
       platform called AIRAWAT, TechSaksham and other initiatives enable ease, provide
       authentic access and transparency to government benefits for the common citizens
       because of cloud computing.
   2. The COVID cloud initiatives taken by the government like CoWin, Aarogya Setu,
       MyGov Saathi, Curfew ePass and COVID-19 Data Repository were some of the key
       steps through cloud that ensured that India is well-prepared to face the challenge posed
       by the COVID-19 pandemic.
With the growing interest and demand for cloud job roles, the number of job opportunities has
also seen a boost and is expected to grow tremendously which also increases the need of skilling
in cloud computing.  From a global perspective, what sets India apart from the other leading
countries, is its extensive, diverse pool of technology services talent which stands at over 4.5
mn as of FY2021, consisting of the traditional IT job roles of 2.4 to 2.6 mn, and the FutureSkills
talent of 1.9 to 2 mn. Consequently, by 2025, the unmet demand is expected to grow 3X by 2025;
demand for over 2.2 mn Cloud professionals versus an installed talent of 1.4 to 1.5 mn, as per
the report.
Cloud computing is that part of a business model that is taking the world by storm. Its ability to
allow organizations to maintain flexibility, scale, and focus their efforts on business
operations makes it very important for any business. It, not just changes the way so many
businesses store and access data but also change the way many of these businesses operate. Thus,
there is an immense future scope of cloud computing and job opportunities in 2022.
As the aftereffects of the pandemic, the migration toward remote work has created even more
demand for cloud services. In fact, Forrester Research expects the market of cloud computing
to grow 35 percent in 2022. Thus, it is one of the most in-demand skills in the IT sector. Cloud
computing, cloud migration, AWS/Azure, SAP, and machine learning/artificial intelligence are
among the top skills demanded by recruiters while hiring cloud professionals. It offers various
exciting career opportunities for IT professionals to enhance their expertise for growth.
Skills Required
In order to become a proficient cloud computing professional, it is advised for you to possess the
following skills and abilities-
    ● Programming skills
    ● Familiarity with databases
    ● Knowledge of virtualization
    ● Understanding of operating systems
    ● Networking skills
    ● Technical understanding
    ● Fundamental knowledge of security and privacy