1. Services - Observability/Logging in Azure

    A while back, I published a guide on observability and logging for AWS. Today, it’s time to balance the scales and dive into the world of Azure. In this post, we’ll explore the suite of tools and services that Azure offers for logging and observability, so that you have the insights and capabilities needed to monitor and manage your Azure environment effectively. …


  2. Coding Best Practices Simplified - Brief and Effective

    Over the years, I have reviewed various coding best practices documents written by different development teams, as well as standards scattered across the web. Major tech companies have also published their own coding standards and best practices. Additionally, I have compiled and published my own coding and best practices using the content fron these diverse sources. …


  3. Services - Design

    When designing services, it is recommended to use a Domain Driven Design (DDD) approach, which is a software engineering method used to solve complex domain models. …


  4. Coding Best Practices Uncovered - A Detailed Exploration

    This document provides a detailed overview of coding spanest practices, intended for reference and to serve as a convenient checklist during code reviews. Coding standards are continuously evolving, and this document is updated regularly as I discover new points to add. …


  5. Understanding Habits: How to build and maintain them

    Many years ago, I had the pleasure of reading "Atomic Habits" by James Clear, and it made a significant impact on me. Recently, I came across a blog post 'Embracing Atomic Habits for Career Growth in the Tech Industry' by Arnold Gamboa that summarizes the book's four core principles. I have applied these principles in my life for years, and recently, I used the book's teachings as the foundation for a presentation. I'm sharing this below in the hope of inspiring you as well. …


  6. Agile - Sprint retrospective

    Introduction Every two weeks, after the sprint concludes, the team comes together for a one-hour retrospective meeting in a casual and relaxed atmosphere. The purpose of this gathering is to reflect on the recently completed sprint and offers the team a opportunity for driving continuous improvements and allows every member to celebrate achievements, voice concerns and frustrations, and, most importantly, present new experimental ideas. The meeting is attended by all team members, and a member of the team takes on the role of facilitating the proceedings. The facilitator can be any team member. …


  7. Services - NodeJS Microservice with AWS Lambda

    Introduction In this article, I want to walk you through my experience of going "serverless" and building an API "microservice" using AWS Lambda and API Gateway. Think of it as a practical guide to help you navigate creating your own microservices with these tools. This article will focus on running serverless on local machine. …


  8. Services - Observability/Logging in AWS

    Within the AWS environment, observability is supported through various integrated services provided by AWS. Here are some of the most popular observability services available within AWS that have proven invaluable in my experience. Let’s dive in and explore! …


  9. Services - Backward compatibility

    Introduction This article explains how to design REST API services that maintain backward compatibility. An API is backward compatible between releases if the clients are able to work with a new version of the API seamlessly. It allows clients to continue using the existing REST API and migrate their applications to the newer API version when they are ready. …


  10. SQL Analytics Functions - Windowing Clause Default Rows Behaviour (with FIRST_VALUE, LAST_VALUE example)

    Windowing clause of analytical function provide more fine-grained access to the data. It uses ROWS/RANGE that limits the rows within the partition by specifying start and end points within the partitio. …


  11. SQL Analytics Functions - ORDER BY Clause (with ROW_NUMBER example)

    ORDER BY clause imposes ordering on incoming data. It is required by some analytics functions (ROW_NUMBER(), LEAD(), LAG(),FIRST_VALUE()…) but does not make sense on other (COUNT(), MIN()). …


  12. SQL Analytics Functions (also known as Window Functions)

    Analytic functions are used to calculate an aggregate value based on a group of rows. While aggregate functions return a single value for each group, analytic functions can return multiple rows for each group. They are particularly useful for computing moving averages, running totals, percentages, or top-N results within a group. By using analytic functions, you can gain insights into the distribution and patterns of data within a group, and make more informed decisions based on the results. …


  13. Agile - Daily stand up

    Introduction The Daily Stand-up plays a vital role as one of the key ceremonies in the agile process. The daily stand-up is a time-boxed meeting and lasts between 15 to 30 minutes. Its purpose is to discuss the progress made by team members and identify any blockers or obstacles. The meeting is attended by all team members, and a member of the team takes on the role of facilitating the proceedings. The facilitator can be any team member. It is essential that the facilitator conducting the stand-up and the team members sharing updates adhere to the following guidelines: …


  14. Streaming data with Kafka Apache - Design

    If you are considering setting up a secondary data source for reporting or other purposes, Kafka can assist in streaming data from the primary data source to the secondary data source. The following steps outline how to transfer data from a SQL Server to Elastic: …


  15. Delete stale branches in Azure DevOps

    Introduction In my experience, there are two main reasons stale branches exist in Azure DevOps (or any source code repo): Branches are not deleted after completing pull request. Although Azure DevOps gives you option to delete branch after merging given the right permissions are applied. But this option is not used most of the time Developers create temp branches for proof of concepts, resolve merging conflicts or any other reason and then forget to delete them In this exercise, we will delete all the branches left as result of two cases. …


  16. Snowflake - Ingest and transform pipeline - Design

    If you’re planning to establish a data transformation pipeline that processes raw data and generates analytics-ready data for consumers, the following steps depict the data flow from source to destination.: …


  17. How to incorporate unplanned changes in agile sprint

    In an Agile sprint, unplanned changes can disrupt the team’s focus and timeline. The team may need to reassess their priorities and allocate more resources to accommodate the change. This can cause delays, increased costs, and decreased quality. Additionally, unplanned changes can lead to confusion and decreased collaboration among team members, as they adjust to the new situation. …


  18. Mind & Body - Personal Power

    Recently, I examined the lives of successful individuals in both personal and business domains, searching for the key to their achievements. I wondered whether their success could be attributed to their knowledge, but soon realized that many knowledgeable people don’t reach the pinnacle of success. I also considered whether their success was due to their hard work, but discovered that there are many hardworking individuals who don’t achieve success either. …


  19. Migration flow for moving applications to cloud

    If you're looking to transition your current applications from on-premises to the cloud, or from one cloud to another, there are certain steps you can take to ensure a seamless migration. In this blog post, we'll go over these concrete steps to help you plan and execute your migration with minimal disruptions. …


  20. React App Template

    I have utilized this template as a starting point for several projects. It consists solely of a front-end interface, utilizing a mock API as the back-end. The template allows for the basic CRUD operations and provides a user-friendly interface for editing and displaying data. It can be adapted to fit any application that requires data management. …