Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Architectural Patterns
Architectural Patterns

Architectural Patterns: Uncover essential patterns in the most indispensable realm of enterprise architecture

Arrow left icon
Profile Icon Murali Profile Icon Pethuru Raj Profile Icon J Profile Icon Pethuru Raj Chelliah
Arrow right icon
€8.99 €32.99
Full star icon Full star icon Half star icon Empty star icon Empty star icon 2.4 (5 Ratings)
eBook Dec 2017 468 pages 1st Edition
eBook
€8.99 €32.99
Paperback
€41.99
Subscription
Free Trial
Renews at €18.99p/m
Arrow left icon
Profile Icon Murali Profile Icon Pethuru Raj Profile Icon J Profile Icon Pethuru Raj Chelliah
Arrow right icon
€8.99 €32.99
Full star icon Full star icon Half star icon Empty star icon Empty star icon 2.4 (5 Ratings)
eBook Dec 2017 468 pages 1st Edition
eBook
€8.99 €32.99
Paperback
€41.99
Subscription
Free Trial
Renews at €18.99p/m
eBook
€8.99 €32.99
Paperback
€41.99
Subscription
Free Trial
Renews at €18.99p/m

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Table of content icon View table of contents Preview book icon Preview Book

Architectural Patterns

Client/Server Multi-Tier Architectural Patterns

This chapter provides a bird's eye view of client-server architectural patterns. It starts with the need for the evolution of two-tier client-server patterns and highlights how the limitations of two-tier client-server patterns led to the evolution of three-tier and consequently n-tier client-server patterns. The different variants of client-server patterns like the master-slave pattern, peer-to-peer patterns, and so on are also explained in-depth with relevant use cases. The second part of the chapter focuses on web application frameworks. The requirements of web applications are different from that of client-server applications, the key differentiating factor being the dynamic updates to the UI based on the changes in the underlying data. All the popular patterns used in web application design are covered in this part of the...

Domain name service (DNS) server and DNS client

DNS is one of the most important services that is present on the internet. An internet has thousands of devices that are a part of it and each of these devices is referred to as a host. Each host could be a printer, router, computer, or any other device. Each host has a unique IP address associated with it. Apart from the IP address, each host also has a unique hostname associated with it. For example, if the hostname is LP471 and it is present in a domain technest.com, then the fully qualified domain name (FQDN) of the host is LP471.technest.com. The FQDN is used to identify the host uniquely within the DNS namespace. The DNS namespace contains some commonly used name suffixes; they are as follows:

  • .com: Commercial organizations
  • .edu: Educational institutions
  • .gov: Government organizations
  • .org: Non-profit bodies like IEEE
  • .net...

Functional requirements in two-tier client-server patterns

The key functional requirements in two-tier client-server patterns are classified in the following table:

Functional requirement

Description

Presentation services

Provides user interface and dialog control

Presentation logic

User interaction and validation of inputs

Business logic

Set of business rules that specify how data can be stored, created, and changed

Distribution service

Management of communication

Database logic

Data operations and manage integrity of data

Database services

Management of various attributes of a database transaction

File services

Operations on files and sharing of files

Distribution of functional requirements in a client-server pattern

...

The three-tier pattern / multi-tier pattern client-server

The following diagram represents a client-server interaction:

We will discuss some of the variants of client-server patterns in this section. Some of the prominent variants of client-server patterns are as follows:

  • The master-slave pattern
  • The peer-to-peer pattern

Let's discuss them in detail.

The master-slave pattern

The master-slave pattern is applied for designing a system if the system involves similar or identical computations that need to be performed repeatedly with separate set of inputs and context. The master-slave pattern offers support for fault tolerance and parallel computation.

The master-slave pattern is depicted in the following diagram:

...

Three-tier client-server architecture

The three tiers that are present in this architecture are as follows:

  • The presentation tier
  • The application or business logic tier
  • Data tier

The diagram depicting the three-tier client-server architecture is as follows:

In a three-tier architecture, the different layers are developed and maintained as different modules, sometimes on different platforms as well. The following are the functions of each layer:

  • Presentation tier: This is the first and topmost layer which is present in the application. This tier provides presentation services, that is presentation, of content to the end user through GUI. This tier can be accessed through any type of client device like desktop, laptop, tablet, mobile, thin client, and so on. For the content to the displayed to the user, the relevant web pages should be fetched by the web browser or other presentation...

The distributed client-server architecture

The n-tier client-server architecture used for the shopping cart web application, which is discussed in the earlier section, is an ideal example of a distributed client-server architecture. Distributed architectures typically have some kind of backend host components (such as Mainframe, Database server, and so on), an intelligent client in the frontend, and multiple agents in the middle, which takes care of all activities pertaining to transactions like transaction processing, security, handling messages, and so on, and a network for communication.

