Skip to main content

Importance of Facade Layer

I still remember that around mid 2013, I was arguing for the same concept of Facade layer in our application in my earlier company. I was unable to digest the importance of Facade layer, so I was of firm opinion that Facade layer is unnecessary and should not be used!!

After 3 years, today when I was working on some code I realized that if we would have used Facade layer in our application then my work would have been much simpler than what I was doing...

Structure of our application -


Controllers/CommandHandlers
                                                  | <----- Aspect execute at here
Service Layer
|
Accessor/DAO
|             |
DB      Server

This is the structure of our application, in which Service layer handles the gathering and processing of data from DB and server process.
We have a concept of MSU, where our application hosted of a central server gathers data from various servers and shows it on the centralized server. Now when call from controller or command handler goes to service layer, our custom Aspect comes into picture and performs the same operation for various servers mapped into our application.
Now this operation can be of four types -


  1. Local only
  2. Local or remote
  3. Local and remote
  4. Remote only
Depending upon the parameter configured in the Annotation aspect, this aspect executes this call of service layer on various servers.

Today when I was working on one of call, which has very heavy processing in service layer I remembered my discussion with one of my colleague or rather my oppose to the use of Facade layer in our application.
I realized that, it would have been very much beneficial if we would have had the following kind of structure of our application.

Controllers/CommandHandlers
                                                                    | <----- Aspect would have executed here
Facade Layer
|
Service Layer
|
Accessor/DAO
|             |
DB      Server
In this case it would have been so easy for our to intercept the facade calls and execute them on various servers without worrying about the heavy processing in the service layer. Well, I would like to also add the point which my colleague was telling me in this discussion, that Facade layer helps to write more testable code(I still do not agree fully on this point yet). 
But surely it helps to segregate the code from the service layer and controller layer which can be very helpful in situations like us.

Comments

Popular posts from this blog

Spring AOP : JDK Proxy vs CGLib Proxy

Spring framework is one of the most widely used framework in Enterprise application development. It has so many features such as Dependency injection, Data access integration, MVC, AOP which takes care of most of the boilerplate part of project, and developers can then focus on business logic only. One of the important feature in Spring is AOP. It is used by almost every enterprise application which is being developed using Spring. AOP So what is AOP? Definition of AOP - Aspect oriented programming is a programming paradigm which aims to increase modularity by allowing the separation of cross cutting concerns. Well, my understanding of AOP is - AOP allows us to introduce/join new modules in your project at pre-specified dynamic locations without having to code for it. Traditional examples of AOP is Transaction management, logging etc. You can read more about AOP at here . This article is for those who know AOP, have used AOP in their projects but do not know how Spring or o...

Notepad++ Compile and Run Java Programs

Notepad++ is a great file editor. It has many features. The most important feature which I like about Notepad++ is its light weight. It loads up so quickly, that's great. It also provides syntax highlighting for many languages. I use notepad++ to edit general files as well as my simple Java programs. Although notepad++ provides functionality to run external programs, I prefer NppJavaTools plugin to compile and run Java programs using notepad++. You can download NppJavaTools plugin from this page - NppJavaTools . Installation Installation of plugins in notepad++ is very simple process. All you have to do is copy plugin dll into plugins folder of notepad++ installation directory and restart the notepad++. Features This plugin provides following features, Compile and run your Java files within Notepad++ Set custom hotkeys for compiling and running Java Code Library support Compile and Run This function allows you to run your Java programs to compile and run from N...

Spring Custom Scope

Spring framework is one of the DI frameworks which is largely used to develop web applications(enterprise). It provides almost every feature which is required to develop a enterprise web application. Also it is extendable, so you can customize it the way it suits for your application. Custom bean scope Although bean scopes provided by Spring fulfills requirements of the application, some times you may need something different which is not available by default. In our application we faced the same situation. Requirement We had a requirement of the scope which uses an application value to decide which bean to use(return). The default scopes provided by Spring were not useful and was not providing the required functionality. Implementation As I said earlier, Spring is extendable. It provides an interface Scope, which you can implement to introduce custom scope in your application. To create custom scope, Scope interface needs to be implemented. Scope interface has ...