A demonstration of how you can integrate Python, ASP .NET and .NET services with EasyNetQ
JavaScript C# Python ASP CSS
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
DataWarehouseLibrary
DataWarehouseService
DataWarehouseTest
PiASP.NET
PiLibrary
PiPython
PiService
PiTest
.gitignore
EasyNetQDemo.sln
EasyNetQDemo.vsmdi
README.md
local.testsettings

README.md

EasyNetQDemo

A (hopefully) working demonstration that can show how EasyNetQ services can allow ASP.NET and Python applications to drink from the same firehose through the use of Enterprise Integration Patterns.

Running the Basic .NET Service

The .NET portion was written in VisualStudio 2010 and should open cleanly as a VisualStudio solution with four projects:

  • PiLibrary - POCOs that provide our data model as well as request/response message pairs
  • PiService - The business logic that calculates values for Pi. Very poorly. It will attach to RabbitMQ and respond to inbound requests.
  • PiTest - Because we're all loyal test-driven developers, this contains our unit tests for the endpoint
  • PiASP.NET - An ASP.NET web application that will allow a user to request a poorly calculated approximation of pi

The solution should build in both VisualStudio as well as Mono, however unit tests will only execute within VisualStudio.

To run the application, launch the PiService executable either as a stand-alone application or using the interactive debugger within VisualStudio. PiASP.NET can be deployed to IIS or run within VisualStudio's application server - just set the properties on the project likewise.

Running the Sample Wiretap

A demonstration of the wiretap pattern is also included, called "DataWarehouseService" to somewhat emulate a realtime ETL process. We extract from the stream of pi calculation requests, we transform it into a string and then we load it into the console... ;)

We have a similar layout for this service:

  • DataWarehouseLibrary - POCOs that provide our data model as well as request/response message pairs. It's currently empty; all messages are referenced from PiLibrary.
  • DataWarehouseService - The service that will attach to RabbitMQ and listen for pi calculation requests.
  • DataWarehouseTest - Also empty. No real business logic to test!

To run the application, launch the DataWarehouseService executable either as a stand-alone application or using the interactive debugger within VisualStudio.

Running the Python Bits

The folder PiPython contains all the code required, however the Bottle and Pika libraries should be installed within your Python environment. Once they are, executing:

python ./server.py

Should launch a Bottle instance and permit you to test things out. Point your browser to the URL echo'd out to the console when you launch the application, such as http://localhost:1080/pi/11 - and a message will be sent to your running PiService.