Some of the key concepts associated with distributed architectures are as follows:

  • Transaction processing: Transaction processing is the automated processing of transactions in order to update a shared database. A transaction processing application in general will have many users who are...

Motivation for development of web application patterns

Most of the web applications are highly interactive in nature. This means that when there is a change to the data, it should be reflected in the UI instantaneously without any further delay. To add on to this scenario, different users of the application may demand outputs in various formats like excel sheets, bar charts, pie charts, dashboards, and so on, as depicted in the following diagram:

When there is a change in the functionality of a specific application, the user interface of the application should also be able to reflect the changes with the addition of new options like menus, dropdowns, and so on. This emphasizes the fact that user interfaces of web applications are always subjected to series of change requests. These user interfaces (UIs) change requests can happen in various circumstances, as follows:

  • A request...

The ASP.Net framework

In ASP.Net, the patterns for the view component and the controller component are well-defined. Only the pattern for the model component is left to be designed by the developer as per the specific application requirements.

View: The files that handle the responsibilities associated with the view component are ASPX and ASCX. In this design, the view object typically inherits from the controller object.

Controller: The responsibilities of the controller component are split among two components. The generation and passing of events is done by the framework and, to be more specific, is done by the Page and Control classes. The event handling is taken care of by the code-behind class.

Model: ASP.NET does not necessarily require a model. It is left to the choice of the developer whether to create a model class, or to forgo it. In case a model is not used,...

Design patterns for web application development

Apart from the MVC, MVP, and MVVM architectural patterns, which were discussed in the previous sections, there are several design patterns that are used for the design of applications along with these patterns. In this section, we will discuss some of the commonly used design patterns for web application design. These patterns and their functionalities are described in the following table:

Pattern name

Functionality

Interpreter design pattern

This pattern is widely used in the development of menus for applications like editors and Integrated Development Environments (IDEs). This pattern works by interpreting instructions that are written in the form of a language grammar or as notations. This pattern involves the implementation of an expression interface, which is used to interpret a given context.

Mediator design...

Summary

In this chapter, we started the discussion with a two-tier client-server pattern. This is one of the earliest and oldest client-server patterns. With the growth of the information technology industry, this two-tier client server pattern was not sufficient to meet the infrastructure requirements. This led to the evolution of the three-tier client-server pattern followed by n-tier client-server pattern. Some other variants of the client-server pattern like the master-slave pattern, peer-to-peer pattern, and so on were also discussed in this chapter. The applications and the design considerations for each type of pattern was also discussed in this chapter.

Web application development, which caught steam later could not use client-server architecture because of its inherent limitations. This led to the evolution of some patterns that were custom-made for the development of...

Left arrow icon Right arrow icon

Key benefits

  • Use patterns to tackle communication, integration, application structure, and more
  • Implement modern design patterns such as microservices to build resilient and highly available applications
  • Choose between the MVP, MVC, and MVVM patterns depending on the application being built

Description

Enterprise Architecture (EA) is typically an aggregate of the business, application, data, and infrastructure architectures of any forward-looking enterprise. Due to constant changes and rising complexities in the business and technology landscapes, producing sophisticated architectures is on the rise. Architectural patterns are gaining a lot of attention these days. The book is divided in three modules. You'll learn about the patterns associated with object-oriented, component-based, client-server, and cloud architectures. The second module covers Enterprise Application Integration (EAI) patterns and how they are architected using various tools and patterns. You will come across patterns for Service-Oriented Architecture (SOA), Event-Driven Architecture (EDA), Resource-Oriented Architecture (ROA), big data analytics architecture, and Microservices Architecture (MSA). The final module talks about advanced topics such as Docker containers, high performance, and reliable application architectures. The key takeaways include understanding what architectures are, why they're used, and how and where architecture, design, and integration patterns are being leveraged to build better and bigger systems.

Who is this book for?

This book will empower and enrich IT architects (such as enterprise architects, software product architects, and solution and system architects), technical consultants, evangelists, and experts.

What you will learn

  • Understand how several architectural and design patterns work to systematically develop multitier web, mobile, embedded, and cloud applications
  • Learn object-oriented and component-based software engineering principles and patterns
  • Explore the frameworks corresponding to various architectural patterns
  • Implement domain-driven, test-driven, and behavior-driven methodologies
  • Deploy key platforms and tools effectively to enable EA design and solutioning
  • Implement various patterns designed for the cloud paradigm

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Dec 22, 2017
Length: 468 pages
Edition : 1st
Language : English
ISBN-13 : 9781787288348
Category :

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Product Details

