SlideShare a Scribd company logo
1 of 25
Distributed Application Development with NServiceBus David Boike www.make-awesome.com @DavidBoike Presentation and source: http://bit.ly/fOn4U9
Real-Life Example using (TransactionScopets = newTransactionScope()) { InsertOrUpdateAlertPreferences(); UpdateAlertEmails(); InternalWebService.UpdateEmailSettings(listID, 		emailAddresses); ts.Complete(); }
Real-Life Example – It Gets Worse using (TransactionScopets = newTransactionScope()) { InsertOrUpdateAlertPreferences(); UpdateAlertEmails(); InternalWebService.UpdateEmailSettings(listID, 		emailAddresses); ExternalWebService.UpdateSmsSettings(keyword, phoneNumber); ts.Complete(); }
NServiceBus to the rescue! Enterprise Service Bus for .NET Not a centralized broker like BizTalk Not a services communication framework like WCF Created by UdiDahan, internationally renowned expert on software architecture and design Focuses on messaging and publish/subscribe Ultra reliable Provides friction against poor architecture decisions
How it Works Utilizes assembly scanning for component discovery Uses marker interfaces to identify message schemas, message handlers, configuration sources, etc. Uses dependency injection (inversion of control) to detect and provide dependencies and services Everything is pluggable
App How an Endpoint Works MSMQ Transactional Receive
Transaction App How an Endpoint Works MSMQ Transactional Receive
Transaction How an Endpoint Works Perform database operations within the distributed transaction MSMQ DB App
Transaction How an Endpoint Works Or connect to a traditional web service MSMQ App Web Service
Transaction App How an Endpoint Works Send or publish additional messages MSMQ
Transaction Transient Errors If an exception happens, the transaction rolls back and returns the message to the queue. Transaction Rolling Back MSMQ Automatic retries are an integral part of the system. Exception App
Poison Messages After a configurable number of retries, poison messages get sent to an error queue. Transaction Rolling Back MSMQ Fix the underlying issue, and you can return error messages to their source queue. App Error
Real-Life Example - Revisited Webapp Bus.Send(new SaveAlertsCmd()); Alert Service Bus.Publish(new AlertsUpdatedEvent()); Subscriptions Bus.Subscribe<AlertsUpdatedEvent>(); Web Svc Adapter SMS Adapter
Getting Started Go to http://www.nservicebus.com Click the Download link Follow the instructions Be sure to run RunMeFirst.bat fromthe command prompt with admin rights! Installs and/or verifies MSMQ configuration Sets the appropriate settings on the Microsoft Distributed Transaction Coordinator Installs performance counters Run from the command prompt so you can see if there are any errors.
Let’s Build Something
In case you missed it… If you are watching the presentation live, the next several slides are apt to be very boring. Sorry. For those of you at home, this is what we did so you can follow along in the code samples.
Code Phase 1: Messaging Create MyMessages assembly Add reference to NServiceBus.dll Add CreateUserCmd
Code Phase 1: Messaging Create UserService assembly Add reference to NServiceBus.dll, NServiceBus.Core.dll, NServiceBus.Host.exe, and Log4Net Add IConfigureThisEndpoint, AsA_Publisher Add UserCreatorservice implementing IHandleMessages<CreateUserCmd> Add Start Action to run NServiceBus.Host.exe
Code Phase 1: Messaging Modify web project Add Global.asax, providing a global home for the web application’s IBus instance Modify Web.config with NServiceBus configuration Modify Register.aspx.cs to send the message
Code Phase 2: Saga/Verification CreateUserSagaData : ISagaEntity Copy properties from CreateUserCmd Add VerificationString property Change from service handling CreateUserCmd to saga started by CreateUserCmd Set saga data from command Override ConfigureHowToFindSaga, calling ConfigureMapping<CreateUserCmd>() method
Code Phase 2: Saga/Verification “Send” verification email Create SendVerificationEmailCmd Create mock handler that logs verification code to console Configure UserCreatorApp.config to send to the UserService (itself, although this could be a separate project) Send SendVerificationEmailCmd from the Handle<CreateUserCmd> method
Code Phase 2: Saga/Verification Verify the email Create VerifyEmailCmd in MyMessages Create UserCreatedEvent in MyMessages Add IHandle<VerifyEmailCmd> to saga and configure how to find saga data from this command Add implementation, actually creating user in DB MarkAsComplete(), log, and Bus.Return(0)
Code Phase 2: Saga/Verification Web handler for email link Create Verify.aspx Configure Web.config to send VerifyEmailCmd to UserService Change Register.aspx.cs redirect from Login to Verify
All caught up!
Where to learn more NServiceBus website: www.nservicebus.com My  blog: www.make-awesome.com Ask on Stack Overflow (tag with “nservicebus”) Udi’sblog: www.udidahan.com Andreas Ohlund’sblog: www.andreasohlund.net Jonathan Oliver’s blog: www.jonathanoliver.com Twitter: #NServiceBus Presentation Source Code: http://bit.ly/fOn4U9

