Main  /  Edit version 2  /  Edit version 3  /   /  Users Area

Difference "Understanding Application Lifetime" ver. 2 versus ver. 3

Content:

<!--toc-->
## Introduction
CppCMS is designed for high performance and thus it "caches" anything possible. Same the application objects.
CppCMS has two core orthogonal concepts:
Before we begin, it is very important to distinct between two types of applications (classes derived from `cppcms::application`):
- **Applications** - classes derived from `cppcms::application` - the objects that define how the user application handles requests
- **HTTP Context** - `cppcms::http::context` - the context of the request, response, session sessions, cache and many other object connected to the specific Client-Application interaction.
1. **Synchronous applications** - the most common type of applications: the ordinary applications that are designed to handle normal request.
2. **Asynchronous application** - the special applications that are designed to handle multiple request and support long pooling.
On each incoming request the Context is created and it is associated with the Application class that handles it.
When the request and response are complete, the context
is destroyed and the application usually continues to
run.
CppCMS is designed for high performance, thus it "caches" anything possible. So it does for the application objects.
Before we begin, it is very important to distinct between two types of Applications:
1. **Synchronous Applications** - the most common type of applications: the ordinary applications that are designed to handle normal request.
2. **Asynchronous Application** - the special applications that are designed to handle multiple request and support long pooling.
## Synchronous Applications
### Single Application
Synchronous applications live in a pool. They are generated by a special `cppcms::applications_pool::factory` object
that is mounted to the [`applications_pool`](/cppcms_ref_v0_99/classcppcms_1_1applications__pool.html) object.
These object are long-living object and once they created
they are usually cached in the pool for future reuse.
Upon incoming request the application if fetched from the
pool or new one is created. The special `cppcms::http::context` object is assigned to the application during all request processing,
This request is processed in the thread pool by
calling the `application::main()` virtual function
that actually handles the request.
Once the request is complete, this context is unassigned
and the application is returned back to the pool
for future reuse.
So when your write your own applications, you may assume
that their constructors are not called frequently. You should also assume that they will "kept alive" for a long time.
It is good idea to cache some general non-mutable
information withing such object.
### Applications with Children
Each application can have multiple children applications, for example:
blog
admin
post_editing
options_editing
display
post
summary
feeds
atom
rss
Each child application can be connected to the parent
via [`add` or `attach`](/cppcms_ref_v0_99/classcppcms_1_1application.html) member functions
in the constructor. Each application shares its lifetime and its `cppcms::http::context` with its parent.
Even thou they are different object and different
classes they are tightly bounded and live
together as long as topmost-parent lives, `blog` in our case.
## Asynchronous Applications
### Lifetime
Unlike synchronous applications that have multiple
instances in the applications pool and are executed
in thread pool, asynchronous applications
are designed to handle multiple connections
simultaneously.
simultaneously, and thus instead of being called
in thread pool per each request, they run exclusively
in the main [CppCMS Event Loop](/wikipp/en/page/cppcms_1x_event_loop)
These applications live as long as their reference
counter is not 0. Once reference counter
goes to 0 the application is destroyed and automatically
unmounted from the applications pool.
So in order to keep asynchronous application alive
you need to do one of the following:
1. Keep a persistent `intrusive_ptr` smart pointer
pointer on the application, for example
in your `main()` function.
This is suitable for long running applications that
exist all the time the service is running.
2. Make sure that you have event handlers that hold
a smart pointer and waiting for the event.
This is usually done by passing `intrusive_ptr` withing
the event handler.
Such method is suitable for temporary
applications that may represent for example
different information channels like chat rooms
that may be created or destroyed
at some point.
When you have application hierarchy
### Asynchronous applications and their Children
Each asynchronous application and its children
share same reference counter. Thus if
children is attached or assigned to the parent
he shares with it its reference and, for example
passing a smart pointer the the children class
keeps the entire hierarchy alive.
Basically, similarly to the synchronous application
the parent and all its ancestors "born" and "die" together.
### HTTP Context handling
There is once context assigned to the asynchronous application. If the `cppcms::application::main()`
function completes while the context is still assigned,
it would be automatically detached and complete
response to the client.
In order to postpone the response, the context should
be manually detached from the application by calling
`cppcms::application::release_context()` function.
Now it is your responsibility to keep it as long
as you need and finalize the response by calling
`cppcms::http::context::complete_response()`

About

CppCMS is a web development framework for performance demanding applications.

Support This Project

SourceForge.net Logo

Поддержать проект

CppCMS needs You


Navigation

Main Page


Valid CSS | Valid XHTML 1.0