Publication date : Dec 22, 2017
Length: 468 pages
Edition : 1st
Language : English
ISBN-13 : 9781787288348
Category :

Packt Subscriptions

See our plans and pricing
Modal Close icon
€18.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
€189.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts
€264.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total 120.97
Embedded Systems Architecture
€36.99
Software Architect’s Handbook
€41.99
Architectural Patterns
€41.99
Total 120.97 Stars icon
Banner background image

Table of Contents

12 Chapters
Demystifying Software Architecture Patterns Chevron down icon Chevron up icon
Client/Server Multi-Tier Architectural Patterns Chevron down icon Chevron up icon
Object-Oriented Software Engineering Patterns Chevron down icon Chevron up icon
Enterprise Integration Patterns Chevron down icon Chevron up icon
Domain-Driven Design (DDD) Principles and Patterns Chevron down icon Chevron up icon
Enterprise Architecture Platforms and Tools Chevron down icon Chevron up icon
Service-Oriented Architecture (SOA) Chevron down icon Chevron up icon
Event-Driven Architectural Patterns Chevron down icon Chevron up icon
Microservices Architecture Patterns Chevron down icon Chevron up icon
Patterns for Containerized and Reliable Applications Chevron down icon Chevron up icon
Software-Defined Clouds - the Architecture and Design Patterns Chevron down icon Chevron up icon
Big Data Architecture and Design Patterns Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Half star icon Empty star icon Empty star icon 2.4
(5 Ratings)
5 star 0%
4 star 0%
3 star 60%
2 star 20%
1 star 20%
Integra99 Jan 27, 2018
Full star icon Full star icon Full star icon Empty star icon Empty star icon 3
The book did cover a number of softawre architecture patterns, including microservice, event-driven, cloud, and big data related patterns. I did find some of the text to be overly wordy. For example, the first chapter of the book includes the following:"It is going to be the software-defined, digitization-enabled, cloud-hosted, context-aware,service-oriented, event-driven, and people-centric era. It is a well-known and widelyaccepted truth that reactive and cognitive software plays a very vital role in shaping up theprojected and pronounced era of knowledge-filled and insight-driven services andapplications. That is, we need highly responsive, reliable, scalable, adaptive, and securesoftware suites and libraries to fulfill the identified goals for the forthcoming era ofknowledge."
Amazon Verified review Amazon
Michael James Mar 01, 2018
Full star icon Full star icon Full star icon Empty star icon Empty star icon 3
I agree with other customer comments. Way too verbose! Here is an example..."With our manufacturing floors, retail stores, warehouses, airports, railway stations, and bus bays, multi-specialty clinics, shopping complexes, malls and hypermarkets, auditoriums and stadiums, entertainment centers and cinema theaters, food joints, and so on..."I've only got through the first chapter, but the chapter is littered with these types of examples. The content seems good so far, but reading these long sentences is very annoying.
Amazon Verified review Amazon
Big Kahuna Jan 02, 2018
Full star icon Full star icon Full star icon Empty star icon Empty star icon 3
This was well intended, but I felt like some of it was just boilerplate. For example, in the chapter on microservices, there is paragraph upon paragraph that restates what had just been said on the page prior. It is also "verbose". For example..."Any tangible thing in our midst is internally as well as externally empowered in time to proactively and preemptively act on all kinds of noteworthy events.", lol.Lastly, I found some things that were almost direct rips from blogs I had recently read on the internet. The author's name on the blog was different from the authors of the book, but perhaps there is some relationship.I really don't think this is worth $40, but if you can get it cheaper, it covers a lot. The real issue is working your way through the boilerplate. If you can do that, it is at least everything in one place.
Amazon Verified review Amazon
ANDY Jul 24, 2019
Full star icon Full star icon Empty star icon Empty star icon Empty star icon 2
Although a lot of content, it feels like a lack of detail in key areas. SO MANY TITLES, make it hard to follow material as there appears to be no in-text hierarchy of titles beyond chapter level so you have no idea if your beginning a new main topic, sub topic or just a new point. By 300 pages, all content as merged into one with little to reference but titles with no numeric ordering.
Amazon Verified review Amazon
ian rust Dec 03, 2022
Full star icon Empty star icon Empty star icon Empty star icon Empty star icon 1
As I glanced through the table of contents I got very excited. Even prior to reading it I almost wanted to give the book a 5 stars review based on its content alone. But then I actually started reading the book.a) the authors are very bad at writing. It reads very much like they wrote the book, then went back and opened up a thesaurus... and replaced all the words with synonyms and near-rhymes. It's not that the words used are too big and confusing. In replacing all the words with thesaurus words the words are actually used incorrectly, and the meaning has been thrown off.b) the coverage of the various topics is completely shallow and useless. My honest opinion is I don't believe the authors even understand the content they're discussing, I think they were probably given a list of topics to discuss and they just quickly googled some of them and scrapped a paragraph together. It reads like a school paper that you would write 4 hours before the deadline. The thoughts do not flow together, there is no depth at all, in many cases you can't even make out what they're trying to say. It is absolutely horribly done.Many of the sentences are copied word for word from wikipedia, other books on the topic (which I knew because I'd read them), random websites (the first to show up on google when you search the topic), etc.. Just further evidence that the authors threw together some sentences quickly and had no idea what they were saying. Honestly the authors didn't deserve to be paid for writing this book, I could write a better book and I don't even know all this stuff.The best thing about this book, by far, is the table of contents. It's thorough and covers all the essential topics of architectural design patterns. You will not be able to glean any useful information out of this book. But what you could do is go through the table of contents & buy the respected books on these various topics. Then you'll be covering all your bases, and you'll be getting content written by people who know what they're talking about.I buy alot of books, very rarely do I give a book this bad of a review. I can only think of 2 other books out of about a hundred that I've reviewed this badly. The fact Packt actually published this, along with a few other experiences I've had with Packt, makes me very hesitant to buy Packt books in the future.Just absolutely lackluster.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