More Related Content

Recently uploaded

Tales from a Passkey Provider Progress from Awareness to Implementation.pptx
Tales from a Passkey Provider  Progress from Awareness to Implementation.pptxTales from a Passkey Provider  Progress from Awareness to Implementation.pptx
Tales from a Passkey Provider Progress from Awareness to Implementation.pptx
FIDO Alliance
 
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptxHarnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
FIDO Alliance
 
Structuring Teams and Portfolios for Success
Structuring Teams and Portfolios for SuccessStructuring Teams and Portfolios for Success
Structuring Teams and Portfolios for Success
UXDXConf
 

Recently uploaded (20)

Tales from a Passkey Provider Progress from Awareness to Implementation.pptx
Tales from a Passkey Provider  Progress from Awareness to Implementation.pptxTales from a Passkey Provider  Progress from Awareness to Implementation.pptx
Tales from a Passkey Provider Progress from Awareness to Implementation.pptx
 
The Value of Certifying Products for FDO _ Paul at FIDO Alliance.pdf
The Value of Certifying Products for FDO _ Paul at FIDO Alliance.pdfThe Value of Certifying Products for FDO _ Paul at FIDO Alliance.pdf
The Value of Certifying Products for FDO _ Paul at FIDO Alliance.pdf
 
TopCryptoSupers 12thReport OrionX May2024
TopCryptoSupers 12thReport OrionX May2024TopCryptoSupers 12thReport OrionX May2024
TopCryptoSupers 12thReport OrionX May2024
 
ERP Contender Series: Acumatica vs. Sage Intacct
ERP Contender Series: Acumatica vs. Sage IntacctERP Contender Series: Acumatica vs. Sage Intacct
ERP Contender Series: Acumatica vs. Sage Intacct
 
Your enemies use GenAI too - staying ahead of fraud with Neo4j
Your enemies use GenAI too - staying ahead of fraud with Neo4jYour enemies use GenAI too - staying ahead of fraud with Neo4j
Your enemies use GenAI too - staying ahead of fraud with Neo4j
 
WebAssembly is Key to Better LLM Performance
WebAssembly is Key to Better LLM PerformanceWebAssembly is Key to Better LLM Performance
WebAssembly is Key to Better LLM Performance
 
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptxHarnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
Harnessing Passkeys in the Battle Against AI-Powered Cyber Threats.pptx
 
Linux Foundation Edge _ Overview of FDO Software Components _ Randy at Intel.pdf
Linux Foundation Edge _ Overview of FDO Software Components _ Randy at Intel.pdfLinux Foundation Edge _ Overview of FDO Software Components _ Randy at Intel.pdf
Linux Foundation Edge _ Overview of FDO Software Components _ Randy at Intel.pdf
 
Portal Kombat : extension du réseau de propagande russe
Portal Kombat : extension du réseau de propagande russePortal Kombat : extension du réseau de propagande russe
Portal Kombat : extension du réseau de propagande russe
 
Long journey of Ruby Standard library at RubyKaigi 2024
Long journey of Ruby Standard library at RubyKaigi 2024Long journey of Ruby Standard library at RubyKaigi 2024
Long journey of Ruby Standard library at RubyKaigi 2024
 
