Skip to content

ServiceProxy is a .NET high performance asynchronous proxy that allows you to use service contracts with your favorite messaging framework.

License

Notifications You must be signed in to change notification settings

mfelicio/ServiceProxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ServiceProxy

Join the chat at https://gitter.im/mfelicio/ServiceProxy

ServiceProxy is a lightweight asynchronous proxy for .NET that allows you to use service contracts in a request/reply manner with your favorite messaging framework.

How does it work?

Client side

On the client side ServiceProxy creates interface proxies for your service contracts, intercepts all service requests, converts them to well defined messages and sends them using a messaging framework. The created proxies are cached for the next requests.

Server side

On the server side ServiceProxy handles the messages received from your messaging framework, resolves/invokes the real service implementation and sends the response back. It uses the service locator pattern to resolve services, so you may use any IoC container.

The first time a service call is made for a given contract, ServiceProxy generates, compiles and caches delegates that invoke your service operations and integrate seamlessly with the ServiceProxy request/reply interface. This means it is as fast as a direct method call to your services, since after the first execution no reflection will be done.

ServiceProxy doesn't require any configuration.

Want to know more? Read how ServiceProxy core components work.

Getting started

The quickest way to get started with ServiceProxy is by using the NuGet package. You may also use one of the bundled request/reply messaging frameworks available in the source code ServiceProxy.Redis and ServiceProxy.Zmq.

The latest stable version is 1.0.1. For more information, visit the Release notes page.

Why use ServiceProxy

Using ServiceProxy your code can be decoupled from the messaging framework you're using and from the ServiceProxy framework itself. If your code uses Dependency Injection and you use a modern IoC container, you can have your code depend on your service interfaces and have the IoC container create the proxies using the ServiceClientFactory. It doesn't intend to replace your messaging framework since ServiceProxy by itself has no messaging capabilities. It just has a simple and asynchronous request/reply model that is supposed to integrate seamlessly with any messaging framework. However, if you don't use one already you can give ServiceProxy.Redis and ServiceProxy.Zmq a try.

Contributing

You can contribute by creating a ServiceProxy.[YourFavoriteMessageBus] and submit your code to github. Make sure to make a reference to this project and I'll make sure it is listed here as well.

Examples

A complete WebAPI example using a service layer can be found here. If you would like to contribute with examples let me know.

Issues

If you find any issues please post them on the issues page.

Dependencies

ServiceProxy uses Castle.Core DynamicProxy internally to generate client side interface proxies.

License

ServiceProxy is licensed under the MIT license.

About

ServiceProxy is a .NET high performance asynchronous proxy that allows you to use service contracts with your favorite messaging framework.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published