How do I buy and download an eBook? Chevron down icon Chevron up icon

Where there is an eBook version of a title available, you can buy it from the book details for that title. Add either the standalone eBook or the eBook and print book bundle to your shopping cart. Your eBook will show in your cart as a product on its own. After completing checkout and payment in the normal way, you will receive your receipt on the screen containing a link to a personalised PDF download file. This link will remain active for 30 days. You can download backup copies of the file by logging in to your account at any time.

If you already have Adobe reader installed, then clicking on the link will download and open the PDF file directly. If you don't, then save the PDF file on your machine and download the Reader to view it.

Please Note: Packt eBooks are non-returnable and non-refundable.

Packt eBook and Licensing When you buy an eBook from Packt Publishing, completing your purchase means you accept the terms of our licence agreement. Please read the full text of the agreement. In it we have tried to balance the need for the ebook to be usable for you the reader with our needs to protect the rights of us as Publishers and of our authors. In summary, the agreement says:

  • You may make copies of your eBook for your own use onto any machine
  • You may not pass copies of the eBook on to anyone else
How can I make a purchase on your website? Chevron down icon Chevron up icon

If you want to purchase a video course, eBook or Bundle (Print+eBook) please follow below steps:

  1. Register on our website using your email address and the password.
  2. Search for the title by name or ISBN using the search option.
  3. Select the title you want to purchase.
  4. Choose the format you wish to purchase the title in; if you order the Print Book, you get a free eBook copy of the same title. 
  5. Proceed with the checkout process (payment to be made using Credit Card, Debit Cart, or PayPal)
Where can I access support around an eBook? Chevron down icon Chevron up icon
  • If you experience a problem with using or installing Adobe Reader, the contact Adobe directly.
  • To view the errata for the book, see www.packtpub.com/support and view the pages for the title you have.
  • To view your account details or to download a new copy of the book go to www.packtpub.com/account
  • To contact us directly if a problem is not resolved, use www.packtpub.com/contact-us
What eBook formats do Packt support? Chevron down icon Chevron up icon

Our eBooks are currently available in a variety of formats such as PDF and ePubs. In the future, this may well change with trends and development in technology, but please note that our PDFs are not Adobe eBook Reader format, which has greater restrictions on security.

You will need to use Adobe Reader v9 or later in order to read Packt's PDF eBooks.

What are the benefits of eBooks? Chevron down icon Chevron up icon
  • You can get the information you need immediately
  • You can easily take them with you on a laptop
  • You can download them an unlimited number of times
  • You can print them out
  • They are copy-paste enabled
  • They are searchable
  • There is no password protection
  • They are lower price than print
  • They save resources and space
What is an eBook? Chevron down icon Chevron up icon

Packt eBooks are a complete electronic version of the print edition, available in PDF and ePub formats. Every piece of content down to the page numbering is the same. Because we save the costs of printing and shipping the book to you, we are able to offer eBooks at a lower cost than print editions.

When you have purchased an eBook, simply login to your account and click on the link in Your Download Area. We recommend you saving the file to your hard drive before opening it.

For optimal viewing of our eBooks, we recommend you download and install the free Adobe Reader version 9.