The New Era of Full Stack Development IJERTV9IS040016

Download as pdf or txt
Download as pdf or txt
You are on page 1of 6

See discussions, stats, and author profiles for this publication at: https://www.researchgate.

net/publication/340460348

The New Era of Full Stack Development Intoduction of Cloud and It's Impacts

Article in International Journal of Engineering Research and · April 2020


DOI: 10.17577/IJERTV9IS040016

CITATION READS

1 8,071

2 authors:

Akshat Dalmia Abhishek Raj Chowdary


Vidya Jyothi Institute of Technology Vidya Jyothi Institute of Technology
1 PUBLICATION 1 CITATION 1 PUBLICATION 1 CITATION

SEE PROFILE SEE PROFILE

All content following this page was uploaded by Akshat Dalmia on 06 April 2020.

The user has requested enhancement of the downloaded file.


Published by : International Journal of Engineering Research & Technology (IJERT)
http://www.ijert.org ISSN: 2278-0181
Vol. 9 Issue 04, April-2020

The New Era of Full Stack Development


Intoduction of Cloud and It’s Impacts

1st 2nd
Akshat Dalmia Abhishek Raj Chowdary
Information Technology Department Information Technology Department
Vidya Jyothi Institute of Technology Vidya Jyothi Institute of Technology
Hyderabad, India Hyderabad, India

Abstract—This is a concise study of the evolution of the full Intranet. The web development process includes web design,
stack development due to advancement of technology and the web content development, client-side/server-side scripting and
introduction of cloud. It helps give you a better understanding of network security configuration, among other tasks. It could
what full stack development was and how full stack development involve the development of static webpages to various
evolved, it shows a take on the fact that full stack development is applications for a website.
not dead and has just evolved to better accommodate the user's
needs. A. Front-end Development
Front-end development is how design gets implemented on
A. Keywords the web. The pages of a website are a sum of layers—structure,
Full Stack Development, Cloud Computing, Networking Model, data, design, content, and functionality. In other words, Front-
Full Stack Developer, Front-end Development, Back-end
end is the part of the website where users can see and interact
Development, Stack, Cloud, API, Development
with the graphical user interface (GUI) and the command line
B. Abbreviations and Acronyms which includes the design, navigation menus, texts, images,
Graphical User Interface(GUI), Hypertext Markup Language videos, etc.
(HTML),Cascading Style Sheets (CSS), Syntactically Awesome
Style Sheet (SASS), Application Program Interface (API), Personal Some of the Front-end Languages include HTML, CSS,
Home Page(PHP), Representational State Transfer (REST), JavaScript, etc. and some of the Front-end Frameworks and
Transmission Control Protocol/Internet Protocol (TCP/IP), Libraries include AngularJS, React.js, jQuery, SASS, etc. [1]
Hypertext Transfer Protocol (HTTP), Open System’s
Interconnection (OSI), Linux, Apache, MySQL, PHP (LAMP), B. Back-end Development
Windows, Apache, MySQL, PHP (WAMP), Cross Platform, Back-end Development refers to server-side development.
Apache, MariaDB, PHP, Pearl (XAMPP), International
Organization for Standardization (ISO), Hypertext Transfer
It is the term used for the behind-the-scenes activities that
Protocol Secure (HTTPS), Transmission Control Protocol (TCP), occur when performing any action on a website.
User Datagram Protocol (UDP), Address Resolution Protocol In other words, it is the portion of software that does not come
(ARP), Media Access Control (MAC), Logical Link Control (LLC) in direct contact with the users. Users indirectly access the
, Operating System (OS), File Transfer Protocol (FTP), Structured parts developed by Back-end designers through a Front-end
Query Language (SQL), Damn Vulnerable Web Application application. Activities, like writing APIs, creating libraries and
(DVWA) , Asynchronous Java Script and XML (AJAX), Extensible
Markup Language (XML), Domain Naming System (DNS),
working with system components without user interfaces are
Software as a service (SaaS), Platform as a Service (PaaS), some examples of Back-end development.
Infrastructure as a service (IaaS), Internet Protocol (IP), Virtual
Local Area Network (VLAN), Uniform Resource Locator (URL), Some of the Back-end Languages include PHP, Java, C++,
Client Uniform Resource Locator (cURL), Java Script Object Python, JavaScript, Node.js, etc., And some of the Back-end
Notation (JSON), User Interface (UI), Development and Operation Frameworks include Express, Django, Rails, Laravel, Spring,
(DevOps), Relational Database Management System (RDBMS),
Continuous Integration (CI), Continuous Delivery (CD) etc.
Some more commonly Back-end program/scripting languages
I. INTRODUCTION are C\#, Ruby, REST, GO etc. [2]
Full stack development is a part of web development which
broadly refers to the tasks associated with developing websites III. NETWORKING MODELS
for hosting via intranet or internet. It is the development of a
complete application both the front end, which we refer to as Networking models are communication models and it is
the client-side, and back-end the server-side. Due to the necessary to understand the construction and architecture of
introduction of cloud computing there have been drastic these models. They establish a connection between the sender
changes in the field of Full Stack Development and how it has and the receiver that helps in transmission of data. When the
affected the development. Cloud Computing consists of various protocols and the functions are competent communication
services and has many advantages. occurs. In networking models, we refer to the individual pieces
of the assembly as layers and the collection as a stack.
II. WEB DEVELOPMENT A. Protocol Model
Web Development is the process of building websites for This model closely matches the structure of a particular
the internet or for a private network which is also known as the protocol suite. A protocol suite includes the set of related