Intro in Product Management - Коротко про професію продакт менеджера
Intro in Product Management - Коротко про професію продакт менеджераIntro in Product Management - Коротко про професію продакт менеджера
Intro in Product Management - Коротко про професію продакт менеджера
 
Using IESVE for Room Loads Analysis - UK & Ireland
Using IESVE for Room Loads Analysis - UK & IrelandUsing IESVE for Room Loads Analysis - UK & Ireland
Using IESVE for Room Loads Analysis - UK & Ireland
 
Introduction to FIDO Authentication and Passkeys.pptx
Introduction to FIDO Authentication and Passkeys.pptxIntroduction to FIDO Authentication and Passkeys.pptx
Introduction to FIDO Authentication and Passkeys.pptx
 
Structuring Teams and Portfolios for Success
Structuring Teams and Portfolios for SuccessStructuring Teams and Portfolios for Success
Structuring Teams and Portfolios for Success
 
How we scaled to 80K users by doing nothing!.pdf
How we scaled to 80K users by doing nothing!.pdfHow we scaled to 80K users by doing nothing!.pdf
How we scaled to 80K users by doing nothing!.pdf
 
Choosing the Right FDO Deployment Model for Your Application _ Geoffrey at In...
Choosing the Right FDO Deployment Model for Your Application _ Geoffrey at In...Choosing the Right FDO Deployment Model for Your Application _ Geoffrey at In...
Choosing the Right FDO Deployment Model for Your Application _ Geoffrey at In...
 
1111 ChatGPT Prompts PDF Free Download - Prompts for ChatGPT
1111 ChatGPT Prompts PDF Free Download - Prompts for ChatGPT1111 ChatGPT Prompts PDF Free Download - Prompts for ChatGPT
1111 ChatGPT Prompts PDF Free Download - Prompts for ChatGPT
 
AI mind or machine power point presentation
AI mind or machine power point presentationAI mind or machine power point presentation
AI mind or machine power point presentation
 
2024 May Patch Tuesday
2024 May Patch Tuesday2024 May Patch Tuesday
2024 May Patch Tuesday
 
Design Guidelines for Passkeys 2024.pptx
Design Guidelines for Passkeys 2024.pptxDesign Guidelines for Passkeys 2024.pptx
Design Guidelines for Passkeys 2024.pptx
 

Featured

Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
 

Featured (20)

PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
 
12 Ways to Increase Your Influence at Work
12 Ways to Increase Your Influence at Work12 Ways to Increase Your Influence at Work
12 Ways to Increase Your Influence at Work
 
ChatGPT webinar slides
ChatGPT webinar slidesChatGPT webinar slides
ChatGPT webinar slides
 
More than Just Lines on a Map: Best Practices for U.S Bike Routes
More than Just Lines on a Map: Best Practices for U.S Bike RoutesMore than Just Lines on a Map: Best Practices for U.S Bike Routes
More than Just Lines on a Map: Best Practices for U.S Bike Routes
 
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
 
Barbie - Brand Strategy Presentation
Barbie - Brand Strategy PresentationBarbie - Brand Strategy Presentation
Barbie - Brand Strategy Presentation
 

