Cc Module 1 Sjbit
Cc Module 1 Sjbit
Prepared by ,
Bindya M K , Professor
Srinidhi K S , Assistant Professor
D Chaitra , Assistant Professor
Course Learning Objectives:
1. Introduce the rationale behind the cloud computing revolution and the business drivers
2. Understand various models, types and challenges of cloud computing
3. Understand the design of cloud native applications, the necessary tools and the design
tradeoffs.
4. Realize the importance of Cloud Virtualization, Abstraction`s, Enabling Technologies and
cloud security
Course Outcomes
CO1 Understand and analyze various cloud computing platforms and service provider
CO2 Illustrate various virtualization concepts
CO3 Identify the architecture, infrastructure and delivery models of cloud computing
CO4 Understand the Security aspects of CLOUD
CO5 Define platforms for development of cloud applications
Textbooks
1. Kai Hwang, Geoffrey C Fox, and Jack J Dongarra, Distributed and Cloud Computing, Morgan
Kaufmann, Elsevier 2012
2. Dan C. Marinescu, Cloud Computing Theory and Practice, Morgan Kaufmann, 2nd Edition,
Elsevier 2018
3. Google Cloud Teaching Resources – LMS [for practical component]
4. AWS Cloud Developing – AWS Academy Courses [for practical component]
Reference Books:
1. Rajkumar Buyya, Christian Vecchiola, and Thamrai Selvi, Mastering Cloud Computing
McGrawHill Education, 1st Edition, 2017
2. Toby Velte, Anthony Velte, Cloud Computing: A Practical Approach, McGraw-Hill Education,
2017.
3. George Reese, Cloud Application Architectures: Building Applications and Infrastructure in the
Cloud, O'Reilly Publication, 1st Edition, 2009
4. John Rhoton, Cloud Computing Explained: Implementation Handbook for Enterprises,
Recursive Press, 2nd Edition, 2009.
Module-1
Distributed System Models and Enabling Technologies:
Scalable Computing Over the Internet, Technologies for Network Based Systems, System Models
for Distributed and Cloud Computing, Software Environments for Distributed Systems and
Clouds, Performance, Security and Energy Efficiency.
Textbook 1: Chapter 1: 1.1 to 1.5
Grids enable access to shared computing power and storage capacity from your desktop.
Clouds enable access to leased computing power and storage capacity from your desktop.
• Grids are an open source technology. Resource users and providers alike can understand and
contribute to the management of their grid
• Clouds are a proprietary technology. Only the resource provider knows exactly how their cloud
manages data, job queues, security requirements and so on.
• The concept of grids was proposed in 1995. The Open science grid (OSG) started in 1995 The
EDG (European Data Grid) project began in 2001.
• In the late 1990`s Oracle and EMC offered early private cloud solutions . However the term cloud
computing didn't gain prominence until 2007. o high-performance computing (HPC) applications
is no longer optimal for measuring system performance
• The emergence of computing clouds instead demands high-throughput computing (HTC)
systems built with parallel and distributed computing technologies
• We have to upgrade data centers using fast servers, storage systems, and high-bandwidth
networks.
• From 1950 to 1970, a handful of mainframes, including the IBM 360 and CDC 6400
o From 1980 to 2000, massive numbers of portable computers and pervasive devices appeared in both
wired and wireless applications
o Since 1990, the use of both HPC and HTC systems hidden in clusters, grids, or Internet clouds has
proliferated
pg. 1
BCS601 Cloud Computing Module-1
pg. 2
BCS601 Cloud Computing Module-1
The transition from HPC to HTC marks a strategic shift in computing paradigms, focusing on
scalability, efficiency, and real-world usability over pure processing power.
Computing Paradigm Distinctions
Centralized computing
A computing paradigm where all computer resources are centralized in a single physical
system. In this setup, processors, memory, and storage are fully shared and tightly integrated
within one operating system. Many data centers and supercomputers operate as centralized
systems, but they are also utilized in parallel, distributed, and cloud computing applications.
• Parallel computing
In parallel computing, processors are either tightly coupled with shared memory or loosely
coupled with distributed memory. Communication occurs through shared memory or message
passing. A system that performs parallel computing is a parallel computer, and the programs
running on it are called parallel programs. Writing these programs is referred to as parallel
programming.
• Distributed computing studies distributed systems, which consist of multiple autonomous
computers with private memory communicating through a network via message passing.
Programs running in such systems are called distributed programs, and writing them is known
as distributed programming.
Cloud computing refers to a system of Internet-based resources that can be either centralized
or distributed. It uses parallel, distributed computing, or both, and can be established with
physical or virtualized resources over large data centers. Some regard cloud computing as a
form of utility computing or service computing. Alternatively, terms such as concurrent
computing or concurrent programming are used within the high-tech community, typically
referring to the combination of parallel and distributed computing, although interpretations
may vary among practitioners.
• Ubiquitous computing refers to computing with pervasive devices at any place and time
using wired or wireless communication. The Internet of Things (IoT) is a networked connection
of everyday objects including computers, sensors, humans, etc. The IoT is supported by Internet
clouds to achieve ubiquitous computing with any object at any place and time. Finally, the term
Internet computing is even broader and covers all computing paradigms over the Internet. This
book covers all the aforementioned computing paradigms, placing more emphasis on
distributed and cloud computing and their working systems, including the clusters, grids, P2P,
and cloud systems.
Internet of Things The traditional Internet connects machines to machines or web pages to web
pages. The concept of the IoT was introduced in 1999 at MIT.
• The IoT refers to the networked interconnection of everyday objects, tools, devices, or computers.
One can view the IoT as a wireless network of sensors that interconnect all things in our daily life.
• It allows objects to be sensed and controlled remotely across existing network infrastructure
pg. 3
BCS601 Cloud Computing Module-1
Degrees of Parallelism
Parallelism in computing has evolved from:
pg. 4
BCS601 Cloud Computing Module-1
HTC systems prioritize task throughput over raw speed, addressing challenges like cost, energy
efficiency, security, and reliability.
Challenges include:
Efficient network processors
Scalable storage and memory
Virtualization middleware
New programming models
pg. 5
BCS601 Cloud Computing Module-1
For example, in 2010, cloud computing was moving toward mainstream adoption, while broadband
over power lines was expected to become obsolete.
pg. 6
BCS601 Cloud Computing Module-1
Modern multicore processors integrate dual, quad, six, or more processing cores to
enhance parallelism at the instruction level (ILP) and task level (TLP).
Processor speed growth has followed Moore’s Law, increasing from 1 MIPS (VAX 780,
1978) to 22,000 MIPS (Sun Niagara 2, 2008) and 159,000 MIPS (Intel Core i7 990x, 2011).
Clock rates have increased from 10 MHz (Intel 286) to 4 GHz (Pentium 4) but have
stabilized due to heat and power limitations.
Multicore CPU and Many-Core GPU Architectures
Multicore processors house multiple processing units, each with private L1 cache and
shared L2/L3 cache for efficient data access.
Many-core GPUs (e.g., NVIDIA and AMD architectures) leverage hundreds to thousands
of cores, excelling in data-level parallelism (DLP) and graphics processing.
Example: Sun Niagara II – Built with eight cores, each supporting eight threads, achieving
a maximum parallelism of 64 threads.
pg. 7
BCS601 Cloud Computing Module-1
Multicore CPUs continue to evolve from tens to hundreds of cores, but they face challenges
like the memory wall problem, limiting data-level parallelism (DLP).
Many-core GPUs, with hundreds to thousands of lightweight cores, excel in DLP and
task-level parallelism (TLP), making them ideal for massively parallel workloads.
Hybrid architectures are emerging, combining fat CPU cores and thin GPU cores on a
single chip for optimal performance.
Multithreading Technologies in Modern CPUs
Different microarchitectures exploit parallelism at instruction-level (ILP) and thread-
level (TLP):
o Superscalar Processors – Execute multiple instructions per cycle.
o Fine-Grained Multithreading – Switches between threads every cycle.
o Coarse-Grained Multithreading – Runs one thread for multiple cycles before
switching.
o Simultaneous Multithreading (SMT) – Executes multiple threads in the same cycle.
Modern GPUs (e.g., NVIDIA CUDA, Tesla, and Fermi) feature hundreds of cores,
handling thousands of concurrent threads.
Example: The NVIDIA Fermi GPU has 512 CUDA cores and delivers 82.4 teraflops,
contributing to the performance of top supercomputers like Tianhe-1A.
GPU vs. CPU Performance and Power Efficiency
GPUs prioritize throughput, while CPUs optimize latency using cache hierarchies.
Power efficiency is a key advantage of GPUs – GPUs consume 1/10th of the power per
instruction compared to CPUs.
Future Exascale Systems will require 60 Gflops/W per core, making power efficiency a
major challenge in parallel and distributed computing.
pg. 9
BCS601 Cloud Computing Module-1
The shift towards hybrid architectures (CPU + GPU) and the rise of power-aware computing
models will drive the next generation of HPC, HTC, and cloud computing systems.
Memory access speed has not kept pace, causing the memory wall problem, where CPUs
outpace memory access speeds.
pg. 10
BCS601 Cloud Computing Module-1
Disks and Storage Technology
Hard drive capacity has grown 10x every eight years, reaching 3 TB (Seagate Barracuda
XT, 2011).
Solid-State Drives (SSDs) provide significant speed improvements and durability (300,000
to 1 million write cycles per block).
Power and cooling challenges limit large-scale storage expansion.
pg. 11
BCS601 Cloud Computing Module-1
pg. 12
BCS601 Cloud Computing Module-1
Hybrid VMs combine features of both native and hosted virtualization. They partially
virtualize hardware by running some components in user mode and others in privileged
mode. This architecture optimizes performance by reducing overhead while maintaining
flexibility and ease of management.
Uses both hardware-assisted and software virtualization techniques.
The hypervisor runs at the kernel level, but some functions rely on the host OS.
Balances performance and flexibility for different workloads.
• First, the VMs can be multiplexed between hardware machines, as shown in Figure 1.13(a).
• Second, a VM can be suspended and stored in stable storage, as shown in Figure 1.13(b).
• Third, a suspended VM can be resumed or provisioned to a new hardware platform, as shown in Figure 1.13(c).
• Finally, a VM can be migrated from one hardware platform to another, as shown in Figure 1.13(d).
Suspension & Migration – VMs can be paused, saved, or migrated across different servers.
Provisioning – VMs can be dynamically deployed based on workload demand.
Virtual Infrastructure
Separates physical hardware from applications, enabling flexible resource management.
pg. 13
BCS601 Cloud Computing Module-1
MapReduce & Iterative MapReduce enable scalable data processing for big data and
machine learning applications.
The convergence of data-intensive computing, cloud platforms, and multicore
architectures is shaping the next generation of distributed computing.
pg. 14
BCS601 Cloud Computing Module-1
The integration of memory, storage, networking, virtualization, and cloud data centers is
transforming distributed systems. By leveraging virtualization, scalable networking, and cloud
computing, modern infrastructures achieve higher efficiency, flexibility, and cost-effectiveness,
paving the way for future exascale computing.
pg. 15
BCS601 Cloud Computing Module-1
Cluster Architecture
Clusters are connected to the Internet via a VPN gateway, which assigns an IP address to
locate the cluster.
Each node operates independently, with its own OS, creating multiple system images
(MSI).
The cluster manages shared I/O devices and disk arrays, providing efficient resource
utilization.
pg. 16
BCS601 Cloud Computing Module-1
Middleware supports features like high availability (HA), distributed memory sharing
(DSM), and job scheduling.
Virtual clusters can be dynamically created using virtualization, optimizing resource
allocation on demand.
Availability and Support Hardware and software support for Failover, failback, check pointing,
sustained HA in cluster rollback recovery, nonstop OS, etc.
Hardware Fault Tolerance Automated failure management to Component redundancy, hot
eliminate all single points of failure swapping, RAI D , multiple
power supplies, etc.
Single System Image (SSI) Achieving SSI at functional level with Hardware mechanisms or middleware
hardware and software support, support to achieve DSM at coherent
middleware, or OS extensions cache level
Efficient Communications To reduce message-passing system Fast message passing, active
overhead and hide latencies messages, enhanced MPI library, etc.
Cluster-wide Job Using a global job management Application of single-job
system with better scheduling and management systems such as LSF,
Management monitoring Codine, etc.
Dynamic Load Balancing Balancing the workload of all Workload monitoring, process
processing nodes a long with failure migration, job replication and gang
recovery scheduling, etc.
Scalability and Adding more servers to a cluster or Use of scalable interconnect,
adding more clusters to a grid as the performance monitoring, distributed
Programmability workload or data set increases execution environment, and better
software tools
Lack of a cluster-wide OS limits full resource sharing.
Middleware solutions provide necessary functionalities like scalability, fault tolerance, and
job management.
Key challenges include efficient message passing, seamless fault tolerance, high
availability, and performance scalability.
Server clusters are scalable, high-performance computing systems that utilize networked
computing nodes for parallel and distributed processing. Achieving SSI and efficient
middleware support remains a key challenge in cluster computing. Virtual clusters and cloud
computing are evolving to enhance cluster flexibility and resource management.
pg. 17
BCS601 Cloud Computing Module-1
Grid computing has evolved from Internet and web-based services to enable large-scale
distributed computing. It allows applications running on remote systems to interact in real-time.
Used for scientific and enterprise applications, including SETI@Home and astrophysics
simulations.
Provides an integrated resource pool, enabling shared computing, data, and information
services.
1.3.2.2 Grid Families
Design Issues Computational and Data Grids P2P Grids
Grid Applications Reported Distributed supercomputing, Open grid with P2P flexibility, all
National Grid initiatives, etc. resources from client machines
Representative Systems TeraGrid built in US, ChinaGrid in JXTA, FightAid@home,
China, and the e-Science grid SETI@home
built in UK
Development Lessons Learned Restricted user groups, Unreliable user-contributed
middleware bugs, protocols to resources, limited to a few apps
acquire resources
Computational and Data Grids – Used in national-scale supercomputing projects (e.g.,
TeraGrid, ChinaGrid, e-Science Grid).
P2P Grids – Utilize client machines for open, distributed computing (e.g., SETI@Home,
JXTA, FightingAID@Home).
Challenges include middleware bugs, security issues, and unreliable user-contributed
resources.
1.3.3 Peer-to-Peer (P2P) Network Families
P2P systems eliminate central coordination, allowing client machines to act as both servers and
clients.
1.3.3.1 P2P Systems
pg. 18
BCS601 Cloud Computing Module-1
Collaboration Platform Skype, MSN, Multiplayer games Privacy risks, spam, lack of trust
Open P2P Platforms JXTA, .NET, FightingAID@Ho Lack of standardization and secur
pg. 19
BCS601 Cloud Computing Module-1
user-driven resource sharing. Future developments will focus on security, standardization, and
efficiency improvements.
pg. 20
BCS601 Cloud Computing Module-1
pg. 21
BCS601 Cloud Computing Module-1
Hybrid Cloud – Combines public and private clouds, optimizing cost and security.
pg. 22
BCS601 Cloud Computing Module-1
pg. 23
BCS601 Cloud Computing Module-1
SOA has expanded from basic web services to complex multi-layered ecosystems:
Sensor Services (SS) – Devices like ZigBee, Bluetooth, GPS, and WiFi collect raw data.
Filter Services (FS) – Process data before feeding into computing, storage, or discovery
clouds.
Cloud Ecosystem – Integrates compute clouds, storage clouds, and discovery clouds for
managing large-scale applications.
SOA enables data transformation from raw data → useful information → knowledge → wisdom
→ intelligent decisions.
SOA defines the foundation for web services, distributed systems, and cloud computing. By
integrating sensors, processing layers, and cloud resources, SOA provides a scalable, flexible
approach for modern computing applications. The future of distributed computing will rely on
intelligent data processing, automation, and service-driven architectures.
3. Truly Distributed OS – Provides single-system image (SSI) with full transparency across
resources.
pg. 24
BCS601 Cloud Computing Module-1
pg. 25
BCS601 Cloud Computing Module-1
1.4.3.2 MapReduce
Highly scalable parallel model, used in big data processing and search engines.
1.4.3.3 Hadoop
Open-source alternative to MapReduce, used for processing petabytes of data.
Scalable, cost-effective, and fault-tolerant, making it ideal for cloud services.
pg. 26
BCS601 Cloud Computing Module-1
Distributed OS models are evolving, with MOSIX2 enabling process migration and
resource sharing across Linux clusters.
Parallel programming models like MPI and MapReduce optimize large-scale computing.
Cloud computing and grid computing continue to merge, leveraging virtualization and
elastic resource management.
Standardized middleware (OGSA, Globus) enhances grid security, interoperability, and
automation.
pg. 27
BCS601 Cloud Computing Module-1
Speedup Formula:
where α is the fraction of the workload that is sequential.
Even with hundreds of processors, speedup is limited if sequential execution (α) is high.
Problem with Fixed Workload
In Amdahl’s law, we have assumed the same amount of workload for both sequential and parallel
execution of the program with a fixed problem size or data set. This was called fixed-workload speedup
by Hwang and Xu [14]. To execute a fixed workload on n processors, parallel processing may lead to
a system efficiency defined as follows:
1.5.1.6 Gustafson’s Law (Scaled Workload Scaling)
Instead of fixing workload size, this model scales the problem to match available
processors.
Speedup Formula:
This speedup is known as Gustafson’s law. By fixing the parallel execution time at
level W, the following efficiency expression is obtained:
More efficient for large clusters, as workload scales dynamically with system size.
Eliminating single points of failure (e.g., hardware redundancy, fault isolation) improves
availability.
pg. 28
BCS601 Cloud Computing Module-1
P2P networks are highly scalable but have low availability due to frequent peer failures.
Grids and clouds offer better fault isolation and thus higher availability than traditional
clusters.
Clouds and grids balance scalability and availability better than traditional SMP or
NUMA systems.
Network Threats, Data Integrity, and Energy Efficiency
This section highlights security challenges, energy efficiency concerns, and mitigation strategies
in distributed computing systems, including clusters, grids, clouds, and P2P networks.
pg. 29
BCS601 Cloud Computing Module-1
Improper Authentication – Allows attackers to steal resources, modify data, and conduct
replay attacks.
PaaS: Provider manages integrity and availability, while users control confidentiality.
IaaS: Users are responsible for most security aspects, while providers ensure availability.
Global energy cost of idle servers: $3.8 billion annually, with 11.8 million tons of CO₂
emissions.
IT departments must identify underutilized servers to reduce waste.
1.5.4.2 Reducing Energy in Active Servers
pg. 30
BCS601 Cloud Computing Module-1
Techniques like DPM and DVFS can significantly reduce power consumption without
compromising performance.
pg. 31
BCS601 Cloud Computing Module-1
pg. 32