IJERTV9IS040016 www.ijert.org 7
(This work is licensed under a Creative Commons Attribution 4.0 International License.)
Published by : International Journal of Engineering Research & Technology (IJERT)
http://www.ijert.org ISSN: 2278-0181
Vol. 9 Issue 04, April-2020

protocols that typically provide all the functionality required for  3 - Network Layer: Routes the data, sends it to the
people to communicate with the data network. The TCP/IP correct destination by checking each piece of data, also
model is a protocol model because it describes the functions maps the destination address to the physical address
that occur at each layer of protocols within the TCP/IP suite. achieved by the ARP.
B. Reference Model  2 - Data Link Layer: It is Complex and Checks for faults
This type of model describes the functions that must be in transmission from the physical layer and then
completed at a particular layer but does not specify precisely converts the data into data frames, which is of 4 parts.
how a function should be accomplished. A reference model is Physical addressing occurs constitutes of MAC and
not intended to provide a sufficient level of detail to define LLC.
precisely how each protocol should work at each layer. The  1 - Physical Layer: This layer usually consists of
primary purpose of a reference model is to aid in a clearer network cables, ports, repeaters, transmitters, etc. Here
understanding of the functions and processes necessary for digital data bits are either received or transferred by the
network communications. respective physical layer devices. It can be of the form
C. TCP/IP Model mechanical, electrical or radio.
The first layered model for communications within a E. Differences between TCP/IP and OSI Network Model
network was created in the early 1970s and is referred to as the OSI follows a vertical approach, whereas TCP/IP follows
Internet model. The TCP/IP model describes a set of general
a horizontal approach. In the OSI model, the transport layer, is
design guidelines and implementations of specific networking
protocols to enable computers to communicate over a network. only connection-oriented, whereas in the TCP/IP model it is
TCP/IP provides end-to-end connectivity specifying how data both connection-oriented and connectionless.
should be formatted, addressed, transmitted, routed and
received at the destination. [3] IV. WEB STACK
1) Layers of TCP/IP model A web stack, also called a web application stack, is a
compilation of a software setup especially for implementing
i. Application Layer: Represents data websites and web applications. The collection of layers is
to the user, plus encoding and known as a stack. The term, 'stack', refers to the fact that the
dialogue control. system's components are built upon one another. The basic
ii. Transport Layer: Supports requirements necessary to construct a web stack include an
communication between across operating system, a web server, a database, and a script
diverse networks. interpreter. Together with the proper server hardware, this
bundle of components ensures that necessary information
iii. Internet: Determines the best path about similar web projects is forwarded to requesting clients
through the network.
which is generally the internet browser. [5]
iv. Network Access: Controls the
hardware devices and media that
make up the network. A. A few types of Web Stacks
A LAMP Stack is one of the examples of a web stack, it is
D. OSI Network Model a set of open-source software that can be used to create
The OSI model is a conceptual model which has been websites and web applications. The LAMP stack was the first
developed by ISO, in the year 1984.It aids in understanding followed by various other stacks. Due to the steadily increasing
what is occurring within a networking system; in this system, progress of this technology and the development of new
data is transferred to and fro within adjacent layers. The OSI freeware, different variations of LAMP stacks have arisen.
Model consists of 7 Layers, and they are typically described Some famous examples include:
from the top layer down. OSI stands for Open Systems 1. WAMP (Windows as an operating system)
Interconnection. The OSI Model consists of 7 Layers, and they 2. MAMP (Mac OS X as an operating system)
are typically described from the top layer down. It aids in
3. XAMPP (any operating system, Perl and PHP as
understanding what is occurring within a networking system; in
this system, data is transferred to and fro within adjacent layers. script interpreters; platform-independent FTP
[4] server)
XAMPP is the most commonly used web stack.
 7 - Application Layer: This This layer provides the Linux supported a MySQL database and has now shifted to
