Q1. What is cloud computing? Explain cloud computing reference model.
Q2. What are characteristics of cloud computing ?
Q3. Write pros and cons of cloud computing,
Q4. Write a note on historical developments of cloud computing.
Q5. Write a note on cloud computing services.
Q6. Write a note on virtualization and hypervisor.
Q7. Write difference between parallel computing and distributed computing.
Q8. Explain some cloud computing platforms and technologies
1. Cloud computing
Definition:
The cloud is a large group of interconnected computers. These computers can be personal computers
or network servers; they can be public or private.
Cloud computing is a technology that uses the internet and central remote servers to maintain data
and applications.
Eg: Yahoo email or Gmail etc
THE CLOUD COMPUTING REFERENCE MODEL
Fig 1: The Cloud Computing Reference Model
Fig 1 defines five major actors:
1. Cloud consumer
2. Cloud provider
3. Cloud carrier
4. Cloud auditor and
5. Cloud broker.
2.
CHARACTERISTICS OF CLOUD COMPUTING
1. Cloud computing is user-centric.
Once users are connected to the cloud, whatever is available (stored) in cloud as documents,
messages, images, applications, it becomes users own.
Users can also share it with others.
2. Cloud computing is task-centric.
It focusing on the application for users on what users need to done and how the application can do it
for users. Eg collage, Animation, Movie in Google Photos
3. Cloud computing is powerful.
Connecting hundreds or thousands of computers together in a cloud creates a wealth of computing
power impossible with a single desktop PC.
4. Cloud computing is accessible.
Data is stored in the cloud; users can instantly retrieve more information from multiple repositories.
You’re not limited to a single source of data.
5. Cloud computing is intelligent.
With all the various data stored on the computers in a cloud, data mining and analysis are necessary
to access that information in an intelligent manner.
6. Cloud computing is programmable.
Many of the tasks necessary with cloud computing must be automated.
For example, cloud must be replicated on other computers in the cloud. If that one computer goes
offline, the cloud’s programming automatically redistributes that computer’s data to a new computer
in the cloud.
Examples of cloud computing applications: Google Docs & Spreadsheets, Google Calendar, Gmail,
Picasa.
3.
PROS AND CONS OF CLOUD COMPUTING
Advantages
• Lower-Cost Computers for Users
• Improved Performance
• Lower IT Infrastructure Costs
• Fewer Maintenance Issues
• Lower Software Costs
• Instant Software Updates
• Increased Computing Power
• Unlimited Storage Capacity
• Increased Data Safety
• Improved Compatibility Between Operating Systems
• Improved Document Format Compatibility
• Easier Group Collaboration
• Universal Access to Documents
• Latest Version Availability
• Removes the Tether to Specific Devices
Dis-Advantages
● Requires a Constant Internet Connection
● Doesn’t Work Well with Low-Speed Connections
● Can Be Slow
● Features Might Be Limited
● Stored Data Might Not Be Secure
● Problem will arise If Data loss occurs
4.
HISTORICAL DEVELOPMENTS
Client/Server Computing: Centralized Applications and Storage
In client/server model all the software applications, data, and the control resided on huge mainframe
computers, known as servers.
If a user wanted to access specific data or run a program, he had to connect to the mainframe, gain
appropriate access, and then do his business.
Users connected to the server via a computer terminal, called a workstation or client.
Drawbacks in client /server Model
Even on a mainframe computer, processing power is limited.
Access was not immediate nor could two users access the same data at the same time.
When multiple people are sharing a single computer, you have to wait for your turn.
There isn’t always immediate access in a client/server environment.
So the client/server model, while providing similar centralized storage, differed from cloud
computing in that it did not have a user-centric focus. It was not a user-enabling environment.
Peer-to-Peer Computing: Sharing Resources
P2P computing defines a network architecture in which each computer has equivalent capabilities
and responsibilities.
In the P2P environment, every computer is a client and a server; there are no masters and slaves.
P2P enables direct exchange of resources and services.
There is no need for a central server, because any computer can function in that capacity when called
on to do so.
P2P was a decentralizing concept. Control is decentralized, with all computers functioning as equals.
Content is also dispersed among the various peer computers.
Distributed Computing: Providing More Computing Power
One of the subsets of the P2P model.
distributed computing, where idle PCs across a network or Internet are tapped to provide computing
power for large, processor-intensive projects.
Collaborative Computing: Working as a Group
Multiple users to work simultaneously on the same computer-based project called collaborative
computing.
The goal was to enable multiple users to collaborate on group projects online, in real time.
To collaborate on any project, users must first be able to talk to one another.
Most collaboration systems offer the complete range of audio/video options, for full-featured
multiple-user video conferencing.
In addition, users must be able to share files and have multiple users work on the same document
simultaneously.
Real-time white boarding is also common, especially in corporate and education environments.
Cloud Computing: The Next Step in Collaboration
With the growth of the Internet, there was no need to limit group collaboration to a single
enterprise’s network environment.
Users from multiple locations within a corporation, and from multiple organizations, desired to
collaborate on projects that crossed company and geographic boundaries.
To do this, projects had to be housed in the “cloud” of the Internet, and accessed from any
Internet-enabled location.
5.
Cloud Computing Services
The three major Cloud Computing Offerings are
● Software as a Service (SaaS)
● Platform as a Service (PaaS)
● Infrastructure as a Service (IaaS)
SaaS (Software as a Service)
SaaS or software as a service is a software distribution model in which applications are hosted by a
vendor or service provider and made available to customers over a network (internet).
PaaS (Platform as a Service)
Platform as a service, is referred as PaaS, it provides a platform and environment to allow developers
to build applications and services.
This service is hosted in the cloud and accessed by the users via internet.
IaaS (Infrastructure as a Service)
IaaS (Infrastructure As A Service) is one of the fundamental service model of cloud computing
alongside PaaS( Platform as a Service).
It provides access to computing resources in a virtualized environment “the cloud” on internet.
It provides computing infrastructure like virtual server space, network connections, bandwidth, load
balancers and IP addresses.
The pool of hardware resource is extracted from multiple servers and networks usually distributed
across numerous data centers.
6.
VIRTUALIZATION
Virtualization is a technique, which allows to share single physical instance of an application or
resource among multiple organizations or tenants (customers).
Creating a virtual machine over existing operating system and hardware is referred as Hardware
Virtualization. Virtual Machines provide an environment that is logically separated from the
underlying hardware.
The machine on which the virtual machine is created is known as host machine and virtual machine
is referred as a guest machine. This virtual machine is managed by a software or firmware, which is
known as hypervisor.
Hypervisor
The hypervisor is a firmware or low-level program that acts as a Virtual Machine Manager.
There are two types of hypervisor:
Type 1 hypervisor executes on bare system.
Eg LynxSecure, RTS Hypervisor, Oracle VM, Sun xVM Server, VirtualLogic VLX.
The type1 hypervisor does not have any host operating system because they are installed on a bare
system.
Type 2 hypervisor is a software interface that emulates the devices with which a system normally
interacts.
Eg Containers, KVM, Microsoft Hyper V, VMWare Fusion, Virtual Server 2005 R2, Windows Virtual
PC and VMWare workstation 6.0.
7.
Difference between Parallel Computing and Distributed Computing
Parallel Computing:
In parallel computing multiple processors performs multiple tasks assigned to them simultaneously.
Memory in parallel systems can either be shared or distributed.
Parallel computing provides concurrency and saves time and money.
Distributed Computing:
In distributed computing we have multiple autonomous computers which seem to the user as a single
system.
In distributed systems there is no shared memory and computers communicate with each other
through message passing.
In distributed computing a single task is divided among different computers.
Table 3: Difference between Parallel Computing and Distributed Computing
 S.NO                    PARALLEL                DISTRIBUTED
                         COMPUTING               COMPUTING
 1                       Many operations are     System components
                         performed               are located at
                         simultaneously          different locations
 2                       Single computer is      Uses multiple
                         required                computers
 3                       Multiple processors     Multiple computers
                         perform multiple        perform multiple
                         operations              operations
 4                       It may have shared or   It have only
                         distributed memory      distributed memory
 5                       Processors              Computers
                         communicate with        communicate with
                         each other through      each other through
                         bus                     message passing.
 6                       Improves the system     Improves system
                         performance             scalability, fault
                                                 tolerance and
                                                 resource sharing
                                                 capabilities