Distributed Application Development with NServiceBus

  • 1. Distributed Application Development with NServiceBus David Boike www.make-awesome.com @DavidBoike Presentation and source: http://bit.ly/fOn4U9
  • 2. Real-Life Example using (TransactionScopets = newTransactionScope()) { InsertOrUpdateAlertPreferences(); UpdateAlertEmails(); InternalWebService.UpdateEmailSettings(listID, emailAddresses); ts.Complete(); }
  • 3. Real-Life Example – It Gets Worse using (TransactionScopets = newTransactionScope()) { InsertOrUpdateAlertPreferences(); UpdateAlertEmails(); InternalWebService.UpdateEmailSettings(listID, emailAddresses); ExternalWebService.UpdateSmsSettings(keyword, phoneNumber); ts.Complete(); }
  • 4. NServiceBus to the rescue! Enterprise Service Bus for .NET Not a centralized broker like BizTalk Not a services communication framework like WCF Created by UdiDahan, internationally renowned expert on software architecture and design Focuses on messaging and publish/subscribe Ultra reliable Provides friction against poor architecture decisions
  • 5. How it Works Utilizes assembly scanning for component discovery Uses marker interfaces to identify message schemas, message handlers, configuration sources, etc. Uses dependency injection (inversion of control) to detect and provide dependencies and services Everything is pluggable
  • 6. App How an Endpoint Works MSMQ Transactional Receive
  • 7. Transaction App How an Endpoint Works MSMQ Transactional Receive
  • 8. Transaction How an Endpoint Works Perform database operations within the distributed transaction MSMQ DB App
  • 9. Transaction How an Endpoint Works Or connect to a traditional web service MSMQ App Web Service
  • 10. Transaction App How an Endpoint Works Send or publish additional messages MSMQ
  • 11. Transaction Transient Errors If an exception happens, the transaction rolls back and returns the message to the queue. Transaction Rolling Back MSMQ Automatic retries are an integral part of the system. Exception App
  • 12. Poison Messages After a configurable number of retries, poison messages get sent to an error queue. Transaction Rolling Back MSMQ Fix the underlying issue, and you can return error messages to their source queue. App Error
  • 13. Real-Life Example - Revisited Webapp Bus.Send(new SaveAlertsCmd()); Alert Service Bus.Publish(new AlertsUpdatedEvent()); Subscriptions Bus.Subscribe<AlertsUpdatedEvent>(); Web Svc Adapter SMS Adapter
  • 14. Getting Started Go to http://www.nservicebus.com Click the Download link Follow the instructions Be sure to run RunMeFirst.bat fromthe command prompt with admin rights! Installs and/or verifies MSMQ configuration Sets the appropriate settings on the Microsoft Distributed Transaction Coordinator Installs performance counters Run from the command prompt so you can see if there are any errors.
  • 16. In case you missed it… If you are watching the presentation live, the next several slides are apt to be very boring. Sorry. For those of you at home, this is what we did so you can follow along in the code samples.
  • 17. Code Phase 1: Messaging Create MyMessages assembly Add reference to NServiceBus.dll Add CreateUserCmd
  • 18. Code Phase 1: Messaging Create UserService assembly Add reference to NServiceBus.dll, NServiceBus.Core.dll, NServiceBus.Host.exe, and Log4Net Add IConfigureThisEndpoint, AsA_Publisher Add UserCreatorservice implementing IHandleMessages<CreateUserCmd> Add Start Action to run NServiceBus.Host.exe
  • 19. Code Phase 1: Messaging Modify web project Add Global.asax, providing a global home for the web application’s IBus instance Modify Web.config with NServiceBus configuration Modify Register.aspx.cs to send the message
  • 20. Code Phase 2: Saga/Verification CreateUserSagaData : ISagaEntity Copy properties from CreateUserCmd Add VerificationString property Change from service handling CreateUserCmd to saga started by CreateUserCmd Set saga data from command Override ConfigureHowToFindSaga, calling ConfigureMapping<CreateUserCmd>() method
  • 21. Code Phase 2: Saga/Verification “Send” verification email Create SendVerificationEmailCmd Create mock handler that logs verification code to console Configure UserCreatorApp.config to send to the UserService (itself, although this could be a separate project) Send SendVerificationEmailCmd from the Handle<CreateUserCmd> method
  • 22. Code Phase 2: Saga/Verification Verify the email Create VerifyEmailCmd in MyMessages Create UserCreatedEvent in MyMessages Add IHandle<VerifyEmailCmd> to saga and configure how to find saga data from this command Add implementation, actually creating user in DB MarkAsComplete(), log, and Bus.Return(0)
  • 23. Code Phase 2: Saga/Verification Web handler for email link Create Verify.aspx Configure Web.config to send VerifyEmailCmd to UserService Change Register.aspx.cs redirect from Login to Verify
  • 25. Where to learn more NServiceBus website: www.nservicebus.com My blog: www.make-awesome.com Ask on Stack Overflow (tag with “nservicebus”) Udi’sblog: www.udidahan.com Andreas Ohlund’sblog: www.andreasohlund.net Jonathan Oliver’s blog: www.jonathanoliver.com Twitter: #NServiceBus Presentation Source Code: http://bit.ly/fOn4U9