networking protocols to the end-user like HTTP and MariaDB, which does not support SQL Injection attacks via
HTTPS. DVWA.
 6 - Presentation Layer: Converts data from one form to
another and evaluates the syntax. V. THE NEW ERA OF WEB 2.0

 5 - Selection Layer: Responsible for connection, re- A. Before the new era
connection, and authentication. Initially companies usually preferred a full-stack developer
and not specialist. A full-stack developer is the one who is both
 4 - Transport Layer: Transmission of data to different fluent in Front-end and Back-end development. A
network connections speed, amount, etc. Implemented specialization would mean the person is either impeccable in
using TCP and UDP.

IJERTV9IS040016 www.ijert.org 8
(This work is licensed under a Creative Commons Attribution 4.0 International License.)
Published by : International Journal of Engineering Research & Technology (IJERT)
http://www.ijert.org ISSN: 2278-0181
Vol. 9 Issue 04, April-2020

developing the Front-end or the Back-end. Companies usually A. Advantages of Cloud Computing
went for full-stack development, but the time taken by the Cloud computing solves significant problems in business.
specialists would be lesser than that of a team consisting of only Obtaining many perks through cloud computing is becoming
full-stack developers. To back this statement up let us consider
the new normal. [10]
the productivity to be 1 unit for one instance of time for a Full
Stack Developer now consider the total productivity required is 1. You pay what you use: While using cloud
four units, then it would require four instances of time. Whereas computing services, you only pay for the services
for a specialist, let us consider two units of productivity per you use, which makes it more cost-efficient
instance then to reach four units, it would take a less amount of 2. Flexibility: As your business progresses the scale
time and hence is more efficient. In case any discrepancies of the data to be handled increase or decreases
occur while the connection of the Back-end to the front you cloud services provide to change your cloud
could add another instance which would still be faster. capacity at anytime.
Therefore, the efficiency, η, and approximate the time taken to 3. Backups/data recovery: For small scale businesses
finish the project, Tp are defined by the following models it is difficult to set up a data recovery systems but
(Equation 5.1 & Equation 5.2).
cloud computing provides data recovery option
𝑃 𝐷
𝜂 = ∗ 100 −   which avoids a substantial investment.
𝐿 100
4. Mobile Connect: One of the essential features of
𝐿
𝑇𝑝 =   cloud computing is you can work from anywhere.
𝑃
5. Security: When it comes to data, security always
in which P is productivity per unit time, L is the minimum comes under consideration as every user wants
productivity units to be reached, and D is the number of their data to be secure. The cloud service providers
discrepancies (if any).
provide the security of data, and the data in the
The productivity per unit time can be calculated using the cloud is more secure compared to storing the data
Labor Productivity Formula (Equation 5.3). [6] in hard drives because loss of sensitive data for
small scale business having insufficient funds to
𝑇𝑜
𝑃=   secure data from hackers and breaches would be
𝑇𝑖
disastrous.
in which To is Total Output and Ti is Total Input. 6. Website management: Cloud computing features
include data management and analytics. It gives
you the ability to manage DNS servers, web
B. After the new era services etc. [11]
Due to the introduction of AJAX support, a new era began
the WEB 2.0 consisting of XMLHttpRequest which refers to
data transfer between a web server and a browser.[7] It B. Cloud Service Models
involved much tedious work, and no single developer could 1. Software as a service (SaaS): In SaaS, cloud
know everything there is to be known, the introduction of new providers manage the infrastructures and platforms
technology involved drastic changes in terms of designing and that run the cloud. There is no necessity to install the
the concepts involved in web development. As several changes software in the user’s system as the cloud provides
were being introduced in both the fields of Front-end and everything. As the software is not running on the
Back-end, as a result, it became difficult 6 for individuals to user’s system there is no need to invest in hardware
expertise oneself in all these fields. Thus full-stack developers reducing the cost.
are no longer present as it is very laborious, hence companies 2. Platform as a service (PaaS): Here the user has control
usually hire a team of specialists. Here each team member must over applications and configuration settings for the
be efficient in more than two layers of web development. The application environment including network, servers,
one having multiple skills are usually assigned to lead. [8] OS and storage.
3. Infrastructure as a service (IaaS): IaaS refers to an
online service which provides high-level API. It also
VI. CLOUD COMPUTING offers containerization which gives higher
In former times there was only one option to store, manage performance than virtualization as there is no hyper
and process the data that was via maintaining local servers or visor involved in it. The capacity of containers auto-
personal computers. However, due to modern advancement in scales dynamically making you pay only for what you
computing techniques, we are now able to manipulate data use. It also provides additional resources like
over the internet. This tradition of storing, processing and firewalls, object storage, IP addresses, VLANs etc.
managing data over the internet is called cloud computing. [9]
Some of the famous companies that provide cloud computing C. The advancement of Web development due to cloud
services include The development of technology allowed us to meet the user's
needs better, and thus we turned to the cloud.
 Due to an increase in the number of concurrent
