JEE Core Concepts: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
Line 7: Line 7:
The possibility to change an application's behavior without changing code is a core concern in JEE. The entire Chapter 5 in the [[JEE#jsr_316|JEE specifications]] is dedicated to it.  
The possibility to change an application's behavior without changing code is a core concern in JEE. The entire Chapter 5 in the [[JEE#jsr_316|JEE specifications]] is dedicated to it.  


The essential mechanism than makes this possible is the ''application component environment'', also known as ''enterprise naming context (ENC)''. ENC is a JNDI naming context, accessible to and private for each application component.
The essential mechanism than makes this possible is the ''application component environment'', also known as ''enterprise naming context'' or ''ENC''. ENC is a JNDI naming context, accessible to and private for each application component.


The application code ''uses named entries'' in ENC to refer to configuration values and external resources. The names of those elements do not change in the code, and actual configuration values and external resource references are ''mapped'' to actual deployment environment specific actual values and resources during deployment.  
The application code uses ENC ''named entries'' to refer to configuration values and external resources. The names of those elements do not change in the code, and those names are mapped to deployment environment specific values and resources during deployment. The use of ''deployment descriptors'' is essential part of the mapping. The deployment descriptors act as a layer of indirection between code and the deployment environment, and provide the mappings mentioned above. The code does not change, but the deployment descriptors do.
 
The key element here is the use of ''deployment descriptors'', that act as a layer of indirection between code and the deployment environment, and provide the mappings mentioned above.

Revision as of 02:39, 7 April 2017

Internal

Changing Application Behavior without Changing Code

The possibility to change an application's behavior without changing code is a core concern in JEE. The entire Chapter 5 in the JEE specifications is dedicated to it.

The essential mechanism than makes this possible is the application component environment, also known as enterprise naming context or ENC. ENC is a JNDI naming context, accessible to and private for each application component.

The application code uses ENC named entries to refer to configuration values and external resources. The names of those elements do not change in the code, and those names are mapped to deployment environment specific values and resources during deployment. The use of deployment descriptors is essential part of the mapping. The deployment descriptors act as a layer of indirection between code and the deployment environment, and provide the mappings mentioned above. The code does not change, but the deployment descriptors do.