Skip to content

Architecture overview

mythz edited this page Jul 12, 2012 · 25 revisions

Ultimately behind-the-scenes ServiceStack is just built on top of a set of Raw ASP.NET IHttpHandler's. Existing config-encumbered and legacy ASP.NET providers and abstractions have been abandoned, instead we start afresh with simple and clean Caching, Session and Authentication providers, based on clean POCOs, supporting multiple back-ends that all work seamlessly with each other.

Server Architecture

ServiceStack Logical Architecture View

Client Architecture

ServiceStack's Message-based design allows us to easily support typed, generic and re-usable Service Clients for all our popular formats:

ServiceStack HTTP Client Architecture

Other benefits of all clients sharing the same interface include being hot-swappable at run-time without code changes and they're highly testable where the same unit test can also serve as an XML, JSON, JSV, SOAP Integration Test.

By promoting clean, endpoint-ignorant and dependency-free Service and DTO classes, your web services are instantly re-usable and can be hosted in non-http contexts as well. e.g. This is the client architecture when a built-in MQ Host is enabled:

ServiceStack MQ Client Architecture

Implementation

The entry point for all ASP.NET and HttpListener requests is in the ServiceStackHttpHandlerFactory whose purpose is to return the appropriate IHttpHandler for the incoming request.

There are 2 distinct modes in any ServiceStack application:

  1. AppHost Setup and Configuration - Only done once for all services. Run only once on App StartUp.
  2. Runtime - Run on every request: uses dependencies, plugins, etc. defined in the AppHost. Each new request re-binds all IOC dependencies to a new service instance which gets disposed at the end of each request.

The implementation of this can be visualized below:

ServiceStack Overview

After the IHttpHandler is returned, it gets executed with the current ASP.NET or HttpListener request wrapped in a common IHttpRequest instance.

The implementation of RestHandler shows what happens during a typical ServiceStack request:

ServiceStack Request Pipeline

Clone this wiki locally