My Blog

Empowering developers since 2015. Real articles, real insights.
Cloud and DevOps solutions that will save you hours.

    How to solve the "here-document at line 1 delimited by end-of-file (wanted 'EOF')" warning

    Recently, I ran into a frustrating issue with a shell script that uses heredocs. The closing EOF had indentation, so the shell didn’t recognize it as the closing tag. Everything after it kept getting added to the file, breaking the whole thing and the logs were showing this warning: here-document at line 1 delimited by end-of-file (wanted 'EOF') warning.

    Read the complete article

    How to add a Git submodule to your repository

    A Git submodule lets you include another repository inside your own project. This is useful for reusing shared code, libraries, or dependencies across multiple projects.

    To add a submodule to your parent repository, follow these steps:

    Read the complete article

    11 configurations you must make to secure your Azure Storage Accounts

    Storage accounts are often the security weak point in an Azure environment. You must actively harden them against insider threats, data exfiltration, and external attack vectors.

    Data protection in Azure must be layered. To truly secure your data, you need a defense-in-depth strategy that covers authentication, network isolation, encryption, and recovery.

    I have compiled this 11-point non-negotiable checklist to help you lock down your Azure Storage Accounts. These configurations cover the critical control plane and data plane settings you need to implement today.

    Read the complete article

    Azure Networking - Six steps to secure network design

    Based on my experience, these are the 6 core steps that ensure your Azure network environment is not only secure today but scalable for the long term.

    Read more about my essential blueprint for building enterprise-grade Azure architectures.

    Read the complete article

    Entra ID and Azure Taxonomy - Designing a clean cloud structure

    Designing a clear Azure structure requires deciding which taxonomy level should enforce Azure Policy, RBAC, and isolation. This article presents the hierarchy from Entra ID Tenant down to Azure Resources, explains where to apply governance, and gives practical tips you can use to build a maintainable cloud structure.

    As the diagram shows, the first takeaway is that Microsoft Entra ID is the identity management branch and Azure is the resource governance branch.

    Read the complete article