8.
CLOUD COMPUTING PLATFORMS AND TECHNOLOGIES
Amazon Web Services (AWS) –
● AWS provides different wide-ranging clouds IaaS services, which ranges from virtual compute,
storage, and networking to complete computing stacks.
● AWS is well known for its storage and compute on demand services, named as Elastic Compute
Cloud (EC2) and Simple Storage Service (S3).
● EC2 offers customizable virtual hardware to the end user which can be utilized as the base
infrastructure for deploying computing systems on the cloud.
● S3 is well ordered into buckets which contain objects that are stored in binary form and can be
grown with attributes. End users can store objects of any size, from basic file to full disk images and
have them retrieval from anywhere.
● In addition, EC2 and S3, a wide range of services can be leveraged to build virtual computing
systems including: networking support, caching system, DNS, database support, and others.
Google AppEngine
● Google AppEngine is a scalable runtime environment frequently dedicated to executing web
applications.
● These utilize the benefits of the large computing infrastructure of Google to dynamically scale as
per the demand.
● AppEngine offers both a secure execution environment and a collection of which simplifies the
development of scalable and high-performance Web applications.
● These services include: in-memory caching, scalable data store, job queues, messaging, and corn
tasks.
● Currently, the supported programming languages are Python, Java, and Go.
Microsoft Azure–
● Microsoft Azure is a Cloud operating system and a platform in which users can develop the
applications in the cloud.
● Azure provides a set of services that support storage, networking, caching, content delivery, and
others.
Hadoop
● Apache Hadoop is an open source framework that is appropriate for processing large data sets on
commodity hardware.
● Hadoop is an implementation of MapReduce, an application programming model which is
developed by Google.
● This model provides two fundamental operations for data processing: map and reduce.