users, load balancers were developed, they

IJERTV9IS040016 www.ijert.org 9
(This work is licensed under a Creative Commons Attribution 4.0 International License.)
Published by : International Journal of Engineering Research & Technology (IJERT)
http://www.ijert.org ISSN: 2278-0181
Vol. 9 Issue 04, April-2020

distribute application traffic amongst servers to Using endpoints repositories can be


prevent crashing. [12] accessed easily. Repositories consist of
 Physical servers were switched to cloud-based packages. JSON is a scripting language
servers which provided much more flexibility, on- which is used to send and request data using
the-go payment approach, zero maintenance etc. a REST API.
Before we talk about cloud-based servers, one must b. Method - The method defines a type and
understand cloud computing which is the gives meaning to the request there are five
availability of computer resources, both hardware different types of methods the most common
and software on demand. being POST. They perform operations like
 The application developed was now to be reached create, read, update and delete.
to a global scale for better profits, and this was i. Get - It returns the requested
information as in ’read’, it is also
made possible via data centers in several regions. the default method.
However, now with the cloud, this is far easier as ii. Post - It creates a new entry as in
you do not have to set up your centers. ’create’.
 Schema’s and Joins were not that adequate. Hence, iii. Put - It updates an existing entry as
key-value stores were used which are virtually in ’update’.
databases consisting of an array of keys, each iv. Delete - It deletes an existing entry
as in ’delete’.
representing one value these are similar to
dictionaries found in Python programming c. Headers - These are separated by a colon and
language. tell where to find the JSON file. They are
 In order to improve quality regression, test suites usually used in commands for the command
