Assignment 1 Front Sheet Qualification BTEC Level 5 HND Diploma in Computings Unit Number and Title Submission Date
Assignment 1 Front Sheet Qualification BTEC Level 5 HND Diploma in Computings Unit Number and Title Submission Date
Assignment 1 Front Sheet Qualification BTEC Level 5 HND Diploma in Computings Unit Number and Title Submission Date
Qualification
m
BTEC Level 5 HND Diploma in Computings
o
Unit number and title
c
Unit 16: Cloud computing
.
ib
Submission date 13/3/2022 Date Received 1st submission
Re-submission Date
Student Name
Class
d
Student declaration
PBIT16101_CNTT1 Assessor name CAO TIẾN THÀNH
I certify that the assignment submission is entirely my own work and I fully understand the consequences of plagiarism. I understand
that making a false declaration is a form of malpractice.
Student’s signature
Grading grid
.c
BTEC Level 5 HND Diploma in Computing
Unit number
Assignment title
k l ib
Unit 16: Cloud computing
Academic Year
Unit Tutor
e s 2021 - 2022
Issue date
d
IV name and date
Submission date
Submission Format:
m
properly, and that understand the guidelines on plagiarism. If you do not, you definitely get failed
.c o
LO1 Demonstrate an understanding of the fundamentals of Cloud Computing and its architectures.
ib
LO2 Evaluate the deployment models, service models and technological drivers of Cloud Computing and
validate their use.
k l
Assignment Brief and Guidance:
e s
d
o m
company has the revenue over 500.000 dollars/year. Currently each shop has its own database to store
transactions for that shop only. Each shop has to send the sale data to the board director monthly and
.c
the board director need lots of time to summarize the data collected from all the shops. Besides the
board can’t see the stock information update in real time.
l ib
The table of contents in your technical report should be as follows:
k
1. Explain to the board director the fundamentals of cloud computing and how it is popular
e s
nowadays(500 words)
2. Persuade the board director to use Cloud Computing in ATN(300 words)
3. Proposed solution (higher level solution description – around 200 words).
d
4. Explain the appropriateness of the solution for the scenario (350 words with images and
diagrams).
5. Architectural design (architectural diagram and description).
6. Detailed design:
a. Deployment model (discussion on why that model was chosen).
b. Service model (discussion on why that model was chosen).
c. Programming language/ webserver/database server chosen.
7. Summary.
o m
INTRODUCTION...........................................................................................................................................................................................8
I.
1.
.c
P1: Analyse the evolution and fundamental concepts of Cloud Computing....................................................................................8
Evolution of cloud computing..........................................................................................................................................................8
II.
2.
1. ib
fundamental concepts of Cloud Computing.................................................................................................................................10
l
P2 Design an appropriate architectural Cloud Computing framework for a given scenario..........................................................13
k
Scenario..........................................................................................................................................................................................13
2.
3.
e s
Purpose of scenario.......................................................................................................................................................................13
Why should we use cloud..............................................................................................................................................................13
1.
2.
3.
d
III. P3 Define an appropriate deployment model for a given scenario................................................................................................13
Deployment model should be used for scenario..........................................................................................................................13
The Comparison of Top Cloud Deployment Models.....................................................................................................................16
Major cloud service models...........................................................................................................................................................18
4. model selected for the project......................................................................................................................................................18
IV. Compare the service models for choosing an adequate model for a given scenario.................................................................22
1. The language programming we should be used...........................................................................................................................22
2. The database we should be used..................................................................................................................................................24
3. The diagram....................................................................................................................................................................................26
4. Explain the diagram.......................................................................................................................................................................27
References.................................................................................................................................................................................................28
o m
Figure 1: Evolution of cloud computing............................................................................................................................................9
Figure 2: Cloud Computing.............................................................................................................................................................12
c
Figure 3 Public cloud......................................................................................................................................................................15
ib .
Figure 4: Private Cloud...................................................................................................................................................................16
Figure 5: Community Cloud............................................................................................................................................................17
l
Figure 6: Hybrid cloud....................................................................................................................................................................18
k
Table1: Comparison of Top Cloud Deployment Models..................................................................................................................19
Table 2. Compare SaaS, PaaS, IaaS.................................................................................................................................................23
e s
Table 3. Compare Node.JS and PHP................................................................................................................................................25
Table 4. Compare NoSQL and SQL..................................................................................................................................................27
d
Figure 7: Diagram of PaaS..............................................................................................................................................................28
INTRODUCTION
This assignment will provide details about the development and concepts of Cloud Computing. ATN now includes many
stores that are using the traditional and unoptimized storage model, it takes a long time for data statistics and management
cannot update the stock information in real time. My task is to find out whether Cloud Computing should be applied to ATN.
Distributed Systems:
It is a composition of multiple independent systems but all of them are depicted as a single entity to the users.
The purpose of distributed systems is to share resources and also use them effectively and efficiently.
Distributed systems possess characteristics such as scalability, concurrency, continuous availability,
heterogeneity, and independence in failures. But the main problem with this system was that all the systems
were required to be present at the same geographical location. Thus to solve this problem, distributed
computing led to three more types of computing and they were-Mainframe computing, cluster computing,
and grid computing.
Mainframe computing:
7
o m
used for bulk processing tasks such as online transactions etc. These systems have almost no downtime with
high fault tolerance. After distributed computing, these increased the processing capabilities of the system.
But these were very expensive. To reduce this cost, cluster computing came as an alternative to mainframe
technology.
Cluster computing:
.c
ib
In 1980s, cluster computing came as an alternative to mainframe computing. Each machine in the cluster was
k lconnected to each other by a network with high bandwidth. These were way cheaper than those mainframe
systems. These were equally capable of high computations. Also, new nodes could easily be added to the
s
cluster if it was required. Thus, the problem of the cost was solved to some extent but the problem related to
geographical restrictions still pertained. To solve this, the concept of grid computing was introduced.
d e Grid computing:
In 1990s, the concept of grid computing was introduced. It means that different systems were placed at
entirely different geographical locations and these all were connected via the internet. These systems
belonged to different organizations and thus the grid consisted of heterogeneous nodes. Although it solved
some problems but new problems emerged as the distance between the nodes increased. The main problem
which was encountered was the low availability of high bandwidth connectivity and with it other network
associated issues. Thus. cloud computing is often referred to as “Successor of grid computing”.
Virtualization:
It was introduced nearly 40 years back. It refers to the process of creating a virtual layer over the hardware
which allows the user to run multiple instances simultaneously on the hardware. It is a key technology used in
cloud computing. It is the base on which major cloud computing services such as Amazon EC2, VMware
vCloud, etc work on. Hardware virtualization is still one of the most common types of virtualization.
Web 2.0:
It is the interface through which the cloud computing services interact with the clients. It is because of Web
2.0 that we have interactive and dynamic web pages. It also increases flexibility among web pages. Popular
Service orientation:
o m
c
It acts as a reference model for cloud computing. It supports low-cost, flexible, and evolvable applications.
ib .
Two important concepts were introduced in this computing model. These were Quality of Service (QoS) which
also includes the SLA (Service Level Agreement) and Software as a Service (SaaS).
k lUtility computing:
It is a computing model that defines service provisioning techniques for services such as compute services
e s along with other major services such as storage, infrastructure, etc which are provisioned on a pay-per-use
basis.
d
Thus, the above technologies contributed to the making of cloud computing.
o m
.c
k l ib
e s
d
Figure 2: Cloud Computing
10
o m
the Internet from any remote location and by any local computing device.
c
The simplest thing that any computer does is allow us to store and retrieve information. We can store our
ib .
family photographs, our favorite songs, or even save movies on it, which is also the most basic service offered
by cloud computing. Let us look at the example of a popular application called Flickr to illustrate the meaning
l
of this section. While Flickr started with an emphasis on sharing photos and images, it has emerged as a great
k
place to store those images. In many ways, it is supe-rior to storing the images on your computer:
e s 1. First, Flickr allows us to easily access our images no matter where we are or what type of device we are
using. While we might upload the photos of our vacation from our home computer, later, we can
o m
ATN is a Vietnamese company which is selling toys to teenagers in many provinces all over Vietnam. The company has the
c
revenue over 500.000 dollars/year. Currently each shop has its own database to store transactions for that shop only. Each
ib .
shop has to send the sale data to the board director monthly and the board director need lots of time to summarize the data
collected from all the shops. Besides the board can’t see the stock information update in real time.
k l
2. Purpose of scenario
Deploying website projects on cloud computing will help us:
e s
- reduce management costs, infrastructure and redundant internal services that the website does not use.
- Easy to manage data in the cloud.
d
- can be used when we are anywhere (only need internet).
12
13
14
15
16
m
privacy
Data control
Little to
none
High
Reliability
Scalability and
k l
Low
ib
High Comparatively high High
flexibility
d
Cost-effectiveness
No
Cost-intensive; the most
expensive model
Depends
Cost is shared among
community members
Depends
Cheaper than a private model but
more costly than a public one
Depends
17
o m
c
There are three major cloud service models: software as a service (SaaS), infrastructure as a service (IaaS) and platform as
a service (PaaS).
ib .
software as a service (SaaS)
l
Software as a service vendors host the applications, making them available to users via the internet. With
k
SaaS, businesses don't have to install or download any software to their existing IT infrastructures. SaaS
ensures that users are always running the most up-to-date versions of the software. The SaaS provider
d Infrastructure as a service is used by companies that don't want to maintain their own on-premises data
centers. IaaS provides virtual computing resources over the Internet. The IaaS cloud vendor hosts the
infrastructure components that typically exist in an on-premises data center, including servers, storage and
networking hardware, as well as the hypervisor or virtualization layer.
platform as a service (PaaS)
Platform as a service offers developers a platform for software development and deployment over the
internet, enabling them to access up-to-date tools. PaaS delivers a framework that developers can use to
create customized applications. The organization or the PaaS cloud vendor manage the servers, storage and
networking, while the developers manage the applications.
18
Paradigm shift
Characteristics
IaaS
Dynamic cloud
.c
Infrastructure as an asset
SaaS
o
License purchasing
Save the time, money
PaaS
Software as an asset
Access for enterprise can
k l
computing .
ib
Easy to access to query
Easy to management and
upgrade security
custom design and building
application in SaaS with
e s
storage, network, server,
and automation.
special software components.
Easy to expanding
d Hardware can be
purchased additionally
based on usage.
Highly expanding.
Resource can buy if they
need.
Features Resources available as a Service management from Built on virtualization
service. central location. technology, resources can
Cost varies depending on Put on remote server. easily scale up or down as
consumption. Access on Internet. your business changes.
Highly scalable services Users do not need to Provides a variety of services
Often there are multiple upgrade hardware and for application development,
19
m
hardware. Multiple users can access the
o
Provide complete control same service application at
c
over your organization's the same time.
infrastructure.
Flexible.
k l
Limit capital expenditure Limit capital expenditure Streamlined version
s
on hardware and human on software and deployment
e
resource. development resource.
d
Low barriers to entry. Reduced risk.
Disadvantage Business efficiency and Centralization of data Centralization of data requires
productivity largely requires new security
depends on the vendor’s measures
capabilities
Centralization requires
new security measures
When use When capital budget is If server error, software If you are a developer or a
greater than operating Short-term projects that enterprise work with many
budget. require cooperation. people or same supplier.
There is no regular need. PaaS provide best speed and
If the software need to generic to whole process.
20
m
website. own.
.c o
Table 2. Compare SaaS, PaaS, IaaS
After compare, the purpose of company is need an environment to testing and service their custom website in own
ib
project mind to a cloud can support to run their source code and PaaS is a best model for deploy because PaaS has
l
support source code language programming complier and database. And team developer need an environment to
k
development website has support server can run the website in environment on brower and complier them.
IV. Compare the service models for choosing an adequate model for a given scenario
e s
1. The language programming we should be used
d
To develop website in company, we need to choose a language programming to develop them. We have 2 options for
develop language programming are Node.JS (JavaScript Framework) and PHP. And We will compare for this 2 language
programming and decision to choose a best language programming to develop website.
Node.JS PHP
Framework & module Node.JS has one framework is PHP has Symfony, Laravel,
Express JS. Codeignter,….
Module easy to use and huge Module easy to use and huge
module support for project module support than Node.JS.
support by Node Package Built-in no need to install.
Manager (NPM).
Community More than 65% website power 80% of website powered by PHP
21
m
day.
o
Speed & Performance Node.JS faster than PHP PHP lower than Node.JS
c
Support Client and Server Support both Client-Server Side Support only Sever-Side
Library Quality
k l
Synchronous
Asynchronous
None Information
Node.JS is a asynchronous
PHP is a synchronous language
PHP is not a asynchronous
e s
Database Node.JS must connect with
databases through NPM
PHP has built-in database support
Best with SQL (MySQL)
d Scalability
libraries.
Node.JS is a best if Node.JS
match with NoSQL Database
Easy to scalability Requires proficiency in the language
Website using Netflix, PayPal, Twitter, Yahoo, Facebook, WordPress, Wikipedia,
eBay Digg
22
m
2. The database we should be used
o
To choose the database for save the data of website and data of company. We have two database NoSQL and SQL. And
c
We will compare for this 2 database and decision to choose a best database match with Node.JS to storage data and
process them.
ib .
Define
k l SQL
Relational database
NoSQL
NoSQL is distributed database
e s
Design for RDBMS using syntax and query
SQL to analyst and get details
NoSQL with many technology
database. Using to develop for
d Language query
data
Structured query language (SQL)
modern applications
NoSQL does not using query
language
Type SQL Databases is a database NoSQL based on database
based on table. folder, couple key-value.
Schema SQL databases have predefined NoSQL databases use dynamic
schema schema for unstructured data.
Scalability SQL databases are vertically NoSQL databases are
scalable horizontally scalable
Brand Provider Oracle, Ms-SQL MongoDB, Redis, Neo4j
Hierarchical Data Storage Complex Not suitable for complex queries
Variations One with a slight variation With many type to storage key
23
o m
like Postgres & MySQL, and
c
commercial like Oracle
Best offer
ib . Database.
Reasonable for solve the ACID NoSQL is best used to solve data
Hardware
k l Specialized DB hardware
availability problems
Commodity hardware
Network
e s
ACID & BASE Model
Highly available network
ACID (Atomicity, Consistency,
Commodity network
Basic
d Performance
Isolation, and Durability) is a
standard for RDBMS
Very good and fast if design Faster than SQL
database good and clean
Common Common than NOSQL Grow up very fast
o m
.c
k l ib
e s
d
Figure 7: Diagram of PaaS
4. Explain the diagram
At the Software and OS step is the first step to deploying an application to the cloud, first developers need to complete
their application to see if the application is stable on internal and external environments. complete or not and this is the
first step (Software & operating systems).
25
m
choose Heroku as one of the best cloud services with support for Platforms are stable and support great under the
o
infrastructure of Amazon Web Service but have been revised to make it easy to develop applications with modern multi-
c
language programming and Databases like Node.JS & NoSQL mentioned earlier in hosting a programming language to
ib .
develop our company's application. (Cloud Services).
Above all, After choosing a cloud service, the next step is to deploy the application to the provider's cloud server and
l
follow their deployment step-by-step instructions.
k
s
After all, successfully deploying the system to the cloud, we will have a complete path given to us by the provider under
e
their domain name and just need users to access that domain name, they will access into our application.
d
References
GeeksforGeeks. 2020. Evolution of Cloud Computing - GeeksforGeeks. [ONLINE] Available at:
https://www.geeksforgeeks.org/evolution-of-cloud-computing/. [Accessed 13 March 2022].
Technology Idea Lab, S., 2020. The Fundamentals of Cloud Computing | by Sagara Technology Idea Lab |
Medium. [ONLINE] Medium. Available at: https://sagaratechnology.medium.com/the-fundamentals-of-cloud-
26
13 March 2022].
m
Available at: https://www.sam-solutions.com/blog/four-best-cloud-deployment-models-you-need-to-know/. [Accessed
o
Sirius Edge. 2017. The Top 3 Cloud Computing Service Models - Sirius Edge. [ONLINE] Available at:
.c
https://edge.siriuscom.com/cloud/the-top-3-cloud-computing-service-models. [Accessed 13 March 2022].
k l ib
e s
d
27