Middleware vs Filters
Dotnet, DotnetCore, Azure, C#,VB.net, Sql Server, WCF, MVC ,Linq, Javascript and Jquery
30 April 2024
Middleware vs Filters
C# Web API Flow
C# Web API Flow
- Receive Request
- Middleware Pipeline(Authentication, authorization, Logging, Error handling, Routing)
- Routing
- Controller Activation
- Model Binding
- Action Filters
- Execute Actions
- Result Execution
- Response Sent
- Logging and Cleanup
OAuth and C# Integration
OAuth and C# Integration
- Register your application - Microsoft Identity Platform(Azure Active Directory)
- Install required Nuget packages.
- Microsoft.Identity.Client
- Configure OAuth Settings - including the ClientID, tenantId, Client Secret
- Implementing Authentication
- Handling Token acquistion - method AcquireTokenByAuthorization Code
- Refresh Token
Solid Principles - Project example
Solid Principles - Project example
Dependency Inversion Principle
25 October 2023
Consistency level in Azure cosmos db
Consistency level in Azure cosmos db
Azure Cosmos DB offers five well-defined consistency levels to provide developers with the flexibility to choose the desired trade-off between consistency, availability, and latency for their applications. Here are the available consistency levels in Azure Cosmos DB:
1. Strong Consistency:
- Description: Guarantees linearizability, meaning that reads are guaranteed to return the most recent committed version of the data across all replicas. It ensures the highest consistency but might have higher latency and lower availability compared to other levels.
- Use Case: Critical applications where strong consistency is required, such as financial or legal applications.
2. Bounded staleness:
- Description: Allows you to specify a maximum lag between reads and writes. You can set the maximum staleness in terms of time or number of versions (operations). This level provides a balance between consistency, availability, and latency.
- Use Case: Scenarios where you can tolerate a slight delay in consistency, such as social media feeds or news applications.
3. Session Consistency:
- Description: Guarantees monotonic reads and writes within a single client session. Once a client reads a particular version of the data, it will never see a version of the data that's older than that in subsequent reads. This level provides consistency within a user session.
- Use Case: User-specific data scenarios where consistency within a user session is important, like in online shopping carts.
4. Consistent Prefix:
- Description: Guarantees that reads never see out-of-order writes. Within a single partition key, reads are guaranteed to see writes in the order they were committed. This level provides consistency per partition key.
- Use Case: Applications that require ordered operations within a partition key, such as time-series data or event logging.
5. Eventual Consistency:
- Description: Provides the weakest consistency level. Guarantees that, given enough time and lack of further updates, all replicas will converge to the same data. There is no strict guarantee about the order in which updates are applied to different replicas.
- Use Case: Scenarios where eventual consistency is acceptable, such as content management systems or applications dealing with non-critical data.
6. Custom Consistency:
- Description: Allows developers to define custom consistency levels based on specific requirements. This flexibility enables fine-tuning consistency for unique application needs.
- Use Case: Applications with highly specific or unique consistency requirements not met by the predefined consistency levels.
When selecting a consistency level, it's essential to understand the requirements of your application, as well as the implications on latency, availability, and throughput. Each consistency level offers a different balance between these factors, allowing you to tailor the database behavior to match your application's needs.
Reprocess data in deadletter queue - Service Bus
Reprocess data in deadletter queue - Service Bus
Reprocessing data from the Dead Letter Queue in Azure Service Bus involves inspecting the failed messages, addressing the issues that caused the failures, and then resubmitting the corrected messages for processing. Here's how you can reprocess data from the Dead Letter Queue:
1. Inspect Messages:
- First, you need to identify and understand the reason why messages ended up in the Dead Letter Queue. Inspect the messages to determine the cause of the failure. You can do this by reading the messages' content, properties, and error details.
2. Correct the Issues:
- Once you've identified the issues, correct the problems with the messages. This might involve fixing data inconsistencies, updating message formats, or addressing any other issues that caused the messages to fail.
3. Manually Resubmit Messages:
- After correcting the problematic messages, you can manually resubmit them to the main queue or topic for reprocessing. To do this, you need to create a new message with the corrected content and send it to the appropriate queue or topic.
Example (using Azure SDK for .NET):
```csharp
// Read the message from the Dead Letter Queue
var deadLetterMessage = await deadLetterReceiver.ReceiveAsync();
// Correct the issues with the message
// ...
// Create a new message with the corrected content
var correctedMessage = new Message(Encoding.UTF8.GetBytes("Corrected Message Content"))
{
// Set message properties, if necessary
MessageId = "NewMessageId"
};
// Send the corrected message back to the main queue or topic
await queueClient.SendAsync(correctedMessage);
4. Automated Retry Mechanism:
- Depending on the nature of the issues, you might implement an automated retry mechanism. For transient errors, you can configure Service Bus to automatically retry processing failed messages after a certain delay. You can set policies for automatic retries and define the maximum number of delivery attempts before a message is moved to the Dead Letter Queue.
Example (using Azure SDK for .NET):
```csharp
queueClient.ServiceBusConnection.OperationTimeout = TimeSpan.FromSeconds(30);
queueClient.RetryPolicy = new RetryExponential(TimeSpan.FromSeconds(1), TimeSpan.FromMinutes(5), 10);
5. Monitoring and Alerting:
- Implement monitoring and alerting to be notified when messages are moved to the Dead Letter Queue. This ensures that you're aware of processing failures promptly and can take appropriate actions to resolve them.
By following these steps, you can reprocess data from the Dead Letter Queue, ensuring that failed messages are corrected, resubmitted, and successfully processed in your Azure Service Bus application.
Uses of Deadletter queue in Service bus
Uses of Deadletter queue in Service bus
The Dead Letter Queue (DLQ) in Azure Service Bus is a storage area used to hold messages that cannot be delivered to any receiver, whether it's due to message expiration, delivery attempts exceeding a specified limit, or issues with message content. Here are the primary uses of the Dead Letter Queue in Azure Service Bus:
1. Error Handling:
- Unprocessable Messages: Messages that are malformed, contain incorrect data, or cannot be deserialized properly might be sent to the Dead Letter Queue. This separation allows developers to focus on resolving issues with problematic messages without affecting the main processing flow.
2. Message Expiry:
- **Expired Messages:** Messages with a limited time to live (TTL) that have expired before being processed end up in the Dead Letter Queue. This ensures that expired messages do not get lost and can be analyzed for auditing purposes.
3. Delivery Failure:
- Exceeded Delivery Attempts: If a message delivery attempt exceeds the maximum allowed retries (due to network issues or receiver failures), the message is moved to the Dead Letter Queue. This prevents infinite delivery loops for messages that cannot be successfully processed.
4. Auditing and Analysis:
- Troubleshooting: Messages in the Dead Letter Queue can be analyzed to understand the reasons for failures. Developers can inspect these messages to identify patterns or issues leading to message failures.
- **Auditing:** Dead Letter Queue acts as an audit trail for problematic messages, allowing administrators to track and monitor issues over time.
5. Retry Mechanism:
- **Manual Retry:** Developers can manually inspect messages in the Dead Letter Queue, address the underlying issues, and then resubmit the messages for processing. This enables a manual retry mechanism for failed messages.
6. Compliance and Governance:
- Compliance Requirements: In certain industries, compliance regulations require organizations to retain failed messages for auditing purposes. Dead Letter Queue ensures compliance with such requirements.
7. Preventing Data Loss:
- Message Preservation: Messages in the Dead Letter Queue are preserved until manually removed or until a specified retention period expires. This prevents accidental data loss and allows for the recovery of important messages.
8. Notification and Alerting:
- Alerting System: Integration with monitoring and alerting systems allows administrators to receive notifications when messages are moved to the Dead Letter Queue. This enables prompt response to message processing failures.
In summary, the Dead Letter Queue in Azure Service Bus provides a safety net for messages that cannot be successfully processed, ensuring that they are preserved, analyzed, and potentially retried. It plays a crucial role in maintaining data integrity, aiding in troubleshooting, and meeting compliance requirements within distributed systems.
Implementing OAuth validation in a Web API
I mplementing OAuth validation in a Web API Implementing OAuth validation in a Web API using C# typically involves several key steps to sec...
-
ViewBag, ViewData, TempData and View State in MVC ASP.NET MVC offers us three options ViewData, ViewBag and TempData for passing data from...
-
// Export Datatable to Excel in C# Windows application using System; using System.Data; using System.IO; using System.Windows.Forms; ...