were developed which check if the application is line.
still functioning after new changes have been d. Data - It consists of information to be
applied to it. Regression test suites have become a retrieved from the server. [14]
necessity. [13] As the user’s demand and interests peaked the UI began
to develop, the interaction was improved to make it more user
friendly, in order to achieve this specialized people in the
D. Some Cloud Services that led to optimization respective fields were hired. Later mobile application versions
were introduced for further convenience of the users.
1. REST APIs Several developments were made to the programming
APIs: It provides rules as to how programs should languages itself.
interact. REST: It is generally considered as a type of a. HTML - Semantic web was added, which
software architecture consisting of a set of rules to be allowed the internet data to be machine-
followed when developing an API. readable.[15] Service Workers were added,
The primary purpose is to get a response from a which helped in developing web applications
specific destination when a request is made. When a URL offline.[16]
is entered, we request for that page to appear. If the request b. CSS - It was updated to add transitions,
is apt, we get the GUI as the response. A Request is a animations and other features to improve
complex process which occurs within short amounts of interactivity.
time, and are also calculated in the form of Performance c. JavaScript - Various features like
Problems. It consists of four parts. modularization, object-oriented classes,
a. Endpoint - It is the route through which you asynchronous functions and interoperability
get a response. Starting with the root were added.
endpoint, which is the beginning of the d. HTTP - Better caching, security measures and
URL, which points to the index and the path tenacious sessions.
of the URL determines the response
required. In the URL path, if there is a colon 2. DevOps
present, it refers to a variable that is to be DevOps is a process that is an amalgamation of 2
changed accordingly. The final part of an main processes which are software development (Dev)
endpoint is Query parameters which usually and technology operations (Ops). The main aim of the
begin with a question mark and are written DevOps cycle is to shorten the software development life
using SQL. Each parameter is separate by cycle while providing continuous delivery where the
because spaces are invalid in an URL. Using teams work in short intervals which ensures the software
Query Parameters SQL Injections are also is being developed reliably in a way the delivery happens
performed. Although Query Parameters are in a very smooth process. Another advantage of the
technically not related to APIs, it is worth DevOps cycle is the fact that it also maintains high
mentioning. In order to test endpoints software quality throughout the development cycle, which
command-line utilities are used there are is evaluated on two parameters. The first parameter is the
several of them available, but the most software’s functional quality which checks if the
common when coming to APIs is cURL. functional requirements which were defined initially have

IJERTV9IS040016 www.ijert.org 10
(This work is licensed under a Creative Commons Attribution 4.0 International License.)
Published by : International Journal of Engineering Research & Technology (IJERT)
http://www.ijert.org ISSN: 2278-0181
Vol. 9 Issue 04, April-2020

