| Understanding the Architecture of a Repository |    | 
The main building block of a CDO repository is split into two layers, the generic repository layer that client applications interact with and the database integration layer that providers can hook into to integrate their data storage solutions with CDO. A number of such integrations already ship with CDO, making it possible to connect a repository to all sorts of JDBC databases, Hibernate, Objectivity/DB, MongoDB or DB4O.
While technically a CDO repository depends on EMF this dependency is not of equal importance as it is in a CDO application. In particular the generated application models are not required to be deployed to the server because a CDO repository accesses models reflectively and the model objects are not implemented as EObject EObjects on the server.
The following diagram illustrates the major building blocks of a CDO repository:
 
 All components of CDO are implemented as OSGi bundles. The core components of
 both clients and servers do not require OSGi to actually run to be functional, they can perfectly be operated
 stand-alone. If OSGi is running the setup and configuration of some CDO facilities is a little simpler than in
 stand-alone mode because the needed factories get automatically registered with the central
 wiring container.
 
 CDO utilizes an operations and maintenance framework to abstract common platform services such
 as logging, tracing, monitoring and configuration. Without the need to depend on additional external libraries these services integrate seamlessly
 with OSGi, if available at runtime, or emulate similar functionality if running stand-alone.
 The core of a CDO server consists of one or more repositories each of which, in turn, consists
 of several generic (network and storage independent) components, such as:
 
revision manager and cache,
 branch manager,
 registry,
 lock manager,
 session manager,
 commit info manager,
 query handler provider.
 In addition the following types of handlers can be hooked up with a repository:
Read access handlers,
 Write access handlers,
 Commit info handlers.
 
 All persistent aspects (the storage/retrieval of data in/from a database system) are fully abstracted
 through the service provider interfaces (SPI) IStore, IStoreAccessor and IStoreChunkReader.
 Concrete implementations are fully separated and can be plugged into the core as described in CDO Store.
 
 All communication aspects (the sending/receiving of signals to/from a network system) are fully abstracted
 through the service provider interface (SPI) ISessionProtocol. Concrete implementations are fully separated
 and can be plugged into the core as described in Protocol.
 A concrete storage adapter, an IStore implementation that operates on top of the generic server
 core. A number of such stores already ship with CDO, making it possible to connect a repository to all sorts of
 JDBC databases, Hibernate, Objectivity/DB, MongoDB or DB4O.
See Also:
 A concrete communications adapter, an ISessionProtocol implementation that operates on top of the generic
 server core. The only session protocol implementation that currently ships with CDO is based on
 Net4j Core.
 An IQueryHandler implementation that provides support for OCL queries by executing them at the generic repository level,
 i.e., independent of the concrete CDO Store being used.
 
The OCL component is optional.
 The Net4j Signalling Platform is an extensible client/server communications framework. Net4j eases the
 development of fast and maintainable application protocols that are independent of the
 physical transport medium. Transport protocols are pluggable and Net4j ships with support for
 TCP, SSL, WS and JVM
 (in-process) transport. The core of Net4j is a fast, asynchronous and non-blocking buffer
 multiplexing kernel, based on OSGi but also executable stand-alone.
See Also:
 A concrete transport adapter, an IAcceptor implementation that operates on top of the
 Net4j core. Net4j currently ships with IJVMAcceptor, ITCPAcceptor
 (optionally with SSL support) and IWSAcceptor.