Chapter 1 Notes
Chapter 1 Notes
Chapter 1 Notes
The term Cloud refers to a Network or Internet. In other words, we can say that Cloud is
something, which is present at remote location. Cloud can provide services over public and
private networks, i.e., WAN, LAN or VPN.
Cloud Computing is the use of hardware and software to deliver a service over a
network (typically the Internet). With cloud computing, users can access files and use
applications from any device that can access the Internet. An example of a Cloud
Computing provider is Google's Gmail. Instead of running an email program on your
computer, you log in to a web email account remotely. The software and storage for your
computer does not exist on your computer; it is on the services computer on the cloud.
The practice of using a network of remote servers hosted on the Internet to store,
manage, and process data, rather than a local server or a personal computer.
In cloud computing, the word "cloud" (also phrased as "the cloud") is used as a
metaphor for "the Internet," so the phrase cloud computing means a type of Internet
based computing, where different services including servers, storage and applications are
delivered to an organization's computers and devices.
With tremendous enhancement in technology all the leading companies and the
emerging ones are migrating towards cloud computing and are offering the best cloud
services to their customer. But there is a big question? What exactly the term cloud
computing mean, what is cloud storage and if I adopt this technology, then will there be any
benefits to my business….
Speaking forthrightly on cloud computing. In this blog, I am going to tell you about
cloud computing and its service. I know there is lots of confusion about this technology and
most of us are juggling these words like IOT, client-server, web app and web services. Then
what exactly this cloud computing means and what actually cloud computing services are?
Cloud computing is a broad term and we can’t define it in simple words. But according to the
NIST (National institute of Standards and Technology)
“Cloud computing is a model for enabling convenient, On-demand access to a
shared pool of configurable computing resources that can be rapidly
provisioned and released with minimal management efforts or services
provider interaction.”
Is this definition screwing your mind so let’s take a simple approach……? Before that, we
need to take a look on the characteristics, model and services of the technology to simplify
our concept.
Basically, cloud computing has some essential characteristics without which we cannot
approve its definition. They are: 1. On-demand self-service, 2. Broad network access, 3.
Resource pooling, 4. Rapid elasticity and 5. Measured Service
● Deployment Models
● Service Models
Deployment Models
Deployment models define the type of access to the cloud, i.e., how the cloud is located?
Cloud can have any of the four types of access: Public, Private, Hybrid, and Community.
PUBLIC CLOUD
The public cloud allows systems and services to be easily accessible to the general public.
Public cloud may be less secure because of its openness.
A public cloud is the most popular cloud among all the deployment models. Public cloud is
the best cloud computing services because it adopts the best resource management technique
and high availability and security. In this deployment model, the service provider creates
resource like application for the business, storage space for the business and general users.
Development environment for the developer and this model always try to minimize its
customer’s expenses and resource uses. Public cloud services are both paid services and free
to use.
Example: We all are using public cloud services in our day to day life, like using Google
drive is the most beautiful example of the public cloud. Also we use Google docs and Google
spread sheet is also the services of the public cloud.
Example :
1. Amazon AWS
2. Microsoft Azure
3. Google
4. Salesforce.com
5. Windows azure
6. Rackspace
7. Google compute engine
8. Qt cloud services
PRIVATE CLOUD
The private cloud allows systems and services to be accessible within an
organization. It is more secured because of its private nature.
Private cloud is a datacentre which is software defined. Which means you have that
much hardware capability which can drive your personal or your organization’s
requirements. It is generally in a virtual environment. Normally it delivers the same
advantage what the public cloud offers. Basically, a private cloud is giving services to the
single organization.
COMMUNITY CLOUD
The community cloud allows systems and services to be accessible by a group of
organizations.
A community cloud is a type of cloud computing services which serve its services to
multiple organizations which are mutually joined together. This organization has common
concerns just like uses, requirements and security issues. This type of cloud can be managed
by the same organization or by the third party. The benefits of this cloud are cost saving.
Instead of managing the service by the individual, they can manage it together with common
concern.
Example : Consider an organization are having 10 schools and they want to handle the data
of all these schools, so this organization will subscribe the community cloud services instead
of managing it individually, and they can do this task with minimum resource and less cost.
HYBRID CLOUD
The hybrid cloud is a mixture of public and private cloud, in which the critical
activities are performed using private cloud while the non-critical activities are performed
using public cloud.
Service Models
Cloud computing is based on service models. These are categorized into three basic
service models which are -
● Infrastructure-as–a-Service (IaaS)
● Platform-as-a-Service (PaaS)
● Software-as-a-Service (SaaS)
The Infrastructure-as-a-Service (IaaS) is the most basic level of service. Each of the
service models inherits the security and management mechanism from the underlying
model, as shown in the following diagram:
INFRASTRUCTURE-AS-A-SERVICE (IAAS)
IaaS provides access to fundamental resources such as physical machines, virtual
machines, virtual storage, etc. In the example given in PaaS, we consider the scenario of
small firm and its development environment. Now consider, the same firm is dealing with
the huge customer data and backup of the same data. Then you need to upgrade your storing
capacity as per the demand of the customer grows and you also need to bother about the
backup of the customer data in case of any disaster. And if we consider the maintenance cost
of the RAID then it will be costlier. But if you subscribe the IaaS then everything will go
well and your storage capacity will increase as per the demand and no need to pay only for
the uses, that mean no need to stock the resource for the future. This service is normally use
for cloud hosting you can find some of the popular cloud providers.
IaaS Characteristics:
*Allows dynamic scaling capabilities – the cost varies based on the infrastructure selection
*Very flexible cloud computing model and gives organizations a complete true control over
their infrastructure
PLATFORM-AS-A-SERVICE (PAAS)
PaaS provides the runtime environment for applications, development and
deployment tools, etc.
If you are the web app developer and still working on the stand alone machine then this
service is best for you. If you want to develop a CRM application then PaaS is best for you.
Now, what is this PaaS stands for? Okay! It’s a Platform as a service but which platform it
is.
Example: Suppose you want to start a small firm for web app development, now the first
thing you need to consider is, purchasing latest computer, then you need to install the
platform for development and frequently need to update with new packages or patches to
keep it updated…Now consider you are subscribing the PaaS then you will able to do the
same thing with the help of low-cost computing device and also there is no need to install the
development platform on your local standalone machine. You just need to login to the server
and start the development and you can deploy your developed app on the internet and also
can sell it on the online market. The best example of PaaS is salesforce.com which is the
biggest CRM cloud which I know.
PaaS Characteristics:
*Built on top of virtualization technology – you can demand for resources as per your need
and scale up/ down as per the requirement
SaaS Characteristics:
*Software is hosted on a remote server and is always accessible through a web browser over
Internet
*Application users don’t need to worry about hardware, software updates and patches
*Any integration with the third party applications are done through APIs
3. Resource pooling:
Cloud computing allows multiple tenants to share a pool of resources. One can share
single physical instance of hardware, database and basic infrastructure . It’s a common term
generally used in I.T, when service provider serves their customer and “tenants” with
minimum and optimistically arranged computing resource in such a way that they can give
better services in less cost or using better resource management strategy. But this pooled
service is not limited to the users.
The provider’s computing resources are pooled to serve multiple consumers
using a multi-tenant model, with different physical and virtual resources
dynamically assigned and reassigned according to consumer demand.
4. Rapid elasticity :
It is very easy to scale the resources vertically or horizontally at any time. Scaling of
resources means the ability of resources to deal with increasing or decreasing demand . The
resources being used by customers at any given point of time are automatically monitored .
What is the most interesting thing of cloud computing and the key factor of the cloud
computing? Yes. It is Rapid elasticity. Then what’s this elasticity mean. Now take an
example.
Suppose you and your friend are taking benefits of the cloud services but the difference
is, you are working on the high-end application and use the tremendous resource, but your
friend using the same service for the word processing. In this situation cloud services will
utilise only that much power which you really want. So it’s a real way to optimise the
resource and it is beneficial for both customer and for the service provider.
Capabilities can be rapidly and elastically provisioned - in some cases
automatically - to quickly scale out; and rapidly released to quickly scale in.
To the consumer, the capabilities available for provisioning often appear to be
unlimited and can be purchased in any quantity at any time.
5. Measured Service:
In this service cloud provider controls and monitors all the aspects of cloud service.
Resource optimization, billing, and capacity planning etc. depend on it. As the name suggest,
the measured services are those services which are measured or monitored in the context of
billing, usage, utilization and for predictive planning. One positive aspect of measured
services is, it gives the prediction regarding utilization of the resources and user need to pay
only for the resources which are utilised by him. So there is no need to pay for the idle time
or down time (Where ideally down time of cloud computing is 0%)
Cloud systems automatically control and optimize resource usage by leveraging
a metering capability at some level of abstraction appropriate to the type of
service.
Resource usage can be monitored, controlled, and reported - providing
transparency for both the provider and consumer of the service.
● One can manipulate and configure the applications online at any time.
● Cloud Computing offers on-demand self-service. The resources can be used without
interaction with cloud service provider.
● Cloud Computing is highly cost effective because it operates at high efficiency with
optimum utilization. It just requires an Internet connection
Although the cloud computing vendors ensure highly secured password protected accounts,
any sign of security breach may result in loss of customers and businesses.
Lock In
It is very difficult for the customers to switch from one Cloud Service Provider
(CSP) to another. It results in dependency on a particular CSP for service.
Isolation Failure
This risk involves the failure of isolation mechanism that separates storage, memory,
and routing between the different tenants.
● Extra copies of data are stored but are not available at the time of deletion
Cluster means a group of similar things. A Cluster Computing is the collection of loosely
or tightly connected computer which work together which gives the illusion of single high
performance computer. The cluster computer used to perform a single task with high
performance computing. This can be achieved by connecting the entire computer via high
performance LAN (Local Area Network) where every computer runs their instance of OS.
Cluster categorizations
• HPC Cluster
• They operates by having redundant nodes, upon failure the standby node take cares
• Often used for critical databases, network file sharing and business applications
Logically they are multiple computers but function as single virtual computer
Request initiated from the user is distributed among all the nodes by one or more load
balancer
HPC Cluster
HPC clusters are mainly used to increases the performance by splitting the
computational task into different nodes
Popular HPC cluster implementations are nodes running with Linux OS and free
software’s to implement the parallelism
The job running on the cluster nodes requires little or no inter nodes communication is
called “Grid Computing”
The local Scheduling software manages the cluster nodes load balancing
1. Availability
2. Scalability
3. Performance
These benefits map to needs of today’s enterprise business, education, military and scientific
community infrastructures.
Grid Computing
Grid computing is the collection of computer resources from multiple locations to
reach a common goal. The grid can be thought of as a distributed system with non-interactive
workloads that involve a large number of files.
Example
I know one example which i used from last 10 year. Actually i am the member of this
project. And it is SETI (Search for Extra-terrestrial Intelligence). Where SETI@HOME is an
Internet Based Public Volunteer Computing Program where you can donate your Processing
power to the Berkeley University to do research on the Space, Space Science and Different
Computer Intensive Research to do the Analysis of Signal Coming from the Space.
Grid Applications
• Disaster Management
• Aerodynamic Simulations
Advantages
Distributed Computing
As the name suggest, the distributed computing is the software system which
computers are located apart from each other but make a illusion of single computer by
passing messages to each other. Normally in distributed computing all the computing
machine work with each other and coordinate by passing the messages to achieve a common
goal.
Example:
We often to use distributed computing when we play multiplayer games and never
think about the technology behind the same. Multiplayer Games is the best example of
Distributed Computing. SOA (Service-Oriented architecture) uses architectural pattern in
which application component provide services to other components using messages.
Utility Computing
Utility computing is somewhat similar to our cable TV services where service
Provider Company gives their services to the customer as per demand. We often to say on
demand services and also charged the customer for the services. The services offered may be
in the form of Computation, storage, and other services. The utility computing is much closed
to cloud computing.
4: Minimally or self-
managed platform
5: Consumption-based billing
The cluster computers all The computers that are part The memory, storage device
have the same hardware and of a grid can run different and network communication
OS. operating systems and have are managed by the operating
different hardware system of the basic physical
cloud units. Open source
software such as LINUX can
support the basic physical
unit management and
virtualization computing.
The whole system (all nodes) Every node is autonomous Every node acts as an
behaves like a single system i.e. it has its own resource independent entity
view and resources are manager and behaves like an
managed by centralized independent entity
resource manager.
More than 2 computers are A large project is divided It does just the opposite. It
connected to solve a problem among multiple computers to allows multiple smaller
make use of their resources. applications to run at the
same time.
5.Visualization
One of the standard OSs Any standard OS (dominated A hypervisor (VM) on which
(Linux, Windows) by Unix) multiple OSs run
Dedicated, high-end with low Mostly Internet with high Dedicated, high-end with low
latency and high bandwidth latency and low Bandwidth latency and high Bandwidth
Interconnection Network Interconnection Network Interconnection Network
Limited service negotiation Yes, SLA based service SLA based service
negotiation negotiation
Virtual Interface Architecture Some Open Grid Forum Web Services (SOAP and
(VIA)-based standards standards REST) standards
Single system image No single system image Yes, but optionally include
Single system image
Stable and guarantee capacity Varies, but high capacity Provisioned on demand
capacity
Failure management (Self- Failure management (Self- Strong support for failover
healing) is limited (often healing) is limited (often and content replication. VMs
failed tasks/applications are failed tasks/applications are can be easily migrated from
restarted). restarted). one node to other
Potential for building 3rd Potential for building 3rd High potential - can create
party or value-added party or value-added new services by dynamically
solutions is limited due to solutions is limited due to provisioning of compute,
rigid architecture strong orientation for storage, and application
scientific Computing services and offer as their
own isolated or composite
Cloud services to users
What Is Service-Oriented Architecture?
Service-Oriented Architecture (SOA) is a style of software design where services are
provided to the other components by application components, through a communication
protocol over a network. Its principles are independent of vendors and other technologies. In
service oriented architecture, a number of services communicate with each other, in one of
two ways: through passing data or through two or more services coordinating an activity.
There are three roles in each of the Service-Oriented Architecture building blocks: service
provider; service broker, service registry, service repository; and service requester/consumer.
The service provider works in conjunction with the service registry, debating the whys and
how’s of the services being offered, such as security, availability, what to charge, and more.
This role also determines the service category and if there need to be any trading agreements.
The service broker makes information regarding the service available to those requesting it.
The scope of the broker is determined by whoever implements it.
The service requester locates entries in the broker registry and then binds them to the service
provider. They may or may not be able to access multiple services; that depends on the
capability of the service requester.
Implementing Service-Oriented Architecture
When it comes to implementing service-oriented architecture (SOA), there is a wide range of
technologies that can be used, depending on what your end goal is and what you’re trying to
accomplish.
Typically, Service-Oriented Architecture is implemented with web services, which makes the
“functional building blocks accessible over standard internet protocols.”
An example of a web service standard is SOAP, which stands for Simple Object Access
Protocol. In a nutshell, SOAP “is a messaging protocol specification for exchanging
structured information in the implementation of web services in computer networks.
Although SOAP wasn’t well-received at first, since 2003 it has gained more popularity and is
becoming more widely used and accepted. Other options for implementing Service-Oriented
Architecture include Jini, COBRA, or REST.
It’s important to note that architectures can “operate independently of specific technologies,”
which means they can be implemented in a variety of ways, including messaging, such as
ActiveMQ; Apache Thrift; and SORCER.