been followed or not. The next parameter is the software’s VII. CONCLUSION
structural quality which verifies if the non-functional By incorporating all the parts, we can interpret what full
requirements, which support the functional requirements, stack was, how it has evolved and why has it evolved. The
have been met or not. The DevOps operation has the efficiency of workers can also be calculated and the
following functionality modes or the more accurate term approximation of time taken to complete a project, and finally
being “toolchains”. The toolchains have been listed people either see Full Sack Development to be dead or overrun.
below. However, it can be seen from the pretext that it has been
a. Coding - it involves code development and evolved and has been drastically optimized to meet the user’s
review of the code. needs.
b. Building - it involves continuous
integration with tools provided by the REFERENCES
project. [1] “Frontend vs Backend,” Jul. 2019. [Online].
c. Testing - it involves continuous testing of Available:https://www.geeksforgeeks.org/ frontend-vs-backend/
the project. [2] “What is Backend Developer? Skills to become a Web Developer.”
[Online]. Available: https://www.guru99.com/what-is-backend-
d. Packaging - it involves application and pre- developer.html
deployment procedures. [3] D. Gera, “TCP IP Layers and role in webpage request,” Nov. 2017.
e. Releasing - it involves application release [Online]. Available: http://lazyheap.com/tcp-ip-layers-role-webpage-
automation. request/
[4] R. Miller, “Sans institute information security reading room the osi
f. Configuring - it involves infrastructure as model: An overview,” 2020.
code tools. [5] “Web stacks: the basics and examples - IONOS.” [Online]. Available:
g. Monitoring - it involves discerning the https: //www.ionos.com/digitalguide/server/know-how/web-stacks-the-
basics-and-examples/
changes at the application for the end users [6] “How to Calculate Workplace Productivity.” [Online]. Available:
The most important parts of the DevOps toolchains are https://www.smartsheet. com/blog/how-calculate-productivity-all-
“continuous integration” and “infrastructure as a code” levels-organization-employee-and-software
which occurs in the building and the configuration part of [7] “XMLHttpRequest,” Mar. 2020, page Version ID: 946412782. [Online].
Available:
the code respectively. [17] https://en.wikipedia.org/w/index.php?title=XMLHttpRequest&oldid=9
46412782
3. NoSQL [8] J. Honton, “Full Stack Pronounced Dead,” Jan. 2020. [Online].
NoSQL, also known as Not only SQL, is a cloud Available: https://medium.com/better-programming/2020-001-full-
service that provides scalable storage, and data is stored in stack-pronounced-dead-355d7f78e733
the form of non-relational databases. This service has [9] “Cloud computing,” Mar. 2020, page Version ID: 947606168. [Online].
Available:
replaced the primitive system of RDBMS wherein SQL https://en.wikipedia.org/w/index.php?title=Cloud_computing&oldid=9
queries were required to access the data, and this data was 47606168
stored in a structured tabular form consisting of rows and [10] “10 Ways Cloud Computing Can Change Web App Development -,”
columns. NoSQL varies in multiple aspects when Apr. 2019. [Online]. Available: https://nimapinfotech.com/blog/ 10-
ways-cloud-computing-can-change-web-app-development/
compared to the traditional database management system [11] “How Cloud Computing Can Change Web App Development.”
in terms of performance, consistency, speed, ease of use, [Online]. Available:https://codecondo.com/cloud-computing-web-app-
availability, flexibility, cost, etc. [18] development/
[12] “Load Balancer.” [Online].
Some of the Famous NoSQL databases include Available:https://www.f5.com/services/resources/glossary/load-
MongoDB, Amazon DynamoDB, Redis, CouchDB, etc. balancer
[13] “Creating Regression Test Suites.” [Online]. Available:
4. Cloud Orchestration https://it.toolbox.com/blogs/craigborysowich/creating-regression-test-
Cloud orchestration is a service that is responsible for suites-071507
managing the interconnections among workloads on the [14] “Understanding And Using REST APIs,” Jan. 2018. [Online].
Available: https:
cloud infrastructure. It combines automated tasks into a //www.smashingmagazine.com/2018/01/understanding-using-rest-api/
cohesive workflow to accomplish a goal, with permissions [15] “Semantic Web,” Mar. 2020, page Version ID: 945184650. [Online].
omission and policy enforcement. Available:
https://en.wikipedia.org/w/index.php?title=Semantic_Web&oldid=945
Cloud orchestration procures, deploys, and starts servers, 184650
it acquires and assigns storage capacity manages [16] E. Sharma, “An Introduction to Service Workers in JavaScript,” Feb.
networking and can also be used to create virtual 2018. [Online]. Available: https://codeburst.io/an-introduction-to-
machines. [19] service-workers-in-javascript-27d6376460c2
[17] “DevOps,” Mar. 2020, page Version ID: 947885950. [Online].
5. CI/CD Available:
https://en.wikipedia.org/w/index.php?title=DevOps&oldid=947885950
Cloud Integration is a collection of tools and [18] G. Vaish,Getting Started with Nosql. Packt Publishing, 2013.
technologies that connects different system and [Online]. Available:https://books.google.co.in/books?id=oPiT-
environments. It deals with exchanging and processing V2eYTsC15
[19] “What is cloud orchestration (cloud orchestrator)? - definition from
data in real-time. Continuous Delivery and Continuous whatis.com.”[Online].Available:
Deployment are both uses for deployment where https://searchitoperations.techtarget.com/definition/cloud-orchestrator
Continuous Delivery is manual and Continuous
Development is automated.

IJERTV9IS040016 www.ijert.org 11
(This work is licensed under a Creative Commons Attribution 4.0 International License.)

View publication stats

You might also like