joomla is a model-view-controller web application. in this chapter, we are going to discuss about the architectural style of joomla. the following diagram shows the architecture of joomla.

the architecture of joomla contains following layers −
- database
- joomla framework
- components
- modules
- plugin
- templates
- web server
database − database is a collection of data and can be stored, manipulated and organized in a particular manner. the database stores the user information, content and many more required data of the site. it is used to store the administrative information to manage the joomla site. using joomla database layer, it ensures maximum flexibility and compatibility for extension.
joomla framework − framework is a collection of open source software, where the joomla cms is built. it is developed for more flexibility and breaks the framework into single modular packages which helps each package to develop more easily.
components − components are considered as mini applications. it consists of two parts i.e. administrator and site. whenever a page gets loaded, component is been called to render the body of main page. the administrator part manages different aspects of the component and the site part helps in rendering the pages when request is made by site visitor. components are main functional unit of joomla.
modules − modules is an extension which is used to render the pages in joomla. it is also used to display the new data from the component. it frequently looks like boxes such as login module. in joomla administrator the modules are managed by the module manager. it displays the new content and images when module is linked to joomla components.
plugin − this is also a kind of joomla extension, it is very flexible and powerful for extending the framework. it contains a bit of codes that is used to execute the particular event trigger. it is commonly used to format the output of a component or module when a page is built. the plugin function which are associated with event are executed in a sequence when a particular event occurs.
templates − template determines the look of the joomla website. there are two types of templates used i.e. front-end and back-end. the back-end template is used to control the functions by the administrator where-as the front-end template is a way to present the website to users. templates are easy to build or customize your site. it provides maximum flexibility to style your site.
web browser − it is a server where the user interacts. it delivers the web pages to the client. the http (hyper text transfer protocol) is used to communicate between the client and the server.