Mejores Practicas Azure

Download as pdf or txt
Download as pdf or txt
You are on page 1of 371
At a glance
Powered by AI
The document provides an overview of Azure security capabilities including identity management, encryption, network security, and monitoring.

Azure provides capabilities for encryption, identity management, network security, antivirus/malware protection, and more to help secure workloads and data in the cloud.

The document recommends practices like choosing passwordless authentication, implementing DDoS protection best practices, securing virtual machines and databases, and more.

Contents

Fundamentals Documentation
Overview
Introduction to Azure security
End-to-end security
Shared responsibility in the cloud
Detect and mitigate threats
Backup and restore plan for ransomware
Recovering from systemic identity compromise
Threat protection
Securing workloads in Azure
Security technical capabilities
Azure platform and infrastructure
Infrastructure security
Physical security
Availability
Components and boundaries
Network architecture
Production network
SQL Database
Operations
Monitoring
Integrity
Data protection
Platform integrity and security
Firmware security
Code integrity
Secure Boot
Measured boot & host attestation
Project Cerberus
Encryption at rest
Hypervisor security
Isolation in the Azure cloud
Identity management
Security overview
Best practices
Security checklist
Choose passwordless
Authentication
Network security
Security overview
Best practices
DDoS Protection best practices
DDoS Protection security baseline
Dangling DNS and subdomain takeover
Secure hybrid network architecture
IaaS security
Microsoft Antimalware
Microsoft Antimalware code samples
Virtual machine security overview
Best practices - IaaS workloads
Azure Marketplace images
Data security, encryption, and storage
Data security and encryption
Double encryption
TLS certificate changes
Disk encryption
Best practices
Data encryption at rest
Data encryption models
Azure Disk Encryption for virtual machines
Database security
Overview
Best practices
Security checklist
Storage security guide
Customer Lockbox
Security baseline for Customer Lockbox
Application
PaaS
Azure App Service for PaaS
Azure Storage for PaaS
DB best practices for PaaS
Azure Service Fabric security
Monitoring, auditing, and operations
Azure logging and auditing
Security management and monitoring
Enhance remote management
Operational security
Overview
Best practices
Security checklist
Resources
Azure security services
Feature availability for US Government clouds
Security white papers
Best practices
Cybersecurity consulting
Log a security event support ticket
Pen testing
Azure domains
Introduction to Azure security
12/12/2021 • 26 minutes to read • Edit Online

Overview
We know that security is job one in the cloud and how important it is that you find accurate and timely
information about Azure security. One of the best reasons to use Azure for your applications and services is to
take advantage of its wide array of security tools and capabilities. These tools and capabilities help make it
possible to create secure solutions on the secure Azure platform. Microsoft Azure provides confidentiality,
integrity, and availability of customer data, while also enabling transparent accountability.
This article provides a comprehensive look at the security available with Azure.
Azure platform
Azure is a public cloud service platform that supports a broad selection of operating systems, programming
languages, frameworks, tools, databases, and devices. It can run Linux containers with Docker integration; build
apps with JavaScript, Python, .NET, PHP, Java, and Node.js; build back-ends for iOS, Android, and Windows
devices.
Azure public cloud services support the same technologies millions of developers and IT professionals already
rely on and trust. When you build on, or migrate IT assets to, a public cloud service provider you are relying on
that organization’s abilities to protect your applications and data with the services and the controls they provide
to manage the security of your cloud-based assets.
Azure’s infrastructure is designed from facility to applications for hosting millions of customers simultaneously,
and it provides a trustworthy foundation upon which businesses can meet their security requirements.
In addition, Azure provides you with a wide array of configurable security options and the ability to control them
so that you can customize security to meet the unique requirements of your organization’s deployments. This
document helps you understand how Azure security capabilities can help you fulfill these requirements.

NOTE
The primary focus of this document is on customer-facing controls that you can use to customize and increase security
for your applications and services.
For information on how Microsoft secures the Azure platform itself, see Azure infrastructure security.

Summary of Azure security capabilities


Depending on the cloud service model, there is variable responsibility for who is responsible for managing the
security of the application or service. There are capabilities available in the Azure Platform to assist you in
meeting these responsibilities through built-in features, and through partner solutions that can be deployed into
an Azure subscription.
The built-in capabilities are organized in six functional areas: Operations, Applications, Storage, Networking,
Compute, and Identity. Additional detail on the features and capabilities available in the Azure Platform in these
six areas are provided through summary information.

Operations
This section provides additional information regarding key features in security operations and summary
information about these capabilities.
Microsoft Defender for Cloud
Defender for Cloud helps you prevent, detect, and respond to threats with increased visibility into and control
over the security of your Azure resources. It provides integrated security monitoring and policy management
across your Azure subscriptions, helps detect threats that might otherwise go unnoticed, and works with a
broad ecosystem of security solutions.
In addition, Defender for Cloud helps with security operations by providing you a single dashboard that surfaces
alerts and recommendations that can be acted upon immediately. Often, you can remediate issues with a single
click within the Defender for Cloud console.
Azure Resource Manager
Azure Resource Manager enables you to work with the resources in your solution as a group. You can deploy,
update, or delete all the resources for your solution in a single, coordinated operation. You use an Azure
Resource Manager template for deployment and that template can work for different environments such as
testing, staging, and production. Resource Manager provides security, auditing, and tagging features to help you
manage your resources after deployment.
Azure Resource Manager template-based deployments help improve the security of solutions deployed in Azure
because standard security control settings and can be integrated into standardized template-based
deployments. This reduces the risk of security configuration errors that might take place during manual
deployments.
Application Insights
Application Insights is an extensible Application Performance Management (APM) service for web developers.
With Application Insights, you can monitor your live web applications and automatically detect performance
anomalies. It includes powerful analytics tools to help you diagnose issues and to understand what users
actually do with your apps. It monitors your application all the time it's running, both during testing and after
you've published or deployed it.
Application Insights creates charts and tables that show you, for example, what times of day you get most users,
how responsive the app is, and how well it is served by any external services that it depends on.
If there are crashes, failures or performance issues, you can search through the telemetry data in detail to
diagnose the cause. And the service sends you emails if there are any changes in the availability and
performance of your app. Application Insight thus becomes a valuable security tool because it helps with the
availability in the confidentiality, integrity, and availability security triad.
Azure Monitor
Azure Monitor offers visualization, query, routing, alerting, auto scale, and automation on data both from the
Azure subscription (Activity Log) and each individual Azure resource (Resource Logs). You can use Azure
Monitor to alert you on security-related events that are generated in Azure logs.
Azure Monitor logs
Azure Monitor logs – Provides an IT management solution for both on-premises and third-party cloud-based
infrastructure (such as AWS) in addition to Azure resources. Data from Azure Monitor can be routed directly to
Azure Monitor logs so you can see metrics and logs for your entire environment in one place.
Azure Monitor logs can be a useful tool in forensic and other security analysis, as the tool enables you to quickly
search through large amounts of security-related entries with a flexible query approach. In addition, on-
premises firewall and proxy logs can be exported into Azure and made available for analysis using Azure
Monitor logs.
Azure Advisor
Azure Advisor is a personalized cloud consultant that helps you to optimize your Azure deployments. It analyzes
your resource configuration and usage telemetry. It then recommends solutions to help improve the
performance, security, and reliability of your resources while looking for opportunities to reduce your overall
Azure spend. Azure Advisor provides security recommendations, which can significantly improve your overall
security posture for solutions you deploy in Azure. These recommendations are drawn from security analysis
performed by Microsoft Defender for Cloud.

Applications
The section provides additional information regarding key features in application security and summary
information about these capabilities.
Web Application vulnerability scanning
One of the easiest ways to get started with testing for vulnerabilities on your App Service app is to use the
integration with Tinfoil Security to perform one-click vulnerability scanning on your app. You can view the test
results in an easy-to-understand report, and learn how to fix each vulnerability with step-by-step instructions.
Penetration Testing
We don’t perform penetration testing of your application for you, but we do understand that you want and need
to perform testing on your own applications. That’s a good thing, because when you enhance the security of
your applications you help make the entire Azure ecosystem more secure. While notifying Microsoft of pen
testing activities is no longer required customers must still comply with the Microsoft Cloud Penetration Testing
Rules of Engagement.
Web Application firewall
The web application firewall (WAF) in Azure Application Gateway helps protect web applications from common
web-based attacks like SQL injection, cross-site scripting attacks, and session hijacking. It comes preconfigured
with protection from threats identified by the Open Web Application Security Project (OWASP) as the top 10
common vulnerabilities.
Authentication and authorization in Azure App Service
App Service Authentication / Authorization is a feature that provides a way for your application to sign in users
so that you don't have to change code on the app backend. It provides an easy way to protect your application
and work with per-user data.
Layered Security Architecture
Since App Service Environments provide an isolated runtime environment deployed into an Azure Virtual
Network, developers can create a layered security architecture providing differing levels of network access for
each application tier. A common desire is to hide API back-ends from general Internet access, and only allow
APIs to be called by upstream web apps. Network Security groups (NSGs) can be used on Azure Virtual Network
subnets containing App Service Environments to restrict public access to API applications.
Web server diagnostics and application diagnostics
App Service web apps provide diagnostic functionality for logging information from both the web server and
the web application. These are logically separated into web server diagnostics and application diagnostics. Web
server includes two major advances in diagnosing and troubleshooting sites and applications.
The first new feature is real-time state information about application pools, worker processes, sites, application
domains, and running requests. The second new advantages are the detailed trace events that track a request
throughout the complete request-and-response process.
To enable the collection of these trace events, IIS 7 can be configured to automatically capture full trace logs, in
XML format, for any particular request based on elapsed time or error response codes.

Storage
The section provides additional information regarding key features in Azure storage security and summary
information about these capabilities.
Azure role -based access control (Azure RBAC )
You can secure your storage account with Azure role-based access control (Azure RBAC). Restricting access
based on the need to know and least privilege security principles is imperative for organizations that want to
enforce Security policies for data access. These access rights are granted by assigning the appropriate Azure role
to groups and applications at a certain scope. You can use Azure built-in roles, such as Storage Account
Contributor, to assign privileges to users. Access to the storage keys for a storage account using the Azure
Resource Manager model can be controlled through Azure RBAC.
Shared Access Signature
A shared access signature (SAS) provides delegated access to resources in your storage account. The SAS means
that you can grant a client limited permissions to objects in your storage account for a specified period and with
a specified set of permissions. You can grant these limited permissions without having to share your account
access keys.
Encryption in Transit
Encryption in transit is a mechanism of protecting data when it is transmitted across networks. With Azure
Storage, you can secure data using:
Transport-level encryption, such as HTTPS when you transfer data into or out of Azure Storage.
Wire encryption, such as SMB 3.0 encryption for Azure File shares.
Client-side encryption, to encrypt the data before it is transferred into storage and to decrypt the data
after it is transferred out of storage.
Encryption at rest
For many organizations, data encryption at rest is a mandatory step towards data privacy, compliance, and data
sovereignty. There are three Azure storage security features that provide encryption of data that is “at rest”:
Storage Service Encryption allows you to request that the storage service automatically encrypt data
when writing it to Azure Storage.
Client-side Encryption also provides the feature of encryption at rest.
Azure Disk Encryption allows you to encrypt the OS disks and data disks used by an IaaS virtual machine.
Storage Analytics
Azure Storage Analytics performs logging and provides metrics data for a storage account. You can use this data
to trace requests, analyze usage trends, and diagnose issues with your storage account. Storage Analytics logs
detailed information about successful and failed requests to a storage service. This information can be used to
monitor individual requests and to diagnose issues with a storage service. Requests are logged on a best-effort
basis. The following types of authenticated requests are logged:
Successful requests.
Failed requests, including timeout, throttling, network, authorization, and other errors.
Requests using a Shared Access Signature (SAS), including failed and successful requests.
Requests to analytics data.
Enabling Browser-Based Clients Using CORS
Cross-Origin Resource Sharing (CORS) is a mechanism that allows domains to give each other permission for
accessing each other’s resources. The User Agent sends extra headers to ensure that the JavaScript code loaded
from a certain domain is allowed to access resources located at another domain. The latter domain then replies
with extra headers allowing or denying the original domain access to its resources.
Azure storage services now support CORS so that once you set the CORS rules for the service, a properly
authenticated request made against the service from a different domain is evaluated to determine whether it is
allowed according to the rules you have specified.

Networking
The section provides additional information regarding key features in Azure network security and summary
information about these capabilities.
Network Layer Controls
Network access control is the act of limiting connectivity to and from specific devices or subnets and represents
the core of network security. The goal of network access control is to make sure that your virtual machines and
services are accessible to only users and devices to which you want them accessible.
Network Security Groups
A Network Security Group (NSG) is a basic stateful packet filtering firewall and it enables you to control access
based on a 5-tuple. NSGs do not provide application layer inspection or authenticated access controls. They can
be used to control traffic moving between subnets within an Azure Virtual Network and traffic between an
Azure Virtual Network and the Internet.
Route Control and Forced Tunneling
The ability to control routing behavior on your Azure Virtual Networks is a critical network security and access
control capability. For example, if you want to make sure that all traffic to and from your Azure Virtual Network
goes through that virtual security appliance, you need to be able to control and customize routing behavior. You
can do this by configuring User-Defined Routes in Azure.
User-Defined Routes allow you to customize inbound and outbound paths for traffic moving into and out of
individual virtual machines or subnets to insure the most secure route possible. Forced tunneling is a
mechanism you can use to ensure that your services are not allowed to initiate a connection to devices on the
Internet.
This is different from being able to accept incoming connections and then responding to them. Front-end web
servers need to respond to requests from Internet hosts, and so Internet-sourced traffic is allowed inbound to
these web servers and the web servers can respond.
Forced tunneling is commonly used to force outbound traffic to the Internet to go through on-premises security
proxies and firewalls.
Virtual Network Security Appliances
While Network Security Groups, User-Defined Routes, and forced tunneling provide you a level of security at the
network and transport layers of the OSI model, there may be times when you want to enable security at higher
levels of the stack. You can access these enhanced network security features by using an Azure partner network
security appliance solution. You can find the most current Azure partner network security solutions by visiting
the Azure Marketplace and searching for “security” and “network security.”
Azure Virtual Network
An Azure virtual network (VNet) is a representation of your own network in the cloud. It is a logical isolation of
the Azure network fabric dedicated to your subscription. You can fully control the IP address blocks, DNS
settings, security policies, and route tables within this network. You can segment your VNet into subnets and
place Azure IaaS virtual machines (VMs) and/or Cloud services (PaaS role instances) on Azure Virtual Networks.
Additionally, you can connect the virtual network to your on-premises network using one of the connectivity
options available in Azure. In essence, you can expand your network to Azure, with complete control on IP
address blocks with the benefit of enterprise scale Azure provides.
Azure networking supports various secure remote access scenarios. Some of these include:
Connect individual workstations to an Azure Virtual Network
Connect on-premises network to an Azure Virtual Network with a VPN
Connect on-premises network to an Azure Virtual Network with a dedicated WAN link
Connect Azure Virtual Networks to each other
Azure Private Link
Azure Private Link enables you to access Azure PaaS Services (for example, Azure Storage and SQL Database)
and Azure hosted customer-owned/partner services privately in your virtual network over a private endpoint.
Setup and consumption using Azure Private Link is consistent across Azure PaaS, customer-owned, and shared
partner services. Traffic from your virtual network to the Azure service always remains on the Microsoft Azure
backbone network.
Private Endpoints allow you to secure your critical Azure service resources to only your virtual networks. Azure
Private Endpoint uses a private IP address from your VNet to connect you privately and securely to a service
powered by Azure Private Link, effectively bringing the service into your VNet. Exposing your virtual network to
the public internet is no longer necessary to consume services on Azure.
You can also create your own private link service in your virtual network. Azure Private Link service is the
reference to your own service that is powered by Azure Private Link. Your service that is running behind Azure
Standard Load Balancer can be enabled for Private Link access so that consumers to your service can access it
privately from their own virtual networks. Your customers can create a private endpoint inside their virtual
network and map it to this service. Exposing your service to the public internet is no longer necessary to render
services on Azure.
VPN Gateway
To send network traffic between your Azure Virtual Network and your on-premises site, you must create a VPN
gateway for your Azure Virtual Network. A VPN gateway is a type of virtual network gateway that sends
encrypted traffic across a public connection. You can also use VPN gateways to send traffic between Azure
Virtual Networks over the Azure network fabric.
Express Route
Microsoft Azure ExpressRoute is a dedicated WAN link that lets you extend your on-premises networks into the
Microsoft cloud over a dedicated private connection facilitated by a connectivity provider.

With ExpressRoute, you can establish connections to Microsoft cloud services, such as Microsoft Azure,
Microsoft 365, and CRM Online. Connectivity can be from an any-to-any (IP VPN) network, a point-to-point
Ethernet network, or a virtual cross-connection through a connectivity provider at a co-location facility.
ExpressRoute connections do not go over the public Internet and thus can be considered more secure than VPN-
based solutions. This allows ExpressRoute connections to offer more reliability, faster speeds, lower latencies,
and higher security than typical connections over the Internet.
Application Gateway
Microsoft Azure Application Gateway provides an Application Delivery Controller (ADC) as a service, offering
various layer 7 load balancing capabilities for your application.

It allows you to optimize web farm productivity by offloading CPU intensive TLS termination to the Application
Gateway (also known as “TLS offload” or “TLS bridging”). It also provides other Layer 7 routing capabilities
including round-robin distribution of incoming traffic, cookie-based session affinity, URL path-based routing,
and the ability to host multiple websites behind a single Application Gateway. Azure Application Gateway is a
layer-7 load balancer.
It provides failover, performance-routing HTTP requests between different servers, whether they are on the
cloud or on-premises.
Application provides many Application Delivery Controller (ADC) features including HTTP load balancing,
cookie-based session affinity, TLS offload, custom health probes, support for multi-site, and many others.
Web Application Firewall
Web Application Firewall is a feature of Azure Application Gateway that provides protection to web applications
that use application gateway for standard Application Delivery Control (ADC) functions. Web application firewall
does this by protecting them against most of the OWASP top 10 common web vulnerabilities.
SQL injection protection
Common Web Attacks Protection such as command injection, HTTP request smuggling, HTTP response
splitting, and remote file inclusion attack
Protection against HTTP protocol violations
Protection against HTTP protocol anomalies such as missing host user-agent and accept headers
Prevention against bots, crawlers, and scanners
Detection of common application misconfigurations (that is, Apache, IIS, etc.)
A centralized web application firewall to protect against web attacks makes security management much simpler
and gives better assurance to the application against the threats of intrusions. A WAF solution can also react to a
security threat faster by patching a known vulnerability at a central location versus securing each of individual
web applications. Existing application gateways can be converted to an application gateway with web
application firewall easily.
Traffic Manager
Microsoft Azure Traffic Manager allows you to control the distribution of user traffic for service endpoints in
different data centers. Service endpoints supported by Traffic Manager include Azure VMs, Web Apps, and Cloud
services. You can also use Traffic Manager with external, non-Azure endpoints. Traffic Manager uses the Domain
Name System (DNS) to direct client requests to the most appropriate endpoint based on a traffic-routing
method and the health of the endpoints.
Traffic Manager provides a range of traffic-routing methods to suit different application needs, endpoint health
monitoring, and automatic failover. Traffic Manager is resilient to failure, including the failure of an entire Azure
region.
Azure Load Balancer
Azure Load Balancer delivers high availability and network performance to your applications. It is a Layer 4 (TCP,
UDP) load balancer that distributes incoming traffic among healthy instances of services defined in a load-
balanced set. Azure Load Balancer can be configured to:
Load balance incoming Internet traffic to virtual machines. This configuration is known as public load
balancing.
Load balance traffic between virtual machines in a virtual network, between virtual machines in cloud
services, or between on-premises computers and virtual machines in a cross-premises virtual network.
This configuration is known as internal load balancing.
Forward external traffic to a specific virtual machine
Internal DNS
You can manage the list of DNS servers used in a VNet in the Management Portal, or in the network
configuration file. Customer can add up to 12 DNS servers for each VNet. When specifying DNS servers, it's
important to verify that you list customer’s DNS servers in the correct order for customer’s environment. DNS
server lists do not work round-robin. They are used in the order that they are specified. If the first DNS server on
the list is able to be reached, the client uses that DNS server regardless of whether the DNS server is functioning
properly or not. To change the DNS server order for customer’s virtual network, remove the DNS servers from
the list and add them back in the order that customer wants. DNS supports the availability aspect of the “CIA”
security triad.
Azure DNS
The Domain Name System, or DNS, is responsible for translating (or resolving) a website or service name to its
IP address. Azure DNS is a hosting service for DNS domains, providing name resolution using Microsoft Azure
infrastructure. By hosting your domains in Azure, you can manage your DNS records using the same credentials,
APIs, tools, and billing as your other Azure services. DNS supports the availability aspect of the “CIA” security
triad.
Azure Monitor logs NSGs
You can enable the following diagnostic log categories for NSGs:
Event: Contains entries for which NSG rules are applied to VMs and instance roles based on MAC
address. The status for these rules is collected every 60 seconds.
Rules counter: Contains entries for how many times each NSG rule is applied to deny or allow traffic.
Defender for Cloud
Microsoft Defender for Cloud continuously analyzes the security state of your Azure resources for network
security best practices. When Defender for Cloud identifies potential security vulnerabilities, it creates
recommendations that guide you through the process of configuring the needed controls to harden and protect
your resources.

Compute
The section provides additional information regarding key features in this area and summary information about
these capabilities.
Antimalware & Antivirus
With Azure IaaS, you can use antimalware software from security vendors such as Microsoft, Symantec, Trend
Micro, McAfee, and Kaspersky to protect your virtual machines from malicious files, adware, and other threats.
Microsoft Antimalware for Azure Cloud Services and Virtual Machines is a protection capability that helps
identify and remove viruses, spyware, and other malicious software. Microsoft Antimalware provides
configurable alerts when known malicious or unwanted software attempts to install itself or run on your Azure
systems. Microsoft Antimalware can also be deployed using Microsoft Defender for Cloud
Hardware Security Module
Encryption and authentication do not improve security unless the keys themselves are protected. You can
simplify the management and security of your critical secrets and keys by storing them in Azure Key Vault. Key
Vault provides the option to store your keys in hardware Security modules (HSMs) certified to FIPS 140-2 Level
2 standards. Your SQL Server encryption keys for backup or transparent data encryption can all be stored in Key
Vault with any keys or secrets from your applications. Permissions and access to these protected items are
managed through Azure Active Directory.
Virtual machine backup
Azure Backup is a solution that protects your application data with zero capital investment and minimal
operating costs. Application errors can corrupt your data, and human errors can introduce bugs into your
applications that can lead to security issues. With Azure Backup, your virtual machines running Windows and
Linux are protected.
Azure Site Recovery
An important part of your organization's business continuity/disaster recovery (BCDR) strategy is figuring out
how to keep corporate workloads and apps up and running when planned and unplanned outages occur. Azure
Site Recovery helps orchestrate replication, failover, and recovery of workloads and apps so that they are
available from a secondary location if your primary location goes down.
SQL VM TDE
Transparent data encryption (TDE) and column level encryption (CLE) are SQL server encryption features. This
form of encryption requires customers to manage and store the cryptographic keys you use for encryption.
The Azure Key Vault (AKV) service is designed to improve the security and management of these keys in a
secure and highly available location. The SQL Server Connector enables SQL Server to use these keys from
Azure Key Vault.
If you are running SQL Server with on-premises machines, there are steps you can follow to access Azure Key
Vault from your on-premises SQL Server instance. But for SQL Server in Azure VMs, you can save time by using
the Azure Key Vault Integration feature. With a few Azure PowerShell cmdlets to enable this feature, you can
automate the configuration necessary for a SQL VM to access your key vault.
VM Disk Encryption
Azure Disk Encryption is a new capability that helps you encrypt your Windows and Linux IaaS virtual machine
disks. It applies the industry standard BitLocker feature of Windows and the DM-Crypt feature of Linux to
provide volume encryption for the OS and the data disks. The solution is integrated with Azure Key Vault to help
you control and manage the disk-encryption keys and secrets in your Key Vault subscription. The solution also
ensures that all data on the virtual machine disks are encrypted at rest in your Azure storage.
Virtual networking
Virtual machines need network connectivity. To support that requirement, Azure requires virtual machines to be
connected to an Azure Virtual Network. An Azure Virtual Network is a logical construct built on top of the
physical Azure network fabric. Each logical Azure Virtual Network is isolated from all other Azure Virtual
Networks. This isolation helps insure that network traffic in your deployments is not accessible to other
Microsoft Azure customers.
Patch Updates
Patch Updates provide the basis for finding and fixing potential problems and simplify the software update
management process, both by reducing the number of software updates you must deploy in your enterprise
and by increasing your ability to monitor compliance.
Security policy management and reporting
Defender for Cloud helps you prevent, detect, and respond to threats, and provides you increased visibility into,
and control over, the security of your Azure resources. It provides integrated Security monitoring and policy
management across your Azure subscriptions, helps detect threats that might otherwise go unnoticed, and
works with a broad ecosystem of security solutions.

Identity and access management


Securing systems, applications, and data begins with identity-based access controls. The identity and access
management features that are built into Microsoft business products and services help protect your
organizational and personal information from unauthorized access while making it available to legitimate users
whenever and wherever they need it.
Secure Identity
Microsoft uses multiple security practices and technologies across its products and services to manage identity
and access.
Multi-Factor Authentication requires users to use multiple methods for access, on-premises and in the
cloud. It provides strong authentication with a range of easy verification options, while accommodating
users with a simple sign-in process.
Microsoft Authenticator provides a user-friendly Multi-Factor Authentication experience that works with
both Microsoft Azure Active Directory and Microsoft accounts, and includes support for wearables and
fingerprint-based approvals.
Password policy enforcement increases the security of traditional passwords by imposing length and
complexity requirements, forced periodic rotation, and account lockout after failed authentication
attempts.
Token-based authentication enables authentication via Azure Active Directory.
Azure role-based access control (Azure RBAC) enables you to grant access based on the user’s assigned
role, making it easy to give users only the amount of access they need to perform their job duties. You
can customize Azure RBAC per your organization’s business model and risk tolerance.
Integrated identity management (hybrid identity) enables you to maintain control of users’ access across
internal datacenters and cloud platforms, creating a single user identity for authentication and
authorization to all resources.
Secure Apps and data
Azure Active Directory, a comprehensive identity and access management cloud solution, helps secure access to
data in applications on site and in the cloud, and simplifies the management of users and groups. It combines
core directory services, advanced identity governance, security, and application access management, and makes
it easy for developers to build policy-based identity management into their apps. To enhance your Azure Active
Directory, you can add paid capabilities using the Azure Active Directory Basic, Premium P1, and Premium P2
editions.

A Z URE A C T IVE
DIREC TO RY JO IN –
F REE / C O M M O N P REM IUM P 1 P REM IUM P 2 W IN DO W S 10 O N LY
F EAT URES B A SIC F EAT URES F EAT URES F EAT URES REL AT ED F EAT URES
A Z URE A C T IVE
DIREC TO RY JO IN –
F REE / C O M M O N P REM IUM P 1 P REM IUM P 2 W IN DO W S 10 O N LY
F EAT URES B A SIC F EAT URES F EAT URES F EAT URES REL AT ED F EAT URES

Directory Objects, Group-based access Self-Service Group Identity Protection, Join a device to
User/Group management / and app Privileged Identity Azure AD, Desktop
Management provisioning, Self- Management/Self- Management SSO, Microsoft
(add/update/delete)/ Service Password Service application Passport for Azure
User-based Reset for cloud users, additions/Dynamic AD, Administrator
provisioning, Device Company Branding Groups, Self-Service BitLocker recovery,
registration, Single (Logon Pages/Access Password MDM auto-
Sign-On (SSO), Self- Panel customization), Reset/Change/Unlock enrollment, Self-
Service Password Application Proxy, with on-premises Service BitLocker
Change for cloud SLA 99.9% write-back, Multi- recovery, Additional
users, Connect (Sync Factor Authentication local administrators
engine that extends (Cloud and On- to Windows 10
on-premises premises (MFA devices via Azure AD
directories to Azure Server)), MIM CAL + Join
Active Directory), MIM Server, Cloud
Security / Usage App Discovery,
Reports Connect Health,
Automatic password
rollover for group
accounts

Cloud App Discovery is a premium feature of Azure Active Directory that enables you to identify cloud
applications that are used by the employees in your organization.
Azure Active Directory Identity Protection is a security service that uses Azure Active Directory anomaly
detection capabilities to provide a consolidated view into risk detections and potential vulnerabilities that
could affect your organization’s identities.
Azure Active Directory Domain Services enables you to join Azure VMs to a domain without the need to
deploy domain controllers. Users sign in to these VMs by using their corporate Active Directory
credentials, and can seamlessly access resources.
Azure Active Directory B2C is a highly available, global identity management service for consumer-facing
apps that can scale to hundreds of millions of identities and integrate across mobile and web platforms.
Your customers can sign in to all your apps through customizable experiences that use existing social
media accounts, or you can create new standalone credentials.
Azure Active Directory B2B Collaboration is a secure partner integration solution that supports your
cross-company relationships by enabling partners to access your corporate applications and data
selectively by using their self-managed identities.
Azure Active Directory joined enables you to extend cloud capabilities to Windows 10 devices for
centralized management. It makes it possible for users to connect to the corporate or organizational
cloud through Azure Active Directory and simplifies access to apps and resources.
Azure Active Directory Application Proxy provides SSO and secure remote access for web applications
hosted on-premises.

Next Steps
Understand your shared responsibility in the cloud.
Learn how Microsoft Defender for Cloud can help you prevent, detect, and respond to threats with
increased visibility and control over the security of your Azure resources.
End-to-end security in Azure
12/12/2021 • 7 minutes to read • Edit Online

One of the best reasons to use Azure for your applications and services is to take advantage of its wide array of
security tools and capabilities. These tools and capabilities help make it possible to create secure solutions on
the secure Azure platform. Microsoft Azure provides confidentiality, integrity, and availability of customer data,
while also enabling transparent accountability.
The following diagram and documentation introduces you to the security services in Azure. These security
services help you meet the security needs of your business and protect your users, devices, resources, data, and
applications in the cloud.

Microsoft security services map


The security services map organizes services by the resources they protect (column). The diagram also groups
services into the following categories (row):
Secure and protect - Services that let you implement a layered, defense in-depth strategy across identity,
hosts, networks, and data. This collection of security services and capabilities provides a way to understand
and improve your security posture across your Azure environment.
Detect threats – Services that identify suspicious activities and facilitate mitigating the threat.
Investigate and respond – Services that pull logging data so you can assess a suspicious activity and respond.
The diagram includes the Azure Security Benchmark program, a collection of high-impact security
recommendations you can use to help secure the services you use in Azure.

Security controls and baselines


The Azure Security Benchmark program includes a collection of high-impact security recommendations you can
use to help secure the services you use in Azure:
Security controls - These recommendations are generally applicable across your Azure tenant and Azure
services. Each recommendation identifies a list of stakeholders that are typically involved in planning,
approval, or implementation of the benchmark.
Service baselines - These apply the controls to individual Azure services to provide recommendations on that
service’s security configuration.

Secure and protect

SERVIC E DESC RIP T IO N

Microsoft Defender for Cloud A unified infrastructure security management system that
strengthens the security posture of your data centers, and
provides advanced threat protection across your hybrid
workloads in the cloud - whether they're in Azure or not - as
well as on premises.
SERVIC E DESC RIP T IO N

Identity & Access Management

Azure Active Directory (AD) Microsoft’s cloud-based identity and access management
service.

Conditional Access is the tool used by Azure AD to bring


identity signals together, to make decisions, and enforce
organizational policies.

Domain Services is the tool used by Azure AD to provide


managed domain services such as domain join, group policy,
lightweight directory access protocol (LDAP), and
Kerberos/NTLM authentication.

Privileged Identity Management (PIM) is a service in Azure


AD that enables you to manage, control, and monitor access
to important resources in your organization.

Multi-factor authentication is the tool used by Azure AD to


help safeguard access to data and applications by requiring a
second form of authentication.

Azure AD Identity Protection A tool that allows organizations to automate the detection
and remediation of identity-based risks, investigate risks
using data in the portal, and export risk detection data to
third-party utilities for further analysis.

Infrastructure & Network

VPN Gateway A virtual network gateway that is used to send encrypted


traffic between an Azure virtual network and an on-premises
location over the public Internet and to send encrypted
traffic between Azure virtual networks over the Microsoft
network.

Azure DDoS Protection Standard Provides enhanced DDoS mitigation features to defend
against DDoS attacks. It is automatically tuned to help
protect your specific Azure resources in a virtual network.

Azure Front Door A global, scalable entry-point that uses the Microsoft global
edge network to create fast, secure, and widely scalable web
applications.

Azure Firewall A managed, cloud-based network security service that


protects your Azure Virtual Network resources. It's a fully
stateful firewall as a service with built-in high availability and
unrestricted cloud scalability.

Azure Key Vault A secure secrets store for tokens, passwords, certificates, API
keys, and other secrets. Key Vault can also be used to create
and control the encryption keys used to encrypt your data.
SERVIC E DESC RIP T IO N

Key Vault Managed HSM A fully managed, highly available, single-tenant, standards-
compliant cloud service that enables you to safeguard
cryptographic keys for your cloud applications, using FIPS
140-2 Level 3 validated HSMs.

Azure Private Link Enables you to access Azure PaaS Services (for example,
Azure Storage and SQL Database) and Azure hosted
customer-owned/partner services over a private endpoint in
your virtual network.

Azure Application Gateway An advanced web traffic load balancer that enables you to
manage traffic to your web applications. Application
Gateway can make routing decisions based on additional
attributes of an HTTP request, for example URI path or host
headers.

Azure Service Bus A fully managed enterprise message broker with message
queues and publish-subscribe topics. Service Bus is used to
decouple applications and services from each other.

Web Application Firewall Provides centralized protection of your web applications


from common exploits and vulnerabilities. WAF can be
deployed with Azure Application Gateway and Azure Front
Door.

Data & Application

Azure Backup Provides simple, secure, and cost-effective solutions to back


up your data and recover it from the Microsoft Azure cloud.

Azure Storage Service Encryption Automatically encrypts data before it is stored and
automatically decrypts the data when you retrieve it.

Azure Information Protection A cloud-based solution that enables organizations to


discover, classify, and protect documents and emails by
applying labels to content.

API Management A way to create consistent and modern API gateways for
existing back-end services.

Azure confidential computing Allows you to isolate your sensitive data while it's being
processed in the cloud.

Azure DevOps Your development projects benefit from multiple layers of


security and governance technologies, operational practices,
and compliance policies when stored in Azure DevOps.

Customer Access

Azure AD External Identities With External Identities in Azure AD, you can allow people
outside your organization to access your apps and
resources, while letting them sign in using whatever identity
they prefer.
SERVIC E DESC RIP T IO N

You can share your apps and resources with external users
via Azure AD B2B collaboration.

Azure AD B2C lets you support millions of users and billions


of authentications per day, monitoring and automatically
handling threats like denial-of-service, password spray, or
brute force attacks.

Detect threats

SERVIC E DESC RIP T IO N

Microsoft Defender for Cloud Brings advanced, intelligent, protection of your Azure and
hybrid resources and workloads. The workload protection
dashboard in Defender for Cloud provides visibility and
control of the cloud workload protection features for your
environment.

Microsoft Sentinel A scalable, cloud-native, security information event


management (SIEM) and security orchestration automated
response (SOAR) solution. Sentinel delivers intelligent
security analytics and threat intelligence across the
enterprise, providing a single solution for alert detection,
threat visibility, proactive hunting, and threat response.

Identity & Access Management

Microsoft 365 Defender A unified pre- and post-breach enterprise defense suite that
natively coordinates detection, prevention, investigation, and
response across endpoints, identities, email, and applications
to provide integrated protection against sophisticated
attacks.

Microsoft Defender for Endpoint is an enterprise endpoint


security platform designed to help enterprise networks
prevent, detect, investigate, and respond to advanced
threats.

Microsoft Defender for Identity is a cloud-based security


solution that leverages your on-premises Active Directory
signals to identify, detect, and investigate advanced threats,
compromised identities, and malicious insider actions
directed at your organization.

Azure AD Identity Protection Sends two types of automated notification emails to help
you manage user risk and risk detections: Users at risk
detected email and Weekly digest email.

Infrastructure & Network


SERVIC E DESC RIP T IO N

Microsoft Defender for IoT A unified security solution for identifying IoT/OT devices,
vulnerabilities, and threats. It enables you to secure your
entire IoT/OT environment, whether you need to protect
existing IoT/OT devices or build security into new IoT
innovations.

Azure Network Watcher Provides tools to monitor, diagnose, view metrics, and
enable or disable logs for resources in an Azure virtual
network. Network Watcher is designed to monitor and repair
the network health of IaaS products which includes virtual
machines, virtual networks, application gateways, and load
balancers.

Azure Policy audit logging Helps to enforce organizational standards and to assess
compliance at-scale. Azure Policy uses activity logs, which are
automatically enabled to include event source, date, user,
timestamp, source addresses, destination addresses, and
other useful elements.

Data & Application

Microsoft Defender for container registries Includes a vulnerability scanner to scan the images in your
Azure Resource Manager-based Azure Container Registry
registries and provide deeper visibility into your images'
vulnerabilities.

Microsoft Defender for Kubernetes Provides cluster-level threat protection by monitoring your
AKS-managed services through the logs retrieved by Azure
Kubernetes Service (AKS).

Microsoft Defender for Cloud Apps A cloud access security broker (CASB) that operates on
multiple clouds. It provides rich visibility, control over data
travel, and sophisticated analytics to identify and combat
cyberthreats across all your cloud services.

Investigate and respond

SERVIC E DESC RIP T IO N

Microsoft Sentinel Powerful search and query tools to hunt for security threats
across your organization's data sources.

Azure Monitor logs and metrics Delivers a comprehensive solution for collecting, analyzing,
and acting on telemetry from your cloud and on-premises
environments. Azure Monitor collects and aggregates data
from a variety of sources into a common data platform
where it can be used for analysis, visualization, and alerting.

Identity & Access Management

Azure AD reports and monitoring Azure AD reports provide a comprehensive view of activity
in your environment.
SERVIC E DESC RIP T IO N

Azure AD monitoring lets you route your Azure AD activity


logs to different endpoints.

Azure AD PIM audit history Shows all role assignments and activations within the past
30 days for all privileged roles.

Data & Application

Microsoft Defender for Cloud Apps Provides tools to gain a deeper understanding of what's
happening in your cloud environment.

Next steps
Understand your shared responsibility in the cloud.
Understand the isolation choices in the Azure cloud against both malicious and non-malicious users.
Shared responsibility in the cloud
12/12/2021 • 2 minutes to read • Edit Online

As you consider and evaluate public cloud services, it’s critical to understand the shared responsibility model
and which security tasks are handled by the cloud provider and which tasks are handled by you. The workload
responsibilities vary depending on whether the workload is hosted on Software as a Service (SaaS), Platform as
a Service (PaaS), Infrastructure as a Service (IaaS), or in an on-premises datacenter

Division of responsibility
In an on-premises datacenter, you own the whole stack. As you move to the cloud some responsibilities transfer
to Microsoft. The following diagram illustrates the areas of responsibility between you and Microsoft, according
to the type of deployment of your stack.

For all cloud deployment types, you own your data and identities. You are responsible for protecting the security
of your data and identities, on-premises resources, and the cloud components you control (which varies by
service type).
Regardless of the type of deployment, the following responsibilities are always retained by you:
Data
Endpoints
Account
Access management

Cloud security advantages


The cloud offers significant advantages for solving long standing information security challenges. In an on-
premises environment, organizations likely have unmet responsibilities and limited resources available to invest
in security, which creates an environment where attackers are able to exploit vulnerabilities at all layers.
The following diagram shows a traditional approach where many security responsibilities are unmet due to
limited resources. In the cloud-enabled approach, you are able to shift day to day security responsibilities to
your cloud provider and reallocate your resources.

In the cloud-enabled approach, you are also able to leverage cloud-based security capabilities for more
effectiveness and use cloud intelligence to improve your threat detection and response time. By shifting
responsibilities to the cloud provider, organizations can get more security coverage, which enables them to
reallocate security resources and budget to other business priorities.

Next steps
For more information on the division of responsibility between you and Microsoft in a SaaS, PaaS, and IaaS
deployment, see Shared responsibilities for cloud computing.
Backup and restore plan to protect against
ransomware
12/12/2021 • 18 minutes to read • Edit Online

Ransomware attacks deliberately encrypt or erase data and systems to force your organization to pay money to
attackers. These attacks target your data, your backups, and also key documentation required for you to recover
without paying the attackers (as a means to increase the chances your organization will pay).
This article addresses what to do before an attack to protect your critical business systems and during an attack
to ensure a rapid recovery of business operations.

NOTE
Preparing for ransomware also improves resilience to natural disasters and rapid attacks like WannaCry & (Not)Petya.

What is ransomware?
Ransomware is a type of extortion attack that encrypts files and folders, preventing access to important data
and systems. Attackers use ransomware to extort money from victims by demanding money, usually in the form
of cryptocurrencies, in exchange for a decryption key or in exchange for not releasing sensitive data to the dark
web or the public internet.
While early ransomware mostly used malware that spread with phishing or between devices, human-operated
ransomware has emerged where a gang of active attackers, driven by human attack operators, target all
systems in an organization (rather than a single device or set of devices). An attack can:
Encrypt your data
Exfiltrate your data
Corrupt your backups
The ransomware leverages the attackers’ knowledge of common system and security misconfigurations and
vulnerabilities to infiltrate the organization, navigate the enterprise network, and adapt to the environment and
its weaknesses as they go.
Ransomware can be staged to exfiltrate your data first, over several weeks or months, before the ransomware
actually executes on a specific date.
Ransomware can also slowly encrypt your data while keeping your key on the system. With your key still
available, your data is usable to you and the ransomware goes unnoticed. Your backups, though, are of the
encrypted data. Once all of your data is encrypted and recent backups are also of encrypted data, your key is
removed so you can no longer read your data.
The real damage is often done when the attack exfiltrates files while leaving backdoors in the network for future
malicious activity—and these risks persist whether or not the ransom is paid. These attacks can be catastrophic
to business operations and difficult to clean up, requiring complete adversary eviction to protect against future
attacks. Unlike early forms of ransomware that only required malware remediation, human-operated
ransomware can continue to threaten your business operations after the initial encounter.
Impact of an attack
The impact of a ransomware attack on any organization is difficult to quantify accurately. Depending on the
scope of the attack, the impact could include:
Loss of data access
Business operation disruption
Financial loss
Intellectual property theft
Compromised customer trust or tarnished reputation
Legal expenses

How can you protect yourself?


The best way to prevent falling victim to ransomware is to implement preventive measures and have tools that
protect your organization from every step that attackers take to infiltrate your systems.
You can reduce your on-premises exposure by moving your organization to a cloud service. Microsoft has
invested in native security capabilities that make Microsoft Azure resilient against ransomware attacks and helps
organizations defeat ransomware attack techniques. For a comprehensive view of ransomware and extortion
and how to protect your organization, use the information in the Human-Operated Ransomware Mitigation
Project Plan PowerPoint presentation.
You should assume that at some point in time you will fall victim to a ransomware attack. One of the most
important steps you can take to protect your data and avoid paying a ransom is to have a reliable backup and
restore plan for your business-critical information. Since ransomware attackers have invested heavily into
neutralizing backup applications and operating system features like volume shadow copy, it is critical to have
backups that are inaccessible to a malicious attacker.
Azure Backup
Azure Backup provides security to your backup environment, both when your data is in transit and at rest. With
Azure Backup, you can back up:
On-premises files, folders, and system state
Entire Windows/Linux VMs
Azure Managed Disks
Azure file shares to a storage account
SQL Server databases running on Azure VMs
The backup data is stored in Azure storage and the guest or attacker has no direct access to backup storage or
its contents. With virtual machine backup, the backup snapshot creation and storage is done by Azure fabric
where the guest or attacker has no involvement other than quiescing the workload for application consistent
backups. With SQL and SAP HANA, the backup extension gets temporary access to write to specific blobs. In this
way, even in a compromised environment, existing backups can't be tampered with or deleted by the attacker.
Azure Backup provides built-in monitoring and alerting capabilities to view and configure actions for events
related to Azure Backup. Backup Reports serve as a one-stop destination for tracking usage, auditing of backups
and restores, and identifying key trends at different levels of granularity. Using Azure Backup's monitoring and
reporting tools can alert you to any unauthorized, suspicious, or malicious activity as soon as they occur.
Checks have been added to make sure only valid users can perform various operations. These include adding an
extra layer of authentication. As part of adding an extra layer of authentication for critical operations, you're
prompted to enter a security PIN before modifying online backups.
Learn more about the security features built into Azure Backup.
Validate backups
Validate that your backup is good as your backup is created and before you restore. We recommend that you
use a Recovery Services vault, which is a storage entity in Azure that houses data. The data is typically copies of
data, or configuration information for virtual machines (VMs), workloads, servers, or workstations. You can use
Recovery Services vaults to hold backup data for various Azure services such as IaaS VMs (Linux or Windows)
and Azure SQL databases as well as on-premises assets. Recovery Services vaults make it easy to organize your
backup data and provide features such as:
Enhanced capabilities to ensure you can secure your backups, and safely recover data, even if production and
backup servers are compromised. Learn more.
Monitoring for your hybrid IT environment (Azure IaaS VMs and on-premises assets) from a central portal.
Learn more.
Compatibility with Azure role-based access control (Azure RBAC), which restricts backup and restore access
to a defined set of user roles. Azure RBAC provides various built-in roles, and Azure Backup has three built-in
roles to manage recovery points. Learn more.
Soft delete protection, even if a malicious actor deletes a backup (or backup data is accidentally deleted).
Backup data is retained for 14 additional days, allowing the recovery of a backup item with no data loss.
Learn more.
Cross Region Restore which allows you to restore Azure VMs in a secondary region, which is an Azure paired
region. You can restore the replicated data in the secondary region any time. This enables you to restore the
secondary region data for audit-compliance, and during outage scenarios, without waiting for Azure to
declare a disaster (unlike the GRS settings of the vault). Learn more.

NOTE
There are two types of vaults in Azure Backup. In addition to the Recovery Services vaults, there are also Backup vaults
that house data for newer workloads supported by Azure Backup.

What to do before an attack


As mentioned earlier, you should assume that at some point in time you will fall victim to a ransomware attack.
Identifying your business-critical systems and applying best practices before an attack will get you back up and
running as quickly as possible.
Determine what is most important to you
Ransomware can attack while you are planning for an attack so your first priority should be to identify the
business-critical systems that are most important to you and begin performing regular backups on those
systems.
In our experience, the five most important applications to customers fall into the following categories in this
priority order:
Identity systems – required for users to access any systems (including all others described below) such as
Active Directory, Azure AD Connect, AD domain controllers
Human life – any system that supports human life or could put it at risk such as medical or life support
systems, safety systems (ambulance, dispatch systems, traffic light control), large machinery,
chemical/biological systems, production of food or personal products, and others
Financial systems – systems that process monetary transactions and keep the business operating, such as
payment systems and related databases, financial system for quarterly reporting
Product or service enablement – any systems that are required to provide the business services or
produce/deliver physical products that your customers pay you for, factory control systems, product
delivery/dispatch systems, and similar
Security (minimum) – You should also prioritize the security systems required to monitor for attacks and
provide minimum security services. This should be focused on ensuring that the current attacks (or easy
opportunistic ones) are not immediately able to gain (or regain) access to your restored systems
Your prioritized back up list also becomes your prioritized restore list. Once you’ve identified your critical
systems and are performing regular backups, then take steps to reduce your exposure level.
Steps to take before an attack
Apply these best practices before an attack.

TA SK DETA IL

Identify the important systems that you need to bring back To get back up and running as quickly as possible after an
online first (using top five categories above) and immediately attack, determine today what is most important to you.
begin performing regular backups of those systems.

Migrate your organization to the cloud. Reduce your on-premises exposure by moving data to cloud
services with automatic backup and self-service rollback.
Consider purchasing a Microsoft Unified Support plan or Microsoft Azure has a robust set of tools to help you backup
working with a Microsoft partner to help support your move your business-critical systems and restore your backups
to the cloud. faster.

Microsoft Unified Support is a cloud services support model


that is there to help you whenever you need it. Unified
Support:

Provides a designated team that is available 24x7 with as-


needed problem resolution and critical incident escalation

Helps you monitor the health of your IT environment and


works proactively to make sure problems are prevented
before they happen

Move user data to cloud solutions like OneDrive and User data in the Microsoft cloud can be protected by built-in
SharePoint to take advantage of versioning and recycle bin security and data management features.
capabilities.
It's good to teach users how to restore their own files but
Educate users on how to recover their files by themselves to you need to be careful that your users do not restore the
reduce delays and cost of recovery. For example, if a user’s malware used to carry out the attack. You need to:
OneDrive files were infected by malware, they can restore
their entire OneDrive to a previous time. Ensure your users don't restore their files until you are
confident that the attacker has been evicted
Consider a defense strategy, such as Microsoft 365
Defender, before allowing users to restore their own files. Have a mitigation in place in case a user does restore some
of the malware

Microsoft 365 Defender uses AI-powered automatic actions


and playbooks to remediate impacted assets back to a
secure state. Microsoft 365 Defender leverages automatic
remediation capabilities of the suite products to ensure all
impacted assets related to an incident are automatically
remediated where possible.

Implement Azure Security Benchmark. Azure Security Benchmark is Azure’s own security control
framework based on industry-based security control
frameworks such as NIST SP800-53, CIS Controls v7.1. It
provides organizations guidance on how to configure Azure
and Azure services and implement the security controls. See
Backup and Recovery.
TA SK DETA IL

Regularly exercise your business continuity/disaster recovery Ensures rapid recovery of business operations by treating a
(BC/DR) plan. ransomware or extortion attack with the same importance
as a natural disaster.
Simulate incident response scenarios. Exercises you perform
in preparing for an attack should be planned and conducted Conduct practice exercise(s) to validate cross-team processes
around your prioritized backup and restore lists. and technical procedures, including out of band employee
and customer communications (assume all email and chat is
Regularly test ‘Recover from Zero’ scenario to ensure your down).
BC/DR can rapidly bring critical business operations online
from zero functionality (all systems down).

Consider creating a risk register to identify potential risks A risk register can help you prioritize risks based on the
and address how you will mediate through preventative likelihood of that risk occurring and the severity to your
controls and actions. Add ransomware to risk register as business should that risk occur.
high likelihood and high impact scenario.
Track mitigation status via Enterprise Risk Management
(ERM) assessment cycle.

Backup all critical business systems automatically on a Allows you to recover data up to the last backup.
regular schedule (including backup of critical dependencies
like Active Directory).

Validate that your backup is good as your backup is created.

Protect (or print) supporting documents and systems Attackers deliberately target these resources because it
required for recovery such as restoration procedure impacts your ability to recover.
documents, CMDB, network diagrams, and SolarWinds
instances.

Ensure you have well-documented procedures for engaging Third-party contacts may be useful if the given ransomware
any third-party support, particularly support from threat variant has known weaknesses or decryption tools are
intelligence providers, antimalware solution providers, and available.
from the malware analysis provider. Protect (or print) these
procedures.

Ensure backup and recovery strategy includes: Backups are essential for resilience after an organization has
been breached. Apply the 3-2-1 rule for maximum
Ability to back up data to a specific point in time. protection and availability: 3 copies (original + 2 backups), 2
storage types, and 1 offsite or cold copy.
Multiple copies of backups are stored in isolated, offline (air-
gapped) locations.

Recovery time objectives that establish how quickly backed


up information can be retrieved and put into production
environment.

Rapid restore of back up to a production


environment/sandbox.
TA SK DETA IL

Protect backups against deliberate erasure and encryption: Backups that are accessible by attackers can be rendered
unusable for business recovery.
Store backups in offline or off-site storage and/or immutable
storage. Offline storage ensures robust transfer of backup data
without using any network bandwidth. Azure Backup
Require out of band steps (such as MFA or a security PIN) supports offline backup, which transfers initial backup data
before permitting an online backup to be modified or erased. offline, without the use of network bandwidth. It provides a
mechanism to copy backup data onto physical storage
Create private endpoints within your Azure Virtual Network devices. The devices are then shipped to a nearby Azure
to securely back up and restore data from your Recovery datacenter and uploaded onto a Recovery Services vault.
Services vault.
Online immutable storage (such as Azure Blob) enables you
to store business-critical data objects in a WORM (Write
Once, Read Many) state. This state makes the data non-
erasable and non-modifiable for a user-specified interval.

Multifactor authentication (MFA) should be mandatory for


all admin accounts and is strongly recommended for all
users. The preferred method is to use an authenticator app
rather than SMS or voice where possible. When you set up
Azure Backup you can configure your recovery services to
enable MFA using a security PIN generated in the Azure
portal. This ensures that a security pin is generated to
perform critical operations such as updating or removing a
recovery point.

Designate protected folders. Makes it more difficult for unauthorized applications to


modify the data in these folders.

Review your permissions: Reduces risk from broad access-enabling ransomware


activities.
Discover broad write/delete permissions on file shares,
SharePoint, and other solutions. Broad is defined as many
users having write/delete permissions for business-critical
data.

Reduce broad permissions while meeting business


collaboration requirements.

Audit and monitor to ensure broad permissions don’t


reappear.

Protect against a phishing attempt: The most common method used by attackers to infiltrate an
organization is phishing attempts via email. Exchange Online
Conduct security awareness training regularly to help users Protection (EOP) is the cloud-based filtering service that
identify a phishing attempt and avoid clicking on something protects your organization against spam, malware, and other
that can create an initial entry point for a compromise. email threats. EOP is included in all Microsoft 365
organizations with Exchange Online mailboxes.
Apply security filtering controls to email to detect and
minimize the likelihood of a successful phishing attempt. An example of a security filtering control for email is Safe
Links. Safe Links is a feature in Defender for Office 365 that
provides URL scanning and rewriting of inbound email
messages in mail flow, and time-of-click verification of URLs
and links in email messages and other locations. Safe Links
scanning occurs in addition to the regular anti-spam and
anti-malware protection in inbound email messages in EOP.
Safe Links scanning can help protect your organization from
malicious links that are used in phishing and other attacks.

Learn more about anti-phishing protection.


What to do during an attack
If you are attacked, your prioritized back up list becomes your prioritized restore list. Before you restore, validate
again that your backup is good. You may be able to look for malware inside the backup.
Steps to take during an attack
Apply these best practices during an attack.

TA SK DETA IL

Early in the attack, engage third-party support, particularly These contacts may be useful if the given ransomware
support from threat intelligence providers, antimalware variant has a known weakness or decryption tools are
solution providers and from the malware analysis provider. available.

Microsoft Detection and Response Team (DART) can help


protect you from attacks. The DART engages with customers
around the world, helping to protect and harden against
attacks before they occur, as well as investigating and
remediating when an attack has occurred.

Microsoft also provides Rapid Ransomware Recovery


services. Services are exclusivelydelivered by the Microsoft
Global Compromise Recovery Security Practice (CRSP). The
focus of this team during a ransomware attack is to restore
authentication service and limit the impact of ransomware.

DART and CRSP are part of Microsoft’s Industry Solutions


Delivery security service line.

Contact your local or federal law enforcement agencies. If you are in the United States, contact the FBI to report a
ransomware breach using the IC3 Complaint Referral Form.

Take steps to remove malware or ransomware payload from You can use Windows Defender or (for older clients)
your environment and stop the spread. Microsoft Security Essentials.

Run a full, current antivirus scan on all suspected computers An alternative that will also help you remove ransomware or
and devices to detect and remove the payload that's malware is the Malicious Software Removal Tool (MSRT).
associated with the ransomware.

Scan devices that are synchronizing data, or the targets of


mapped network drives.

Restore business-critical systems first. Remember to validate At this point, you don’t need to restore everything. Focus on
again that your backup is good before you restore. the top five business-critical systems from your restore list.

If you have offline backups, you can probably restore the To prevent future attacks, ensure ransomware or malware is
encrypted data after you've removed the ransomware not on your offline backup before restoring.
payload (malware) from your environment.

Identify a safe point-in-time backup image that is known not To prevent future attacks, scan backup for ransomware or
to be infected. malware before restoring.

If you use Recovery Services vault, carefully review the


incident timeline to understand the right point-in-time to
restore a backup.

Use a safety scanner and other tools for full operating Microsoft Safety Scanner is a scan tool designed to find and
system restore as well as data restore scenarios. remove malware from Windows computers. Simply
download it and run a scan to find malware and try to
reverse changes made by identified threats.
TA SK DETA IL

Ensure that your antivirus or endpoint detection and An EDR solution, such as Microsoft Defender for Endpoint, is
response (EDR) solution is up to date. You also need to have preferred.
up-to-date patches.

After business-critical systems are up and running, restore Telemetry data should help you identify if malware is still on
other systems. your systems.

As systems get restored, start collecting telemetry data so


you can make formative decisions about what you are
restoring.

Post attack or simulation


After a ransomware attack or an incident response simulation, take the following steps to improve your backup
and restore plans as well as your security posture:
1. Identify lessons learned where the process did not work well (and opportunities to simplify, accelerate, or
otherwise improve the process)
2. Perform root cause analysis on the biggest challenges (at enough detail to ensure solutions address the right
problem — considering people, process, and technology)
3. Investigate and remediate the original breach (engage the Microsoft Detection and Response Team (DART) to
help)
4. Update your backup and restore strategy based on lessons learned and opportunities — prioritizing based
on highest impact and quickest implementation steps first

Next steps
In this article, you learned how to improve your backup and restore plan to protect against ransomware. For
best practices on deploying ransomware protection, see Rapidly protect against ransomware and extortion.
Key industry information:
Microsoft Digital Defense Report (see pages 22-24)
Microsoft Azure:
Help protect from ransomware with Microsoft Azure Backup (26 minute video)
Recovering from systemic identity compromise
Advanced multistage attack detection in Microsoft Sentinel
Microsoft 365:
Recover from a ransomware attack
Malware and ransomware protection
Protect your Windows 10 PC from ransomware
Handling ransomware in SharePoint Online
Microsoft 365 Defender:
Find ransomware with advanced hunting
Microsoft Security team blog posts:
Becoming resilient by understanding cybersecurity risks: Part 4, navigating current threats (May 2021). See
the Ransomware section
Human-operated ransomware attacks: A preventable disaster (March 2020). Includes attack chain analysis of
actual human-operated ransomware attacks
Ransomware response — to pay or not to pay? (December 2019)
Norsk Hydro responds to ransomware attack with transparency (December 2019)
Recovering from systemic identity compromise
12/12/2021 • 20 minutes to read • Edit Online

This article describes Microsoft resources and recommendations for recovering from a systemic identity
compromise attack against your organization, such as the Nobelium attack of December 2020.
The content in this article is based on guidance provided by Microsoft's Detection and Response Team (DART),
which works to respond to compromises and help customers become cyber-resilient. For more guidance from
the DART team, see their Microsoft security blog series.
Many organizations have transitioned to a cloud-based approach for stronger security on their identity and
access management. However, your organization may also have on-premises systems in place and use varying
methods of hybrid architecture. This article acknowledges that systemic identity attacks affect cloud, on-
premises, and hybrid systems, and provides recommendations and references for all of these environments.

IMPORTANT
This information is provided as-is and constitutes generalized guidance; the ultimate determination about how to apply
this guidance to your IT environment and tenant(s) must consider your unique environment and needs, which each
Customer is in the best position to determine.

About systemic identity compromise


A systemic identity compromise attack on an organization occurs when an attacker successfully gains a foothold
into the administration of an organization's identity infrastructure.
If this has happened to your organization, you are in a race against the attacker to secure your environment
before further damage can be done.
Attackers with administrative control of an environment's identity infrastructure can use that
control to create, modify, or delete identities and identity permissions in that environment.
In an on-premises compromise, if trusted SAML token-signing certificates are not stored in an HSM, the
attack includes access to that trusted SAML token-signing certificate.
Attackers can then use the cer tificate to forge SAML tokens to impersonate any of the
organization's existing users and accounts without requiring access to account credentials, and without
leaving any traces.
Highly-privileged account access can also be used to add attacker-controlled credentials to existing
applications, enabling attackers to access your system undetected, such as to call APIs, using those
permissions.

Responding to the attack


Responding to systemic identity compromises should include the steps shown in the following image and table:
ST EP DESC RIP T IO N

Establish secure communications An organization that has experienced a systemic identity


compromise must assume that all communication is affected.
Before taking any recovery action, you must ensure that the
members of your team who are key to your investigation
and response effort can communicate securely.

Securing communications must be your very first step so


that you can proceed without the attacker's knowledge.

Investigate your environment After you have secured communications on your core
investigation team, you can start looking for initial access
points and persistence techniques. Identify your indications
of compromise, and then look for initial access points and
persistence. At the same time, start establishing continuous
monitoring operations during your recovery efforts.

Improve security posture Enable security features and capabilities following best
practice recommendations for improved system security
moving forward.

Make sure to continue your continuous monitoring efforts


as time goes on and the security landscape changes.

Regain / retain control You must regain administrative control of your environment
from the attacker. After you have control again and have
refreshed your system's security posture, make sure to
remediate or block all possible persistence techniques and
new initial access exploits.

Establish secure communications


Before you start responding, you must be sure that you can communicate safely without the attacker
eavesdropping. Make sure to isolate any communications related to the incident so that the attacker is not
tipped-off to your investigation and is taken by surprise at your response actions.
For example:
1. For initial one-on-one and group communications, you may want to use PSTN calls, conference bridges
that are not connected to the corporate infrastructure, and end-to-end encrypted messaging solutions.
Communications outside these frameworks should be treated as compromised and untrusted, unless
verified through a secure channel.
2. After those initial conversations, you may want to create an entirely new Microsoft 365 tenant, isolated
from the organization's production tenant. Create accounts only for key personnel who need to be part of
the response.
If you do create a new Microsoft 365 tenant, make sure to follow all best practices for the tenant, and especially
for administrative accounts and rights. Limit administrative rights, with no trusts for outside applications or
vendors.

IMPORTANT
Make sure that you do not communicate about your new tenant on your existing, and potentially compromised, email
accounts.

For more information, see Best practices for securely using Microsoft 365.

Identify indications of compromise


We recommend that customers follow updates from system providers, including both Microsoft and any
partners, and implement any new detections and protections provided and identify published incidents of
compromise (IOCs).
Check for updates in the following Microsoft security products, and implement any recommended changes:
Microsoft Sentinel
Microsoft 365 security solutions and services
Windows 10 Enterprise Security
Microsoft Defender for Cloud Apps
Implementing new updates will help identify any prior campaigns and prevent future campaigns against your
system. Keep in mind that lists of IOCs may not be exhaustive, and may expand as investigations continue.
Therefore, we recommend also taking the following actions:
Make sure that you've applied the Azure security benchmark documentation, and are monitoring
compliance via Microsoft Defender for Cloud.
Incorporate threat intelligence feeds into your SIEM, such as by configuring Microsoft 365 data
connectors in Microsoft Sentinel.
For more information, see Microsoft's security documentation:
Microsoft security documentation
Azure security documentation

Investigate your environment


Once your incident responders and key personnel have a secure place to collaborate, you can start investigating
the compromised environment.
You'll need to balance getting to the bottom of every anomalous behavior and taking quick action to stop any
further activity by the attacker. Any successful remediation requires an understanding of the initial method of
entry and persistence methods that the attacker used, as complete as is possible at the time. Any persistence
methods missed during the investigation can result in continued access by the attacker, and a potential
recompromise.
At this point, you may want to perform a risk analysis to prioritize your actions. For more information, see:
Datacenter threat, vulnerability, and risk assessment
Track and respond to emerging threats with threat analytics
Threat and vulnerability management
Microsoft's security services provide extensive resources for detailed investigations. The following sections
describe top recommended actions.

NOTE
If you find that one or more of the listed logging sources is not currently part of your security program, we recommend
configuring them as soon as possible to enable detections and future log reviews.
Make sure to configure your log retention to support your organization’s investigation goals going forward. Retain
evidence as needed for legal, regulatory, or insurance purposes.

Investigate and review cloud environment logs


Investigate and review cloud environment logs for suspicious actions and attacker indications of compromise.
For example, check the following logs:
Unified Audit Logs (UAL)
Azure Active Directory (Azure AD) logs
Microsoft Exchange on-premises logs
VPN logs, such as from VPN Gateway
Engineering system logs
Antivirus and endpoint detection logs
Review endpoint audit logs
Review your endpoint audit logs for on-premises changes, such as the following types of actions:
Group membership changes
New user account creation
Delegations within Active Directory
Especially consider any of these changes that occur along with other typical signs of compromise or activity.
Review administrative rights in your environments
Review administrative rights in both your cloud and on-premises environments. For example:

EN VIRO N M EN T DESC RIP T IO N

All cloud environments - Review any privileged access rights in the cloud and
remove any unnecessary permissions
- Implement Privileged Identity Management (PIM)
- Set up Conditional Access policies to limit administrative
access during hardening

All on-premises environments - Review privileged access on-premise and remove


unnecessary permissions
- Reduce membership of built-in groups
- Verify Active Directory delegations
- Harden your Tier 0 environment, and limit who has access
to Tier 0 assets
EN VIRO N M EN T DESC RIP T IO N

All Enterprise applications Review for delegated permissions and consent grants that
allow any of the following actions:

- Modifying privileged users and roles


- Reading or accessing all mailboxes
- Sending or forwarding email on behalf of other users
- Accessing all OneDrive or SharePoint site content
- Adding service principals that can read/write to the
directory

Microsoft 365 environments Review access and configuration settings for your Microsoft
365 environment, including:
- SharePoint Online Sharing
- Microsoft Teams
- Power Apps
- Microsoft OneDrive for Business

Review user accounts in your environments - Review and remove guest user accounts that are no longer
needed.
- Review email configurations for delegates, mailbox folder
permissions, ActiveSync mobile device registrations, Inbox
rules, and Outlook on the Web options.
- Review ApplicationImpersonation rights and reduce any
use of legacy authentication as much as possible.
- Validate that MFA is enforced and that both MFA and self-
service password reset (SSPR) contact information for all
users is correct.

Establish continuous monitoring


Detecting attacker behavior includes several methods, and depends on the security tools your organization has
available for responding to the attack.
For example, Microsoft security services may have specific resources and guidance that's relevant to the attack,
as described in the sections below.

IMPORTANT
If your investigation finds evidence of administrative permissions acquired through the compromise on your system,
which have provided access to your organization's global administrator account and/or trusted SAML token-signing
certificate, we recommend taking action to remediate and retain administrative control.

Monitoring with Microsoft Sentinel


Microsoft Sentinel has many built-in resources to help in your investigation, such as hunting workbooks and
analytics rules that can help detect attacks in relevant areas of your environment.
For more information, see:
Visualize and analyze your environment
Detect threats out of the box.
Monitoring with Microsoft 365 Defender
We recommend that you check Microsoft 365 Defender for Endpoint and Microsoft Defender Antivirus for
specific guidance relevant to your attack.
Check for other examples of detections, hunting queries, and threat analytics reports in the Microsoft security
center, such as in Microsoft 365 Defender, Microsoft 365 Defender for Identity, and Microsoft Defender for Cloud
Apps. To ensure coverage, make sure that you install the Microsoft Defender for Identity agent on ADFS servers
in addition to all domain controllers.
For more information, see:
Track and respond to emerging threats with threat analytics
Understand the analyst report in threat analytics
Monitoring with Azure Active Directory
Azure Active Directory sign-in logs can show whether multi-factor authentication is being used correctly. Access
sign-in logs directly from the Azure Active Directory area in the Azure portal, use the Get-
AzureADAuditSignInLogs cmdlet, or view them in the Logs area of Microsoft Sentinel.
For example, search or filter the results for when the MFA results field has a value of MFA requirement
satisfied by claim in the token . If your organization uses ADFS and the claims logged are not included in the
ADFS configuration, these claims may indicate attacker activity.
Search or filter your results further to exclude extra noise. For example, you may want to include results only
from federated domains. If you find suspicious sign-ins, drill down even further based on IP addresses, user
accounts, and so on.
The following table describes more methods for using Azure Active directory logs in your investigation:

M ET H O D DESC RIP T IO N

Analyze risky sign-in events Azure Active Directory and its Identity Protection platform
may generate risk events associated with the use of
attacker-generated SAML tokens.

These events might be labeled as unfamiliar properties,


anonymous IP address, impossible travel, and so on.

We recommend that you closely analyze all risk events


associated with accounts that have administrative privileges,
including any that may have been automatically been
dismissed or remediated. For example, a risk event or an
anonymous IP address might be automatically remediated
because the user passed MFA.

Make sure to use ADFS Connect Health so that all


authentication events are visible in Azure AD.

Detect domain authentication proper ties Any attempt by the attacker to manipulate domain
authentication policies will be recorded in the Azure Active
Directory Audit logs, and reflected in the Unified Audit log.

For example, review any events associated with Set domain


authentication in the Unified Audit Log, Azure AD Audit
logs, and / or your SIEM environment to verify that all
activities listed were expected and planned.
M ET H O D DESC RIP T IO N

Detect credentials for OAuth applications Attackers who have gained control of a privileged account
may search for an application with the ability to access any
user's email in the organization, and then add attacker-
controlled credentials to that application.

For example, you may want to search for any of the


following activities, which would be consistent with attacker
behavior:
- Adding or updating service principal credentials
- Updating application certificates and secrets
- Adding an app role assignment grant to a user
- Adding Oauth2PermissionGrant

Detect e-mail access by applications Search for access to email by applications in your
environment. For example, use the Microsoft 365 Advanced
Auditing features to investigate compromised accounts.

Detect non-interactive sign-ins to ser vice principals The Azure Active Directory sign-in reports provide details
about any non-interactive sign-ins that used service
principal credentials. For example, you can use the sign-in
reports to find valuable data for your investigation, such as
an IP address used by the attacker to access email
applications.

Improve security posture


If a security event has occurred in your systems, we recommend that you reflect on your current security
strategy and priorities.
Incident Responders are often asked to provide recommendations on what investments the organization should
prioritize, now that it’s been faced with new threats.
In addition to the recommendations documented in this article, we recommend that you consider prioritizing
the areas of focus that are responsive to the post-exploitation techniques used by this attacker and the common
security posture gaps that enable them.
The following sections list recommendations to improve both general and identity security posture.
Improve general security posture
We recommend the following actions to ensure your general security posture:
Review Microsoft Secure Score for security fundamentals recommendations customized for the
Microsoft products and services you consume.
Ensure that your organization has EDR and SIEM solutions in place , such as Microsoft 365
Defender for Endpoint and Microsoft Sentinel.
Review Microsoft’s Enterprise access model .
Improve identity security posture
We recommend the following actions to ensure identity-related security posture:
Review Microsoft's Five steps to securing your identity infrastructure , and prioritize the steps as
appropriate for your identity architecture.
Consider migrating to Azure AD Security Defaults for your authentication policy.
Eliminate your organization’s use of legacy authentication , if systems or applications still require
it. For more information, see Block legacy authentication to Azure AD with Conditional Access.

NOTE
The Exchange Team is planning to disable Basic Authentication for the EAS, EWS, POP, IMAP, and RPS protocols in
the second half of 2021.
As a point of clarity, Security Defaults and Authentication Policies are separate but provide complementary
features.
We recommend that customers use Authentication Policies to turn off Basic Authentication for a subset of
Exchange Online protocols or to gradually turn off Basic Authentication across a large organization.

Treat your ADFS infrastructure and AD Connect infrastructure as a Tier 0 asset .


Restrict local administrative access to the system , including the account that is used to run the
ADFS service.
The least privilege necessary for the account running ADFS is the Log on as a Service User Right
Assignment.
Restrict administrative access to limited users and from limited IP address ranges by using
Windows Firewall policies for Remote Desktop.
We recommend that you set up a Tier 0 jump box or equivalent system.
Block all inbound SMB access to the systems from anywhere in the environment. For more
information, see Beyond the Edge: How to Secure SMB Traffic in Windows. We also recommend that you
stream the Windows Firewall logs to a SIEM for historical and proactive monitoring.
If you are using a Service Account and your environment supports it, migrate from a Ser vice Account
to a group-Managed Ser vice Account (gMSA) . If you cannot move to a gMSA, rotate the password
on the Service Account to a complex password.
Ensure Verbose logging is enabled on your ADFS systems . For example, run the following
commands:

Set-AdfsProperties -AuditLevel verbose


Restart-Service -Name adfssrv
Auditpol.exe /set /subcategory:”Application Generated” /failure:enable /success:enable

Remediate and retain administrative control


If your investigation has identified that the attacker has administrative control in the organization’s cloud or on-
premises environment, you must regain control in such a way that you ensure that the attacker isn't persistent.
This section provides possible methods and steps to consider when building your administrative control
recovery plan.
IMPORTANT
The exact steps required in your organization will depend on what persistence you've discovered in your investigation, and
how confident you are that your investigation was complete and has discovered all possible entry and persistence
methods.
Ensure that any actions taken are performed from a trusted device, built from a clean source. For example, use a fresh,
privileged access workstation.

The following sections include the following types of recommendations for remediating and retaining
administrative control:
Removing trust on your current servers
Rotating your SAML token-signing certificate, or replacing your ADFS servers if needed
Specific remediation activities for cloud or on-premises environments
Remove trust on your current servers
If your organization has lost control of the token-signing certificates or federated trust, the most assured
approach is to remove trust, and switch to cloud-mastered identity while remediating on-premises.
Removing trust and switching to cloud-mastered identity requires careful planning and an in-depth
understanding of the business operation effects of isolating identity. For more information, see Protecting
Microsoft 365 from on-premises attacks.
Rotate your SAML token-signing certificate
If your organization decides not to remove trust while recovering administrative control on-premises, you'll
have to rotate your SAML token-signing certificate after having regained administrative control on-premises,
and blocked the attackers ability to access the signing certificate again.
Rotating the token-signing certificate a single time still allows the previous token-signing certificate to work.
Continuing to allow previous certificates to work is a built-in functionality for normal certificate rotations, which
permits a grace period for organizations to update any relying party trusts before the certificate expires.
If there was an attack, you don't want the attacker to retain access at all. Make sure to use the following steps to
ensure that the attacker doesn't maintain the ability to forge tokens for your domain.
Cau t i on

The last step in this procedure logs users out of their phones, current webmail sessions, and any other items that
are using the associated tokens and refresh tokens.

TIP
Performing these steps in your ADFS environment creates both a primary and secondary certificate, and automatically
promotes the secondary certificate to primary after a default period of 5 days.
If you have Relying Party Trusts, this may have effects 5 days after the initial ADFS environment change, and should be
accounted for in your plan. You can also resolve this by replacing the primary certificate a third time, using the Urgent
flag again, and removing the secondary certificate or turning off automatic certificate rotation.

To fully rotate the token-signing cer tificate, and prevent new token forging by an attacker
1. Check to make sure that your AutoCer tificateRollover parameter is set to True :

Get-AdfsProperties | FL AutoCert*, Certificate*

If AutoCer tificateRollover isn't set to True , set the value as follows:


Set-ADFSProperties -AutoCertificateRollover $true

2. Connect to the Microsoft Online Service:

Connect-MsolService

3. Run the following command and make a note of your on-premises and cloud token signing certificate
thumbprint and expiration dates:

Get-MsolFederationProperty -DomainName <domain>

For example:

...
[Not Before]
12/9/2020 7:57:13 PM

[Not After]
12/9/2021 7:57:13 PM

[Thumbprint]
3UD1JG5MEFHSBW7HEPF6D98EI8AHNTY22XPQWJFK6

4. Replace the primary token signing certificate using the Urgent switch. This command causes ADFS to
replace the primary certificate immediately, without making it a secondary certificate:

Update-AdfsCertificate -CertificateType Token-Signing -Urgent

5. Create a secondary Token Signing certificate, without the Urgent switch. This command allows for two
on-premises token signing certificates before synching with Azure Cloud.

Update-AdfsCertificate -CertificateType Token-Signing

6. Update the cloud environment with both the primary and secondary certificates on-premises to
immediately remove the cloud published token signing certificate.

Update-MsolFederatedDomain -DomainName <domain>

IMPORTANT
If this step is not performed using this method, the old token signing certificate may still be able to authenticate
users.

7. To ensure that these steps have been performed correctly, verify that the certificate displayed before in
step 3 is now removed:

Get-MsolFederationProperty -DomainName <domain>

8. Revoke your refresh tokens via PowerShell, to prevent access with the old tokens.
For more information, see:
Revoke user access in Azure Active Directory
Revoke-AzureADUserAllRefreshToken PowerShell docs
Replace your ADFS servers
If, instead of rotating your SAML token-signing certificate, you decide to replace the ADFS servers with clean
systems, you'll need to remove the existing ADFS from your environment, and then build a new one.
For more information, see Remove a configuration.
Cloud remediation activities
In addition to the recommendations listed earlier in this article, we also recommend the following activities for
your cloud environments:

A C T IVIT Y DESC RIP T IO N

Reset passwords Reset passwords on any break-glass accounts and reduce


the number of break-glass accounts to the absolute
minimum required.

Restrict privileged access accounts Ensure that service and user accounts with privileged access
are cloud-only accounts, and do not use on-premise
accounts that are synced or federated to Azure Active
Directory.

Enforce MFA Enforce Multi-Factor Authentication (MFA) across all elevated


users in the tenant. We recommend enforcing MFA across all
users in the tenant.

Limit administrative access Implement Privileged Identity Management (PIM) and


conditional access to limit administrative access.

For Microsoft 365 users, implement Privileged Access


Management (PAM) to limit access to sensitive abilities, such
as eDiscovery, Global Admin, Account Administration, and
more.

Review / reduce delegated permissions and consent Review and reduce all Enterprise Applications delegated
grants permissions or consent grants that allow any of the
following functionalities:

- Modification of privileged users and roles


- Reading, sending email, or accessing all mailboxes
- Accessing OneDrive, Teams, or SharePoint content
- Adding Service Principals that can read/write to the
directory
- Application Permissions versus Delegated Access

On-premises remediation activities


In addition to the recommendations listed earlier in this article, we also recommend the following activities for
your on-premises environments:

A C T IVIT Y DESC RIP T IO N


A C T IVIT Y DESC RIP T IO N

Rebuild affected systems Rebuild systems that were identified as compromised by the
attacker during your investigation.

Remove unnecessar y admin users Remove unnecessary members from Domain Admins,
Backup Operators, and Enterprise Admin groups. For more
information, see Securing Privileged Access.

Reset passwords to privileged accounts Reset passwords of all privileged accounts in the
environment.

Note : Privileged accounts are not limited to built-in groups,


but can also be groups that are delegated access to server
administration, workstation administration, or other areas of
your environment.

Reset the krbtgt account Reset the krbtgt account twice using the New-KrbtgtKeys
script.

Note : If you are using Read-Only Domain Controllers, you


will need to run the script separately for Read-Write Domain
Controllers and for Read-Only Domain Controllers.

Schedule a system restar t After you validate that no persistence mechanisms created
by the attacker exist or remain on your system, schedule a
system restart to assist with removing memory-resident
malware.

Reset the DSRM password Reset each domain controller’s DSRM (Directory Services
Restore Mode) password to something unique and complex.

Remediate or block persistence discovered during investigation


Investigation is an iterative process, and you'll need to balance the organizational desire to remediate as you
identify anomalies and the chance that remediation will alert the attacker to your detection and give them time
to react.
For example, an attacker who becomes aware of the detection might change techniques or create more
persistence.
Make sure to remediate any persistence techniques that you've identified in earlier stages of the investigation.
Remediate user and service account access
In addition to the recommended actions listed above, we recommend that you consider the following steps to
remediate and restore user accounts:
Enforce conditional access based on trusted devices . If possible we recommend that you enforce
location-based conditional access to suit your organizational requirements.
Reset passwords after eviction for any user accounts that may have been compromised. Make sure to
also implement a mid-term plan to reset credentials for all accounts in your directory.
Revoke refresh tokens immediately after rotating your credentials.
For more information, see:
Revoke user access in an emergency in Azure Active Directory
Revoke-AzureADUserAllRefreshToken PowerShell documentation

Next steps
Get help from inside Microsoft products , including the Microsoft 365 Defender portal, Microsoft
365 compliance center, and Office 365 Security & Compliance Center by selecting the Help (? ) button in
the top navigation bar.
For deployment assistance , contact us at FastTrack
If you have product suppor t-related needs , file a Microsoft support case.

IMPORTANT
If you believe you have been compromised and require assistance through an incident response, open a Sev A
Microsoft support case.
Azure threat protection
12/12/2021 • 21 minutes to read • Edit Online

Azure offers built in threat protection functionality through services such as Azure Active Directory (Azure AD),
Azure Monitor logs, and Microsoft Defender for Cloud. This collection of security services and capabilities
provides a simple and fast way to understand what is happening within your Azure deployments.
Azure provides a wide array of options to configure and customize security to meet the requirements of your
app deployments. This article discusses how to meet these requirements.

Azure Active Directory Identity Protection


Azure AD Identity Protection is an Azure Active Directory Premium P2 edition feature that provides an overview
of the risk detections and potential vulnerabilities that can affect your organization’s identities. Identity
Protection uses existing Azure AD anomaly-detection capabilities that are available through Azure AD
Anomalous Activity Reports, and introduces new risk detection types that can detect real time anomalies.

Identity Protection uses adaptive machine learning algorithms and heuristics to detect anomalies and risk
detections that might indicate that an identity has been compromised. Using this data, Identity Protection
generates reports and alerts so that you can investigate these risk detections and take appropriate remediation
or mitigation action.
Azure Active Directory Identity Protection is more than a monitoring and reporting tool. Based on risk
detections, Identity Protection calculates a user risk level for each user, so that you can configure risk-based
policies to automatically protect the identities of your organization.
These risk-based policies, in addition to other Conditional Access controls that are provided by Azure Active
Directory and EMS, can automatically block or offer adaptive remediation actions that include password resets
and multi-factor authentication enforcement.
Identity Protection capabilities
Azure Active Directory Identity Protection is more than a monitoring and reporting tool. To protect your
organization's identities, you can configure risk-based policies that automatically respond to detected issues
when a specified risk level has been reached. These policies, in addition to other Conditional Access controls
provided by Azure Active Directory and EMS, can either automatically block or initiate adaptive remediation
actions including password resets and multi-factor authentication enforcement.
Examples of some of the ways that Azure Identity Protection can help secure your accounts and identities
include:
Detecting risk detections and risky accounts
Detect six risk detection types using machine learning and heuristic rules.
Calculate user risk levels.
Provide custom recommendations to improve overall security posture by highlighting vulnerabilities.
Investigating risk detections
Send notifications for risk detections.
Investigate risk detections using relevant and contextual information.
Provide basic workflows to track investigations.
Provide easy access to remediation actions such as password reset.
Risk-based, conditional-access policies
Mitigate risky sign-ins by blocking sign-ins or requiring multi-factor authentication challenges.
Block or secure risky user accounts.
Require users to register for multi-factor authentication.
Azure AD Privileged Identity Management
With Azure Active Directory Privileged Identity Management (PIM), you can manage, control, and monitor
access within your organization. This feature includes access to resources in Azure AD and other Microsoft
online services, such as Microsoft 365 or Microsoft Intune.

PIM helps you:


Get alerts and reports about Azure AD administrators and just-in-time (JIT) administrative access to
Microsoft online services, such as Microsoft 365 and Intune.
Get reports about administrator access history and changes in administrator assignments.
Get alerts about access to a privileged role.
Azure Monitor logs
Azure Monitor logs is a Microsoft cloud-based IT management solution that helps you manage and protect your
on-premises and cloud infrastructure. Because Azure Monitor logs is implemented as a cloud-based service, you
can have it up and running quickly with minimal investment in infrastructure services. New security features are
delivered automatically, saving ongoing maintenance and upgrade costs.
In addition to providing valuable services on its own, Azure Monitor logs can integrate with System Center
components, such as System Center Operations Manager, to extend your existing security management
investments into the cloud. System Center and Azure Monitor logs can work together to provide a full hybrid
management experience.
Holistic security and compliance posture
Microsoft Defender for Cloud provides a comprehensive view into your organization’s IT security posture, with
built-in search queries for notable issues that require your attention. It provides high-level insight into the
security state of your computers. You can also view all events from the past 24 hours, 7 days, or any other
custom time-frame.
Azure Monitor logs help you quickly and easily understand the overall security posture of any environment, all
within the context of IT Operations, including software update assessment, antimalware assessment, and
configuration baselines. Security log data is readily accessible to streamline the security and compliance audit
processes.
Insight and analytics
At the center of Azure Monitor logs is the repository, which is hosted by Azure.

You collect data into the repository from connected sources by configuring data sources and adding solutions to
your subscription.
Data sources and solutions each create separate record types with their own set of properties, but you can still
analyze them together in queries to the repository. You can use the same tools and methods to work with a
variety of data that's collected by various sources.
Most of your interaction with Azure Monitor logs is through the Azure portal, which runs in any browser and
provides you with access to configuration settings and multiple tools to analyze and act on collected data. From
the portal, you can use:
Log searches where you construct queries to analyze collected data.
Dashboards, which you can customize with graphical views of your most valuable searches.
Solutions, which provide additional functionality and analysis tools.
Solutions add functionality to Azure Monitor logs. They primarily run in the cloud and provide analysis of data
that's collected in the log analytics repository. Solutions might also define new record types to be collected that
can be analyzed with log searches or by using an additional user interface that the solution provides in the log
analytics dashboard.
Defender for Cloud is an example of these types of solutions.
Automation and control: Alert on security configuration drifts
Azure Automation automates administrative processes with runbooks that are based on PowerShell and run in
the cloud. Runbooks can also be executed on a server in your local data center to manage local resources. Azure
Automation provides configuration management with PowerShell Desired State Configuration (DSC).

You can create and manage DSC resources that are hosted in Azure and apply them to cloud and on-premises
systems. By doing so, you can define and automatically enforce their configuration or get reports on drift to help
ensure that security configurations remain within policy.

Microsoft Defender for Cloud


Microsoft Defender for Cloud helps protect your hybrid cloud environment. By performing continuous security
assessments of your connected resources, it's able to provide detailed security recommendations for the
discovered vulnerabilities.
Defender for Cloud's recommendations are based on the Azure Security Benchmark - the Microsoft-authored,
Azure-specific set of guidelines for security and compliance best practices based on common compliance
frameworks. This widely respected benchmark builds on the controls from the Center for Internet Security (CIS)
and the National Institute of Standards and Technology (NIST) with a focus on cloud centric security.
Enabling Defender for Cloud's enhanced security features brings advanced, intelligent, protection of your Azure,
hybrid and multi-cloud resources and workloads. Learn more in Microsoft Defender for Cloud's enhanced
security features.
The workload protection dashboard in Defender for Cloud provides visibility and control of the integrated cloud
workload protection features provided by a range of Microsoft Defender plans:
TIP
Learn more about the numbered sections in The workload protections dashboard.

Microsoft security researchers are constantly on the lookout for threats. They have access to an expansive set of
telemetry gained from Microsoft’s global presence in the cloud and on-premises. This wide-reaching and
diverse collection of datasets enables Microsoft to discover new attack patterns and trends across its on-
premises consumer and enterprise products, as well as its online services.
Thus, Defender for Cloud can rapidly update its detection algorithms as attackers release new and increasingly
sophisticated exploits. This approach helps you keep pace with a fast-moving threat environment.
Microsoft Defender for Cloud automatically collects security information from your resources, the network, and
connected partner solutions. It analyzes this information, correlating information from multiple sources, to
identify threats.
Security alerts are prioritized in Defender for Cloud along with recommendations on how to remediate the
threats.
Defender for Cloud employs advanced security analytics, which go far beyond signature-based approaches.
Breakthroughs in big data and machine learning technologies are used to evaluate events across the entire
cloud. Advanced analytics can detect threats that would be impossible to identify through manual approaches
and predict the evolution of attacks. These security analytics types are covered in the next sections.
Threat intelligence
Microsoft has access to an immense amount of global threat intelligence.
Telemetry flows in from multiple sources, such as Azure, Microsoft 365, Microsoft CRM online, Microsoft
Dynamics AX, outlook.com, MSN.com, the Microsoft Digital Crimes Unit (DCU), and Microsoft Security Response
Center (MSRC).
Researchers also receive threat intelligence information that is shared among major cloud service providers, and
they subscribe to threat intelligence feeds from third parties. Microsoft Defender for Cloud can use this
information to alert you to threats from known bad actors. Some examples include:
Harnessing the power of machine learning : Microsoft Defender for Cloud has access to a vast
amount of data about cloud network activity, which can be used to detect threats targeting your Azure
deployments.
Brute force detection : Machine learning is used to create a historical pattern of remote access
attempts, which allows it to detect brute force attacks against Secure Shell (SSH), Remote Desktop
Protocol (RDP), and SQL ports.
Outbound DDoS and botnet detection : A common objective of attacks that target cloud resources is
to use the compute power of these resources to execute other attacks.
New behavioral analytics ser vers and VMs : After a server or virtual machine is compromised,
attackers employ a wide variety of techniques to execute malicious code on that system while avoiding
detection, ensuring persistence, and obviating security controls.
Azure SQL Database Threat Detection : Threat detection for Azure SQL Database, which identifies
anomalous database activities that indicate unusual and potentially harmful attempts to access or exploit
databases.
Behavioral analytics
Behavioral analytics is a technique that analyzes and compares data to a collection of known patterns. However,
these patterns are not simple signatures. They are determined through complex machine learning algorithms
that are applied to massive datasets.
The patterns are also determined through careful analysis of malicious behaviors by expert analysts. Microsoft
Defender for Cloud can use behavioral analytics to identify compromised resources based on analysis of virtual
machine logs, virtual network device logs, fabric logs, crash dumps, and other sources.
In addition, patterns are correlated with other signals to check for supporting evidence of a widespread
campaign. This correlation helps to identify events that are consistent with established indicators of
compromise.
Some examples include:
Suspicious process execution : Attackers employ several techniques to execute malicious software
without detection. For example, an attacker might give malware the same names as legitimate system
files but place these files in an alternate location, use a name that is similar to that of a benign file, or
mask the file’s true extension. Defender for Cloud models process behaviors and monitor process
executions to detect outliers such as these.
Hidden malware and exploitation attempts : Sophisticated malware can evade traditional
antimalware products by either never writing to disk or encrypting software components stored on disk.
However, such malware can be detected by using memory analysis, because the malware must leave
traces in memory to function. When software crashes, a crash dump captures a portion of memory at the
time of the crash. By analyzing the memory in the crash dump, Microsoft Defender for Cloud can detect
techniques used to exploit vulnerabilities in software, access confidential data, and surreptitiously persist
within a compromised machine without affecting the performance of your machine.
Lateral movement and internal reconnaissance : To persist in a compromised network and locate
and harvest valuable data, attackers often attempt to move laterally from the compromised machine to
others within the same network. Defender for Cloud monitors process and login activities to discover
attempts to expand an attacker’s foothold within the network, such as remote command execution,
network probing, and account enumeration.
Malicious PowerShell scripts : PowerShell can be used by attackers to execute malicious code on
target virtual machines for various purposes. Defender for Cloud inspects PowerShell activity for
evidence of suspicious activity.
Outgoing attacks : Attackers often target cloud resources with the goal of using those resources to
mount additional attacks. Compromised virtual machines, for example, might be used to launch brute
force attacks against other virtual machines, send spam, or scan open ports and other devices on the
internet. By applying machine learning to network traffic, Defender for Cloud can detect when outbound
network communications exceed the norm. When spam is detected, Defender for Cloud also correlates
unusual email traffic with intelligence from Microsoft 365 to determine whether the mail is likely
nefarious or the result of a legitimate email campaign.
Anomaly detection
Microsoft Defender for Cloud also uses anomaly detection to identify threats. In contrast to behavioral analytics
(which depends on known patterns derived from large data sets), anomaly detection is more “personalized” and
focuses on baselines that are specific to your deployments. Machine learning is applied to determine normal
activity for your deployments, and then rules are generated to define outlier conditions that could represent a
security event. Here’s an example:
Inbound RDP/SSH brute force attacks : Your deployments might have busy virtual machines with many
logins each day and other virtual machines that have few, if any, logins. Microsoft Defender for Cloud can
determine baseline login activity for these virtual machines and use machine learning to define around the
normal login activities. If there is any discrepancy with the baseline defined for login related characteristics,
an alert might be generated. Again, machine learning determines what is significant.
Continuous threat intelligence monitoring
Microsoft Defender for Cloud operates with security research and data science teams throughout the world that
continuously monitor for changes in the threat landscape. This includes the following initiatives:
Threat intelligence monitoring : Threat intelligence includes mechanisms, indicators, implications, and
actionable advice about existing or emerging threats. This information is shared in the security
community, and Microsoft continuously monitors threat intelligence feeds from internal and external
sources.
Signal sharing : Insights from security teams across the broad Microsoft portfolio of cloud and on-
premises services, servers, and client endpoint devices are shared and analyzed.
Microsoft security specialists : Ongoing engagement with teams across Microsoft that work in
specialized security fields, such as forensics and web attack detection.
Detection tuning : Algorithms are run against real customer data sets, and security researchers work
with customers to validate the results. True and false positives are used to refine machine learning
algorithms.
These combined efforts culminate in new and improved detections, which you can benefit from instantly. There’s
no action for you to take.

Threat protection features: Other Azure services


Virtual machines: Microsoft antimalware
Microsoft antimalware for Azure is a single-agent solution for applications and tenant environments, designed
to run in the background without human intervention. You can deploy protection based on the needs of your
application workloads, with either basic secure-by-default or advanced custom configuration, including
antimalware monitoring. Azure antimalware is a security option for Azure virtual machines that's automatically
installed on all Azure PaaS virtual machines.
Microsoft antimalware core features
Here are the features of Azure that deploy and enable Microsoft antimalware for your applications:
Real-time protection : Monitors activity in cloud services and on virtual machines to detect and block
malware execution.
Scheduled scanning : Periodically performs targeted scanning to detect malware, including actively
running programs.
Malware remediation : Automatically acts on detected malware, such as deleting or quarantining
malicious files and cleaning up malicious registry entries.
Signature updates : Automatically installs the latest protection signatures (virus definitions) to ensure
that protection is up to date on a pre-determined frequency.
Antimalware Engine updates : Automatically updates the Microsoft Antimalware Engine.
Antimalware platform updates : Automatically updates the Microsoft antimalware platform.
Active protection : Reports telemetry metadata about detected threats and suspicious resources to
Microsoft Azure to ensure rapid response to the evolving threat landscape, enabling real-time
synchronous signature delivery through the Microsoft active protection system.
Samples repor ting : Provides and reports samples to the Microsoft antimalware service to help refine
the service and enable troubleshooting.
Exclusions : Allows application and service administrators to configure certain files, processes, and drives
for exclusion from protection and scanning for performance and other reasons.
Antimalware event collection : Records the antimalware service health, suspicious activities, and
remediation actions taken in the operating system event log and collects them into the customer’s Azure
storage account.
Azure SQL Database Threat Detection
Azure SQL Database Threat Detection is a new security intelligence feature built into the Azure SQL Database
service. Working around the clock to learn, profile, and detect anomalous database activities, Azure SQL
Database Threat Detection identifies potential threats to the database.
Security officers or other designated administrators can get an immediate notification about suspicious
database activities as they occur. Each notification provides details of the suspicious activity and recommends
how to further investigate and mitigate the threat.
Currently, Azure SQL Database Threat Detection detects potential vulnerabilities and SQL injection attacks, and
anomalous database access patterns.
Upon receiving a threat-detection email notification, users are able to navigate and view the relevant audit
records through a deep link in the mail. The link opens an audit viewer or a preconfigured auditing Excel
template that shows the relevant audit records around the time of the suspicious event, according to the
following:
Audit storage for the database/server with the anomalous database activities.
Relevant audit storage table that was used at the time of the event to write the audit log.
Audit records of the hour immediately following the event occurrence.
Audit records with a similar event ID at the time of the event (optional for some detectors).
SQL Database threat detectors use one of the following detection methodologies:
Deterministic detection : Detects suspicious patterns (rules based) in the SQL client queries that match
known attacks. This methodology has high detection and low false positive, but limited coverage because
it falls within the category of “atomic detections.”
Behavioral detection : Detects anomalous activity, which is abnormal behavior in the database that was
not seen during the most recent 30 days. Examples of SQL client anomalous activity can be a spike of
failed logins or queries, a high volume of data being extracted, unusual canonical queries, or unfamiliar IP
addresses used to access the database.
Application Gateway Web Application Firewall
Web Application Firewall (WAF) is a feature of Azure Application Gateway that provides protection to web
applications that use an application gateway for standard application delivery control functions. Web
Application Firewall does this by protecting them against most of the Open Web Application Security Project
(OWASP) top 10 common web vulnerabilities.

Protections include:
SQL injection protection.
Cross site scripting protection.
Common Web Attacks Protection, such as command injection, HTTP request smuggling, HTTP response
splitting, and remote file inclusion attack.
Protection against HTTP protocol violations.
Protection against HTTP protocol anomalies, such as missing host user-agent and accept headers.
Prevention against bots, crawlers, and scanners.
Detection of common application misconfigurations (that is, Apache, IIS, and so on).
Configuring WAF at your application gateway provides the following benefits:
Protects your web application from web vulnerabilities and attacks without modification of the back-end
code.
Protects multiple web applications at the same time behind an application gateway. An application
gateway supports hosting up to 20 websites.
Monitors web applications against attacks by using real-time reports that are generated by application
gateway WAF logs.
Helps meet compliance requirements. Certain compliance controls require all internet-facing endpoints
to be protected by a WAF solution.
Anomaly Detection API: Built with Azure Machine Learning
The Anomaly Detection API is an API that's useful for detecting a variety of anomalous patterns in your time
series data. The API assigns an anomaly score to each data point in the time series, which can be used for
generating alerts, monitoring through dashboards, or connecting with your ticketing systems.
The Anomaly Detection API can detect the following types of anomalies on time series data:
Spikes and dips : When you're monitoring the number of login failures to a service or number of
checkouts in an e-commerce site, unusual spikes or dips could indicate security attacks or service
disruptions.
Positive and negative trends : When you're monitoring memory usage in computing, shrinking free
memory size indicates a potential memory leak. For service queue length monitoring, a persistent
upward trend might indicate an underlying software issue.
Level changes and changes in dynamic range of values : Level changes in latencies of a service
after a service upgrade or lower levels of exceptions after upgrade can be interesting to monitor.
The machine learning-based API enables:
Flexible and robust detection : The anomaly detection models allow users to configure sensitivity
settings and detect anomalies among seasonal and non-seasonal data sets. Users can adjust the anomaly
detection model to make the detection API less or more sensitive according to their needs. This would
mean detecting the less or more visible anomalies in data with and without seasonal patterns.
Scalable and timely detection : The traditional way of monitoring with present thresholds set by
experts' domain knowledge are costly and not scalable to millions of dynamically changing data sets. The
anomaly detection models in this API are learned, and models are tuned automatically from both
historical and real-time data.
Proactive and actionable detection : Slow trend and level change detection can be applied for early
anomaly detection. The early abnormal signals that are detected can be used to direct humans to
investigate and act on the problem areas. In addition, root cause analysis models and alerting tools can
be developed on top of this anomaly-detection API service.
The anomaly-detection API is an effective and efficient solution for a wide range of scenarios, such as service
health and KPI monitoring, IoT, performance monitoring, and network traffic monitoring. Here are some popular
scenarios where this API can be useful:
IT departments need tools to track events, error code, usage log, and performance (CPU, memory, and so
on) in a timely manner.
Online commerce sites want to track customer activities, page views, clicks, and so on.
Utility companies want to track consumption of water, gas, electricity, and other resources.
Facility or building management services want to monitor temperature, moisture, traffic, and so on.
IoT/manufacturers want to use sensor data in time series to monitor work flow, quality, and so on.
Service providers, such as call centers, need to monitor service demand trend, incident volume, wait
queue length, and so on.
Business analytics groups want to monitor business KPIs' (such as sales volume, customer sentiments, or
pricing) abnormal movement in real time.
Defender for Cloud Apps
Defender for Cloud Apps is a critical component of the Microsoft Cloud Security stack. It's a comprehensive
solution that can help your organization as you move to take full advantage of the promise of cloud
applications. It keeps you in control, through improved visibility into activity. It also helps increase the protection
of critical data across cloud applications.
With tools that help uncover shadow IT, assess risk, enforce policies, investigate activities, and stop threats, your
organization can more safely move to the cloud while maintaining control of critical data.

C AT EGO RY DESC RIP T IO N

Discover Uncover shadow IT with Defender for Cloud Apps. Gain


visibility by discovering apps, activities, users, data, and files
in your cloud environment. Discover third-party apps that
are connected to your cloud.

Investigate Investigate your cloud apps by using cloud forensics tools to


deep-dive into risky apps, specific users, and files in your
network. Find patterns in the data collected from your cloud.
Generate reports to monitor your cloud.

Control Mitigate risk by setting policies and alerts to achieve


maximum control over network cloud traffic. Use Defender
for Cloud Apps to migrate your users to safe, sanctioned
cloud app alternatives.

Protect Use Defender for Cloud Apps to sanction or prohibit


applications, enforce data loss prevention, control
permissions and sharing, and generate custom reports and
alerts.

Control Mitigate risk by setting policies and alerts to achieve


maximum control over network cloud traffic. Use Defender
for Cloud Apps to migrate your users to safe, sanctioned
cloud app alternatives.
Defender for Cloud Apps integrates visibility with your cloud by:
Using Cloud Discovery to map and identify your cloud environment and the cloud apps your
organization is using.
Sanctioning and prohibiting apps in your cloud.
Using easy-to-deploy app connectors that take advantage of provider APIs, for visibility and governance
of apps that you connect to.
Helping you have continuous control by setting, and then continually fine-tuning, policies.
On collecting data from these sources, Defender for Cloud Apps runs sophisticated analysis on it. It immediately
alerts you to anomalous activities, and gives you deep visibility into your cloud environment. You can configure
a policy in Defender for Cloud Apps and use it to protect everything in your cloud environment.

Third-party threat protection capabilities through the Azure


Marketplace
Web Application Firewall
Web Application Firewall inspects inbound web traffic and blocks SQL injections, cross-site scripting, malware
uploads, application DDoS attacks, and other attacks targeted at your web applications. It also inspects the
responses from the back-end web servers for data loss prevention (DLP). The integrated access control engine
enables administrators to create granular access control policies for authentication, authorization, and
accounting (AAA), which gives organizations strong authentication and user control.
Web Application Firewall provides the following benefits:
Detects and blocks SQL injections, Cross-Site Scripting, malware uploads, application DDoS, or any other
attacks against your application.
Authentication and access control.
Scans outbound traffic to detect sensitive data and can mask or block the information from being leaked
out.
Accelerates the delivery of web application contents, using capabilities such as caching, compression, and
other traffic optimizations.
For examples of web application firewalls that are available in the Azure Marketplace, see Barracuda WAF,
Brocade virtual web application firewall (vWAF), Imperva SecureSphere, and the ThreatSTOP IP firewall.

Next steps
Responding to today’s threats: Helps identify active threats that target your Azure resources and provides
the insights you need to respond quickly.
Azure SQL Database Threat Detection: Helps address your concerns about potential threats to your
databases.
Azure security technical capabilities
12/12/2021 • 26 minutes to read • Edit Online

This article provides an introduction to security services in Azure that help you protect your data, resources, and
applications in the cloud and meet the security needs of your business.

Azure platform
Microsoft Azure is a cloud platform comprised of infrastructure and application services, with integrated data
services and advanced analytics, and developer tools and services, hosted within Microsoft’s public cloud data
centers. Customers use Azure for many different capacities and scenarios, from basic compute, networking, and
storage, to mobile and web app services, to full cloud scenarios like Internet of Things, and can be used with
open-source technologies, and deployed as hybrid cloud or hosted within a customer’s datacenter. Azure
provides cloud technology as building blocks to help companies save costs, innovate quickly, and manage
systems proactively. When you build on, or migrate IT assets to a cloud provider, you are relying on that
organization’s abilities to protect your applications and data with the services and the controls they provide to
manage the security of your cloud-based assets.
Microsoft Azure is the only cloud computing provider that offers a secure, consistent application platform and
infrastructure-as-a-service for teams to work within their different cloud skillsets and levels of project
complexity, with integrated data services and analytics that uncover intelligence from data wherever it exists,
across both Microsoft and non-Microsoft platforms, open frameworks and tools, providing choice for
integrating cloud with on-premises as well deploying Azure cloud services within on-premises datacenters. As
part of the Microsoft Trusted Cloud, customers rely on Azure for industry-leading security, reliability,
compliance, privacy, and the vast network of people, partners, and processes to support organizations in the
cloud.
With Microsoft Azure, you can:
Accelerate innovation with the cloud.
Power business decisions & apps with insights.
Build freely and deploy anywhere.
Protect their business.

Security technical capabilities to fulfill your responsibility


Microsoft Azure provides services that help you meet your security, privacy, and compliance needs. The
following picture helps explain various Azure services available for you to build a secure and compliant
application infrastructure based on industry standards.
Manage and control identity and user access
Azure helps you protect business and personal information by enabling you to manage user identities and
credentials and control access.
Azure Active Directory
Microsoft identity and access management solutions help IT protect access to applications and resources across
the corporate datacenter and into the cloud, enabling additional levels of validation such as multi-factor
authentication and Conditional Access policies. Monitoring suspicious activity through advanced security
reporting, auditing and alerting helps mitigate potential security issues. Azure Active Directory Premium
provides single sign-on to thousands of cloud apps and access to web apps you run on-premises.
Security benefits of Azure Active Directory (Azure AD) include the ability to:
Create and manage a single identity for each user across your hybrid enterprise, keeping users, groups,
and devices in sync.
Provide single sign-on access to your applications including thousands of pre-integrated SaaS apps.
Enable application access security by enforcing rules-based Multi-Factor Authentication for both on-
premises and cloud applications.
Provision secure remote access to on-premises web applications through Azure AD Application Proxy.
The Azure Active Directory portal is available as part of the Azure portal. From this dashboard, you can get an
overview of the state of your organization, and easily manage the directory, users, or application access.
The following are core Azure identity management capabilities:
Single sign-on
Multi-factor authentication
Security monitoring, alerts, and machine learning-based reports
Consumer identity and access management
Device registration
Privileged identity management
Identity protection
Single sign-on
Single sign-on (SSO) means being able to access all the applications and resources that you need to do
business, by signing in only once using a single user account. Once signed in, you can access all the applications
you need without being required to authenticate (for example, type a password) a second time.
Many organizations rely upon software as a service (SaaS) applications such as Microsoft 365, Box, and
Salesforce for end-user productivity. Historically, IT staff needed to individually create and update user accounts
in each SaaS application, and users had to remember a password for each SaaS application.
Azure AD extends on-premises Active Directory into the cloud, enabling users to use their primary
organizational account to not only sign in to their domain-joined devices and company resources, but also all
the web and SaaS applications needed for their job.
Not only do users not have to manage multiple sets of usernames and passwords, application access can be
automatically provisioned or de-provisioned based on organizational groups and their status as an employee.
Azure AD introduces security and access governance controls that enable you to centrally manage users' access
across SaaS applications.
Multi-factor authentication
Azure AD Multi-Factor Authentication (MFA) is a method of authentication that requires the use of more than
one verification method and adds a critical second layer of security to user sign-ins and transactions. MFA helps
safeguard access to data and applications while meeting user demand for a simple sign-in process. It delivers
strong authentication via a range of verification options—phone call, text message, or mobile app notification or
verification code and third-party OAuth tokens.
Security monitoring, alerts, and machine learning-based reports
Security monitoring and alerts and machine learning-based reports that identify inconsistent access patterns
can help you protect your business. You can use Azure Active Directory's access and usage reports to gain
visibility into the integrity and security of your organization’s directory. With this information, a directory admin
can better determine where possible security risks may lie so that they can adequately plan to mitigate those
risks.
In the Azure portal or through the Azure Active Directory portal, reports are categorized in the following ways:
Anomaly reports – contain sign in events that we found to be anomalous. Our goal is to make you aware
of such activity and enable you to be able to decide about whether an event is suspicious.
Integrated application reports – provide insights into how cloud applications are being used in your
organization. Azure Active Directory offers integration with thousands of cloud applications.
Error reports – indicate errors that may occur when provisioning accounts to external applications.
User-specific reports – display device and sign in activity data for a specific user.
Activity logs – contain a record of all audited events within the last 24 hours, last 7 days, or last 30 days,
and group activity changes, and password reset and registration activity.
Consumer identity and access management
Azure Active Directory B2C is a highly available, global, identity management service for consumer-facing
applications that scales to hundreds of millions of identities. It can be integrated across mobile and web
platforms. Your consumers can log on to all your applications through customizable experiences by using their
existing social accounts or by creating new credentials.
In the past, application developers who wanted to sign up and sign in consumers into their applications would
have written their own code. And they would have used on-premises databases or systems to store usernames
and passwords. Azure Active Directory B2C offers your organization a better way to integrate consumer identity
management into applications with the help of a secure, standards-based platform, and a large set of extensible
policies.
When you use Azure Active Directory B2C, your consumers can sign up for your applications by using their
existing social accounts (Facebook, Google, Amazon, LinkedIn) or by creating new credentials (email address and
password, or username and password).
Device registration
Azure AD device registration is the foundation for device-based Conditional Access scenarios. When a device is
registered, Azure AD device registration provides the device with an identity that is used to authenticate the
device when the user signs in. The authenticated device, and the attributes of the device, can then be used to
enforce Conditional Access policies for applications that are hosted in the cloud and on-premises.
When combined with a mobile device management (MDM) solution such as Intune, the device attributes in
Azure Active Directory are updated with additional information about the device. This allows you to create
Conditional Access rules that enforce access from devices to meet your standards for security and compliance.
Privileged identity management
Azure Active Directory (AD) Privileged Identity Management lets you manage, control, and monitor your
privileged identities and access to resources in Azure AD as well as other Microsoft online services like Microsoft
365 or Microsoft Intune.
Sometimes users need to carry out privileged operations in Azure or Microsoft 365 resources, or other SaaS
apps. This often means organizations have to give them permanent privileged access in Azure AD. This is a
growing security risk for cloud-hosted resources because organizations can't sufficiently monitor what those
users are doing with their admin privileges. Additionally, if a user account with privileged access is
compromised, that one breach could impact their overall cloud security. Azure AD Privileged Identity
Management helps to resolve this risk.
Azure AD Privileged Identity Management lets you:
See which users are Azure AD admins
Enable on-demand, "just in time" administrative access to Microsoft Online Services like Microsoft 365
and Intune
Get reports about administrator access history and changes in administrator assignments
Get alerts about access to a privileged role
Identity protection
Azure AD Identity Protection is a security service that provides a consolidated view into risk detections and
potential vulnerabilities affecting your organization’s identities. Identity Protection uses existing Azure Active
Directory’s anomaly detection capabilities (available through Azure AD’s Anomalous Activity Reports), and
introduces new risk detection types that can detect anomalies in real time.

Secure resource access


Access control in Azure starts from a billing perspective. The owner of an Azure account, accessed by visiting the
Azure portal, is the Account Administrator (AA). Subscriptions are a container for billing, but they also act as a
security boundary: each subscription has a Service Administrator (SA) who can add, remove, and modify Azure
resources in that subscription by using the Azure portal. The default SA of a new subscription is the AA, but the
AA can change the SA in the Azure portal.

Subscriptions also have an association with a directory. The directory defines a set of users. These can be users
from the work or school that created the directory, or they can be external users (that is, Microsoft Accounts).
Subscriptions are accessible by a subset of those directory users who have been assigned as either Service
Administrator (SA) or Co-Administrator (CA); the only exception is that, for legacy reasons, Microsoft Accounts
(formerly Windows Live ID) can be assigned as SA or CA without being present in the directory.
Security-oriented companies should focus on giving employees the exact permissions they need. Too many
permissions can expose an account to attackers. Too few permissions mean that employees can't get their work
done efficiently. Azure role-based access control (Azure RBAC) helps address this problem by offering fine-
grained access management for Azure.
Using Azure RBAC, you can segregate duties within your team and grant only the amount of access to users that
they need to perform their jobs. Instead of giving everybody unrestricted permissions in your Azure
subscription or resources, you can allow only certain actions. For example, use Azure RBAC to let one employee
manage virtual machines in a subscription, while another can manage SQL databases within the same
subscription.

Data security and encryption


One of the keys to data protection in the cloud is accounting for the possible states in which your data may
occur, and what controls are available for that state. For Azure data security and encryption best practices the
recommendations be around the following data’s states.
At-rest: This includes all information storage objects, containers, and types that exist statically on physical
media, be it magnetic or optical disk.
In-transit: When data is being transferred between components, locations or programs, such as over the
network, across a service bus (from on-premises to cloud and vice-versa, including hybrid connections such
as ExpressRoute), or during an input/output process, it is thought of as being in-motion.
Encryption at rest
Encryption at rest is discussed in detail in Azure Data Encryption-at-Rest.
Encryption in-transit
Protecting data in transit should be essential part of your data protection strategy. Since data is moving back
and forth from many locations, the general recommendation is that you always use SSL/TLS protocols to
exchange data across different locations. In some circumstances, you may want to isolate the entire
communication channel between your on-premises and cloud infrastructure by using a virtual private network
(VPN).
For data moving between your on-premises infrastructure and Azure, you should consider appropriate
safeguards such as HTTPS or VPN.
For organizations that need to secure access from multiple workstations located on-premises to Azure, use
Azure site-to-site VPN.
For organizations that need to secure access from one workstation located on-premises to Azure, use Point-to-
Site VPN.
Larger data sets can be moved over a dedicated high-speed WAN link such as ExpressRoute. If you choose to
use ExpressRoute, you can also encrypt the data at the application-level using SSL/TLS or other protocols for
added protection.
If you are interacting with Azure Storage through the Azure portal, all transactions occur via HTTPS. Storage
REST API over HTTPS can also be used to interact with Azure Storage and Azure SQL Database.
Organizations that fail to protect data in transit are more susceptible for man-in-the-middle attacks,
eavesdropping, and session hijacking. These attacks can be the first step in gaining access to confidential data.
You can learn more about Azure VPN option by reading the article Planning and design for VPN Gateway.
Enforce file level data encryption
Azure RMS uses encryption, identity, and authorization policies to help secure your files and email. Azure RMS
works across multiple devices—phones, tablets, and PCs by protecting both within your organization and
outside your organization. This capability is possible because Azure RMS adds a level of protection that remains
with the data, even when it leaves your organization’s boundaries.
When you use Azure RMS to protect your files, you are using industry-standard cryptography with full support
of FIPS 140-2. When you use Azure RMS for data protection, you have the assurance that the protection stays
with the file, even if it is copied to storage that is not under the control of IT, such as a cloud storage service. The
same occurs for files shared via e-mail, the file is protected as an attachment to an email message, with
instructions how to open the protected attachment. When planning for Azure RMS adoption we recommend the
following:
Install the RMS sharing app. This app integrates with Office applications by installing an Office add-in so
that users can easily protect files directly.
Configure applications and services to support Azure RMS
Create custom templates that reflect your business requirements. For example: a template for top secret
data that should be applied in all top secret related emails.
Organizations that are weak on data classification and file protection may be more susceptible to data leakage.
Without proper file protection, organizations won’t be able to obtain business insights, monitor for abuse and
prevent malicious access to files.

NOTE
You can learn more about Azure RMS by reading the article Getting Started with Azure Rights Management.
Secure your application
While Azure is responsible for securing the infrastructure and platform that your application runs on, it is your
responsibility to secure your application itself. In other words, you need to develop, deploy, and manage your
application code and content in a secure way. Without this, your application code or content can still be
vulnerable to threats.
Web application firewall
Web application firewall (WAF) is a feature of Application Gateway that provides centralized protection of your
web applications from common exploits and vulnerabilities.
Web application firewall is based on rules from the OWASP core rule sets 3.0 or 2.2.9. Web applications are
increasingly targets of malicious attacks that exploit common known vulnerabilities. Common among these
exploits are SQL injection attacks, cross site scripting attacks to name a few. Preventing such attacks in
application code can be challenging and may require rigorous maintenance, patching and monitoring at
multiple layers of the application topology. A centralized web application firewall helps make security
management much simpler and gives better assurance to application administrators against threats or
intrusions. A WAF solution can also react to a security threat faster by patching a known vulnerability at a central
location versus securing each of individual web applications. Existing application gateways can be converted to a
web application firewall enabled application gateway easily.
Some of the common web vulnerabilities which web application firewall protects against includes:
SQL injection protection
Cross site scripting protection
Common Web Attacks Protection such as command injection, HTTP request smuggling, HTTP response
splitting, and remote file inclusion attack
Protection against HTTP protocol violations
Protection against HTTP protocol anomalies such as missing host user-agent and accept headers
Prevention against bots, crawlers, and scanners
Detection of common application misconfigurations (that is, Apache, IIS, etc.)

NOTE
For a more detailed list of rules and their protections see the following Core rule sets:

Azure also provides several easy-to-use features to help secure both inbound and outbound traffic for your app.
Azure also helps customers secure their application code by providing externally provided functionality to scan
your web application for vulnerabilities.
Setup Azure Active Directory authentication for your app
Secure traffic to your app by enabling Transport Layer Security (TLS/SSL) - HTTPS
Force all incoming traffic over HTTPS connection
Enable Strict Transport Security (HSTS)
Restrict access to your app by client's IP address
Restrict access to your app by client's behavior - request frequency and concurrency
Scan your web app code for vulnerabilities using Tinfoil Security Scanning
Configure TLS mutual authentication to require client certificates to connect to your web app
Configure a client certificate for use from your app to securely connect to external resources
Remove standard server headers to avoid tools from fingerprinting your app
Securely connect your app with resources in a private network using Point-To-Site VPN
Securely connect your app with resources in a private network using Hybrid Connections
Azure App Service uses the same Antimalware solution used by Azure Cloud Services and Virtual Machines. To
learn more about this refer to our Antimalware documentation.

Secure your network


Microsoft Azure includes a robust networking infrastructure to support your application and service
connectivity requirements. Network connectivity is possible between resources located in Azure, between on-
premises and Azure hosted resources, and to and from the Internet and Azure.
The Azure network infrastructure enables you to securely connect Azure resources to each other with virtual
networks (VNets). A VNet is a representation of your own network in the cloud. A VNet is a logical isolation of
the Azure cloud network dedicated to your subscription. You can connect VNets to your on-premises networks.

If you need basic network level access control (based on IP address and the TCP or UDP protocols), then you can
use Network Security Groups. A Network Security Group (NSG) is a basic stateful packet filtering firewall and it
enables you to control access based on a 5-tuple.
Azure networking supports the ability to customize the routing behavior for network traffic on your Azure
Virtual Networks. You can do this by configuring User-Defined Routes in Azure.
Forced tunneling is a mechanism you can use to ensure that your services are not allowed to initiate a
connection to devices on the Internet.
Azure supports dedicated WAN link connectivity to your on-premises network and an Azure Virtual Network
with ExpressRoute. The link between Azure and your site uses a dedicated connection that does not go over the
public Internet. If your Azure application is running in multiple datacenters, you can use Azure Traffic Manager to
route requests from users intelligently across instances of the application. You can also route traffic to services
not running in Azure if they are accessible from the Internet.
Azure also supports private and secure connectivity to your PaaS resources (for example, Azure Storage and
SQL Database) from your Azure Virtual Network with Azure Private Link. PaaS resource is mapped to a private
endpoint in your virtual network. The link between private endpoint in your virtual network and your PaaS
resource uses Microsoft backbone network and does not go over the public Internet. Exposing your service to
the public internet is no longer necessary. You can also use Azure Private Link to access Azure hosted customer-
owned and partner services in your virtual network. In addition, Azure Private Link enables you to create your
own private link service in your virtual network and deliver it to your customers privately in their virtual
networks. Setup and consumption using Azure Private Link is consistent across Azure PaaS, customer-owned,
and shared partner services.

Virtual machine security


Azure Virtual Machines lets you deploy a wide range of computing solutions in an agile way. With support for
Microsoft Windows, Linux, Microsoft SQL Server, Oracle, IBM, SAP, and Azure BizTalk Services, you can deploy
any workload and any language on nearly any operating system.
With Azure, you can use antimalware software from security vendors such as Microsoft, Symantec, Trend Micro,
and Kaspersky to protect your virtual machines from malicious files, adware, and other threats.
Microsoft Antimalware for Azure Cloud Services and Virtual Machines is a real-time protection capability that
helps identify and remove viruses, spyware, and other malicious software. Microsoft Antimalware provides
configurable alerts when known malicious or unwanted software attempts to install itself or run on your Azure
systems.
Azure Backup is a scalable solution that protects your application data with zero capital investment and minimal
operating costs. Application errors can corrupt your data, and human errors can introduce bugs into your
applications. With Azure Backup, your virtual machines running Windows and Linux are protected.
Azure Site Recovery helps orchestrate replication, failover, and recovery of workloads and apps so that they are
available from a secondary location if your primary location goes down.

Ensure compliance: Cloud services due diligence checklist


Microsoft developed the Cloud Services Due Diligence Checklist to help organizations exercise due diligence as
they consider a move to the cloud. It provides a structure for an organization of any size and type—private
businesses and public-sector organizations, including government at all levels and nonprofits—to identify their
own performance, service, data management, and governance objectives and requirements. This allows them to
compare the offerings of different cloud service providers, ultimately forming the basis for a cloud service
agreement.
The checklist provides a framework that aligns clause-by-clause with a new international standard for cloud
service agreements, ISO/IEC 19086. This standard offers a unified set of considerations for organizations to help
them make decisions about cloud adoption, and create a common ground for comparing cloud service
offerings.
The checklist promotes a thoroughly vetted move to the cloud, providing structured guidance and a consistent,
repeatable approach for choosing a cloud service provider.
Cloud adoption is no longer simply a technology decision. Because checklist requirements touch on every
aspect of an organization, they serve to convene all key internal decision-makers—the CIO and CISO as well as
legal, risk management, procurement, and compliance professionals. This increases the efficiency of the
decision-making process and ground decisions in sound reasoning, thereby reducing the likelihood of
unforeseen roadblocks to adoption.
In addition, the checklist:
Exposes key discussion topics for decision-makers at the beginning of the cloud adoption process.
Supports thorough business discussions about regulations and the organization’s own objectives for
privacy, personal information and data security.
Helps organizations identify any potential issues that could affect a cloud project.
Provides a consistent set of questions, with the same terms, definitions, metrics, and deliverables for each
provider, to simplify the process of comparing offerings from different cloud service providers.

Azure infrastructure and application security validation


Azure Operational Security refers to the services, controls, and features available to users for protecting their
data, applications, and other assets in Microsoft Azure.

Azure Operational Security is built on a framework that incorporates the knowledge gained through a various
capabilities that are unique to Microsoft, including the Microsoft Security Development Lifecycle (SDL), the
Microsoft Security Response Center program, and deep awareness of the cybersecurity threat landscape.
Microsoft Azure Monitor
Azure Monitor is the IT management solution for the hybrid cloud. Used alone or to extend your existing System
Center deployment, Azure Monitor logs gives you the maximum flexibility and control for cloud-based
management of your infrastructure.

With Azure Monitor, you can manage any instance in any cloud, including on-premises, Azure, AWS, Windows
Server, Linux, VMware, and OpenStack, at a lower cost than competitive solutions. Built for the cloud-first world,
Azure Monitor offers a new approach to managing your enterprise that is the fastest, most cost-effective way to
meet new business challenges and accommodate new workloads, applications and cloud environments.
Azure Monitor logs
Azure Monitor logs provides monitoring services by collecting data from managed resources into a central
repository. This data could include events, performance data, or custom data provided through the API. Once
collected, the data is available for alerting, analysis, and export.

This method allows you to consolidate data from a variety of sources, so you can combine data from your Azure
services with your existing on-premises environment. It also clearly separates the collection of the data from the
action taken on that data so that all actions are available to all kinds of data.
Microsoft Defender for Cloud
Microsoft Defender for Cloud helps you prevent, detect, and respond to threats with increased visibility into and
control over the security of your Azure resources. It provides integrated security monitoring and policy
management across your Azure subscriptions, helps detect threats that might otherwise go unnoticed, and
works with a broad ecosystem of security solutions.
Defender for Cloud analyzes the security state of your Azure resources to identify potential security
vulnerabilities. A list of recommendations guides you through the process of configuring needed controls.
Examples include:
Provisioning antimalware to help identify and remove malicious software
Configuring network security groups and rules to control traffic to VMs
Provisioning of web application firewalls to help defend against attacks that target your web applications
Deploying missing system updates
Addressing OS configurations that do not match the recommended baselines
Defender for Cloud automatically collects, analyzes, and integrates log data from your Azure resources, the
network, and partner solutions like antimalware programs and firewalls. When threats are detected, a security
alert is created. Examples include detection of:
Compromised VMs communicating with known malicious IP addresses
Advanced malware detected by using Windows error reporting
Brute force attacks against VMs
Security alerts from integrated antimalware programs and firewalls
Azure monitor
Azure Monitor provides pointers to information on specific types of resources. It offers visualization, query,
routing, alerting, auto scale, and automation on data both from the Azure infrastructure (Activity Log) and each
individual Azure resource (Diagnostic Logs).
Cloud applications are complex with many moving parts. Monitoring provides data to ensure that your
application stays up and running in a healthy state. It also helps you to stave off potential problems or
troubleshoot past ones.

In
addition, you can use monitoring data to gain deep insights about your application. That knowledge can help
you to improve application performance or maintainability, or automate actions that would otherwise require
manual intervention.
Auditing your network security is vital for detecting network vulnerabilities and ensuring compliance with your
IT security and regulatory governance model. With Security Group view, you can retrieve the configured
Network Security Group and security rules, as well as the effective security rules. With the list of rules applied,
you can determine the ports that are open and ss network vulnerability.
Network watcher
Network Watcher is a regional service that enables you to monitor and diagnose conditions at a network level
in, to, and from Azure. Network diagnostic and visualization tools available with Network Watcher help you
understand, diagnose, and gain insights to your network in Azure. This service includes packet capture, next hop,
IP flow verify, security group view, NSG flow logs. Scenario level monitoring provides an end to end view of
network resources in contrast to individual network resource monitoring.
Storage analytics
Storage Analytics can store metrics that include aggregated transaction statistics and capacity data about
requests to a storage service. Transactions are reported at both the API operation level as well as at the storage
service level, and capacity is reported at the storage service level. Metrics data can be used to analyze storage
service usage, diagnose issues with requests made against the storage service, and to improve the performance
of applications that use a service.
Application Insights
Application Insights is an extensible Application Performance Management (APM) service for web developers on
multiple platforms. Use it to monitor your live web application. It will automatically detect performance
anomalies. It includes powerful analytics tools to help you diagnose issues and to understand what users do
with your app. It's designed to help you continuously improve performance and usability. It works for apps on a
wide variety of platforms including .NET, Node.js and Java EE, hosted on-premises or in the cloud. It integrates
with your DevOps process, and has connection points to a various development tools.
It monitors:
Request rates, response times, and failure rates - Find out which pages are most popular, at what
times of day, and where your users are. See which pages perform best. If your response times and failure
rates go high when there are more requests, then perhaps you have a resourcing problem.
Dependency rates, response times, and failure rates - Find out whether external services are
slowing you down.
Exceptions - Analyze the aggregated statistics, or pick specific instances and drill into the stack trace and
related requests. Both server and browser exceptions are reported.
Page views and load performance - reported by your users' browsers.
AJAX calls from web pages - rates, response times, and failure rates.
User and session counts.
Performance counters from your Windows or Linux server machines, such as CPU, memory, and
network usage.
Host diagnostics from Docker or Azure.
Diagnostic trace logs from your app - so that you can correlate trace events with requests.
Custom events and metrics that you write yourself in the client or server code, to track business
events such as items sold, or games won.
The infrastructure for your application is typically made up of many components – maybe a virtual machine,
storage account, and virtual network, or a web app, database, database server, and 3rd party services. You do
not see these components as separate entities, instead you see them as related and interdependent parts of a
single entity. You want to deploy, manage, and monitor them as a group. Azure Resource Manager enables you
to work with the resources in your solution as a group.
You can deploy, update, or delete all the resources for your solution in a single, coordinated operation. You use a
template for deployment and that template can work for different environments such as testing, staging, and
production. Resource Manager provides security, auditing, and tagging features to help you manage your
resources after deployment.
The benefits of using Resource Manager
Resource Manager provides several benefits:
You can deploy, manage, and monitor all the resources for your solution as a group, rather than handling
these resources individually.
You can repeatedly deploy your solution throughout the development lifecycle and have confidence your
resources are deployed in a consistent state.
You can manage your infrastructure through declarative templates rather than scripts.
You can define the dependencies between resources, so they are deployed in the correct order.
You can apply access control to all services in your resource group because Azure role-based access
control (Azure RBAC) is natively integrated into the management platform.
You can apply tags to resources to logically organize all the resources in your subscription.
You can clarify your organization's billing by viewing costs for a group of resources sharing the same tag.
NOTE
Resource Manager provides a new way to deploy and manage your solutions. If you used the earlier deployment model
and want to learn about the changes, see Understanding Resource Manager Deployment and classic deployment.

Next step
The Azure Security Benchmark program includes a collection of security recommendations you can use to help
secure the services you use in Azure.
Azure infrastructure security
12/12/2021 • 2 minutes to read • Edit Online

Microsoft Azure runs in datacenters managed and operated by Microsoft. These geographically dispersed
datacenters comply with key industry standards, such as ISO/IEC 27001:2013 and NIST SP 800-53, for security
and reliability. The datacenters are managed, monitored, and administered by Microsoft operations staff. The
operations staff has years of experience in delivering the world’s largest online services with 24 x 7 continuity.

Securing the Azure infrastructure


This series of articles provides information about what Microsoft does to secure the Azure infrastructure. The
articles address:
Physical security
Availability
Components and boundaries
Network architecture
Production network
SQL Database
Operations
Monitoring
Integrity
Data protection

Next steps
Understand your shared responsibility in the cloud.
Learn how Microsoft Defender for Cloud can help you prevent, detect, and respond to threats with
increased visibility and control over the security of your Azure resources.
Azure facilities, premises, and physical security
12/12/2021 • 5 minutes to read • Edit Online

This article describes what Microsoft does to secure the Azure infrastructure.

Datacenter infrastructure
Azure is composed of a globally distributed datacenter infrastructure, supporting thousands of online services
and spanning more than 100 highly secure facilities worldwide.
The infrastructure is designed to bring applications closer to users around the world, preserving data residency,
and offering comprehensive compliance and resiliency options for customers. Azure has 58 regions worldwide,
and is available in 140 countries/regions.
A region is a set of datacenters that is interconnected via a massive and resilient network. The network includes
content distribution, load balancing, redundancy, and data-link layer encryption by default for all Azure traffic
within a region or travelling between regions. With more global regions than any other cloud provider, Azure
gives you the flexibility to deploy applications where you need them.
Azure regions are organized into geographies. An Azure geography ensures that data residency, sovereignty,
compliance, and resiliency requirements are honored within geographical boundaries.
Geographies allow customers with specific data-residency and compliance needs to keep their data and
applications close. Geographies are fault-tolerant to withstand complete region failure, through their connection
to the dedicated, high-capacity networking infrastructure.
Availability zones are physically separate locations within an Azure region. Each availability zone is made up of
one or more datacenters equipped with independent power, cooling, and networking. Availability zones allow
you to run mission-critical applications with high availability and low-latency replication.
The following figure shows how the Azure global infrastructure pairs region and availability zones within the
same data residency boundary for high availability, disaster recovery, and backup.
Geographically distributed datacenters enables Microsoft to be close to customers, to reduce network latency
and allow for geo-redundant backup and failover.

Physical security
Microsoft designs, builds, and operates datacenters in a way that strictly controls physical access to the areas
where your data is stored. Microsoft understands the importance of protecting your data, and is committed to
helping secure the datacenters that contain your data. We have an entire division at Microsoft devoted to
designing, building, and operating the physical facilities supporting Azure. This team is invested in maintaining
state-of-the-art physical security.
Microsoft takes a layered approach to physical security, to reduce the risk of unauthorized users gaining physical
access to data and the datacenter resources. Datacenters managed by Microsoft have extensive layers of
protection: access approval at the facility’s perimeter, at the building’s perimeter, inside the building, and on the
datacenter floor. Layers of physical security are:
Access request and approval. You must request access prior to arriving at the datacenter. You're
required to provide a valid business justification for your visit, such as compliance or auditing purposes.
All requests are approved on a need-to-access basis by Microsoft employees. A need-to-access basis
helps keep the number of individuals needed to complete a task in the datacenters to the bare minimum.
After Microsoft grants permission, an individual only has access to the discrete area of the datacenter
required, based on the approved business justification. Permissions are limited to a certain period of time,
and then expire.
Facility’s perimeter. When you arrive at a datacenter, you're required to go through a well-defined
access point. Typically, tall fences made of steel and concrete encompass every inch of the perimeter.
There are cameras around the datacenters, with a security team monitoring their videos at all times.
Building entrance. The datacenter entrance is staffed with professional security officers who have
undergone rigorous training and background checks. These security officers also routinely patrol the
datacenter, and monitor the videos of cameras inside the datacenter at all times.
Inside the building. After you enter the building, you must pass two-factor authentication with
biometrics to continue moving through the datacenter. If your identity is validated, you can enter only the
portion of the datacenter that you have approved access to. You can stay there only for the duration of
the time approved.
Datacenter floor. You are only allowed onto the floor that you're approved to enter. You are required to
pass a full body metal detection screening. To reduce the risk of unauthorized data entering or leaving the
datacenter without our knowledge, only approved devices can make their way into the datacenter floor.
Additionally, video cameras monitor the front and back of every server rack. When you exit the
datacenter floor, you again must pass through full body metal detection screening. To leave the
datacenter, you're required to pass through an additional security scan.
Microsoft requires visitors to surrender badges upon departure from any Microsoft facility.

Physical security reviews


Periodically, we conduct physical security reviews of the facilities, to ensure the datacenters properly address
Azure security requirements. The datacenter hosting provider personnel do not provide Azure service
management. Personnel can't sign in to Azure systems and don't have physical access to the Azure collocation
room and cages.

Data bearing devices


Microsoft uses best practice procedures and a wiping solution that is NIST 800-88 compliant. For hard drives
that can’t be wiped, we use a destruction process that destroys it and renders the recovery of information
impossible. This destruction process can be to disintegrate, shred, pulverize, or incinerate. We determine the
means of disposal according to the asset type. We retain records of the destruction.

Equipment disposal
Upon a system's end-of-life, Microsoft operational personnel follow rigorous data handling and hardware
disposal procedures to assure that hardware containing your data is not made available to untrusted parties. We
use a secure erase approach for hard drives that support it. For hard drives that can’t be wiped, we use a
destruction process that destroys the drive and renders the recovery of information impossible. This destruction
process can be to disintegrate, shred, pulverize, or incinerate. We determine the means of disposal according to
the asset type. We retain records of the destruction. All Azure services use approved media storage and disposal
management services.

Compliance
We design and manage the Azure infrastructure to meet a broad set of international and industry-specific
compliance standards, such as ISO 27001, HIPAA, FedRAMP, SOC 1, and SOC 2. We also meet country- or
region-specific standards, including Australia IRAP, UK G-Cloud, and Singapore MTCS. Rigorous third-party
audits, such as those done by the British Standards Institute, verify adherence to the strict security controls these
standards mandate.
For a full list of compliance standards that Azure adheres to, see the Compliance offerings.

Next steps
To learn more about what Microsoft does to help secure the Azure infrastructure, see:
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Azure infrastructure availability
12/12/2021 • 2 minutes to read • Edit Online

This article provides information about what Microsoft does to secure the Azure infrastructure and provide
maximum availability of customers' data. Azure provides robust availability, based on extensive redundancy
achieved with virtualization technology.

Temporary outages and natural disaster


The Microsoft Cloud Infrastructure and Operations team designs, builds, operates, and improves the security of
the cloud infrastructure. This team ensures that the Azure infrastructure is delivering high availability and
reliability, high efficiency, and smart scalability. The team provides a more secure, private, and trusted cloud.
Uninterruptible power supplies and vast banks of batteries ensure that electricity remains continuous if a short-
term power disruption occurs. Emergency generators provide backup power for extended outages and planned
maintenance. If a natural disaster occurs, the datacenter can use onsite fuel reserves.
High-speed and robust fiber optic networks connect datacenters with other major hubs and internet users.
Compute nodes host workloads closer to users to reduce latency, provide geo-redundancy, and increase overall
service resiliency. A team of engineers works around the clock to ensure services are persistently available.
Microsoft ensures high availability through advanced monitoring and incident response, service support, and
backup failover capability. Geographically distributed Microsoft operations centers operate 24/7/365. The Azure
network is one of the largest in the world. The fiber optic and content distribution network connects datacenters
and edge nodes to ensure high performance and reliability.

Disaster recovery
Azure keeps your data durable in two locations. You can choose the location of the backup site. In both locations,
Azure constantly maintains three healthy replicas of your data.

Database availability
Azure ensures that a database is internet accessible through an internet gateway with sustained database
availability. Monitoring assesses the health and state of the active databases at five-minute time intervals.

Storage availability
Azure delivers storage through a highly scalable and durable storage service, which provides connectivity
endpoints. This means that an application can access the storage service directly. The storage service processes
incoming storage requests efficiently, with transactional integrity.

Next steps
To learn more about what Microsoft does to help secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Azure information system components and
boundaries
12/12/2021 • 8 minutes to read • Edit Online

This article provides a general description of the Azure architecture and management. The Azure system
environment is made up of the following networks:
Microsoft Azure production network (Azure network)
Microsoft corporate network (corpnet)
Separate IT teams are responsible for operations and maintenance of these networks.

Azure architecture
Azure is a cloud computing platform and infrastructure for building, deploying, and managing applications and
services through a network of datacenters. Microsoft manages these datacenters. Based on the number of
resources you specify, Azure creates virtual machines (VMs) based on resource need. These VMs run on an
Azure hypervisor, which is designed for use in the cloud and is not accessible to the public.
On each Azure physical server node, there is a hypervisor that runs directly over the hardware. The hypervisor
divides a node into a variable number of guest VMs. Each node also has one root VM, which runs the host
operating system. Windows Firewall is enabled on each VM. You define which ports are addressable by
configuring the service definition file. These ports are the only ones open and addressable, internally or
externally. All traffic and access to the disk and network is mediated by the hypervisor and root operating
system.
At the host layer, Azure VMs run a customized and hardened version of the latest Windows Server. Azure uses a
version of Windows Server that includes only those components necessary to host VMs. This improves
performance and reduces attack surface. Machine boundaries are enforced by the hypervisor, which doesn’t
depend on the operating system security.
Azure management by fabric controllers
In Azure, VMs running on physical servers (blades/nodes) are grouped into clusters of about 1000. The VMs are
independently managed by a scaled-out and redundant platform software component called the fabric
controller (FC).
Each FC manages the lifecycle of applications running in its cluster, and provisions and monitors the health of
the hardware under its control. It runs autonomic operations, such as reincarnating VM instances on healthy
servers when it determines that a server has failed. The FC also performs application-management operations,
such as deploying, updating, and scaling out applications.
The datacenter is divided into clusters. Clusters isolate faults at the FC level, and prevent certain classes of errors
from affecting servers beyond the cluster in which they occur. FCs that serve a particular Azure cluster are
grouped into an FC cluster.
Hardware inventory
The FC prepares an inventory of Azure hardware and network devices during the bootstrap configuration
process. Any new hardware and network components entering the Azure production environment must follow
the bootstrap configuration process. The FC is responsible for managing the entire inventory listed in the
datacenter.xml configuration file.
FC -managed operating system images
The operating system team provides images, in the form of Virtual Hard Disks, deployed on all host and guest
VMs in the Azure production environment. The team constructs these base images through an automated
offline build process. The base image is a version of the operating system in which the kernel and other core
components have been modified and optimized to support the Azure environment.
There are three types of fabric-managed operating system images:
Host: A customized operating system that runs on host VMs.
Native: A native operating system that runs on tenants (for example, Azure Storage). This operating system
does not have any hypervisor.
Guest: A guest operating system that runs on guest VMs.
The host and native FC-managed operating systems are designed for use in the cloud, and are not publicly
accessible.
Host and native operating systems
Host and native are hardened operating system images that host the fabric agents, and run on a compute node
(runs as first VM on the node) and storage nodes. The benefit of using optimized base images of host and native
is that it reduces the surface area exposed by APIs or unused components. These can present high security risks
and increase the footprint of the operating system. Reduced-footprint operating systems only include the
components necessary to Azure.
Guest operating system
Azure internal components running on guest operating system VMs have no opportunity to run Remote
Desktop Protocol. Any changes to baseline configuration settings must go through the change and release
management process.

Azure datacenters
The Microsoft Cloud Infrastructure and Operations (MCIO) team manages the physical infrastructure and
datacenter facilities for all Microsoft online services. MCIO is primarily responsible for managing the physical
and environmental controls within the datacenters, as well as managing and supporting outer perimeter
network devices (such as edge routers and datacenter routers). MCIO is also responsible for setting up the bare
minimum server hardware on racks in the datacenter. Customers have no direct interaction with Azure.

Service management and service teams


Various engineering groups, known as service teams, manage the support of the Azure service. Each service
team is responsible for an area of support for Azure. Each service team must make an engineer available 24x7
to investigate and resolve failures in the service. Service teams do not, by default, have physical access to the
hardware operating in Azure.
The service teams are:
Application Platform
Azure Active Directory
Azure Compute
Azure Net
Cloud Engineering Services
ISSD: Security
Multifactor Authentication
SQL Database
Storage
Types of users
Employees (or contractors) of Microsoft are considered to be internal users. All other users are considered to be
external users. All Azure internal users have their employee status categorized with a sensitivity level that
defines their access to customer data (access or no access). User privileges to Azure (authorization permission
after authentication takes place) are described in the following table:

A UT H O RIZ ED
P RIVIL EGES A N D
IN T ERN A L O R F UN C T IO N S
RO L E EXT ERN A L SEN SIT IVIT Y L EVEL P ERF O RM ED A C C ESS T Y P E

Azure datacenter Internal No access to Manage the physical Persistent access to


engineer customer data security of the the environment.
premises. Conduct
patrols in and out of
the datacenter, and
monitor all entry
points. Escort into
and out of the
datacenter certain
non-cleared
personnel who
provide general
services (such as
dining or cleaning) or
IT work within the
datacenter. Conduct
routine monitoring
and maintenance of
network hardware.
Perform incident
management and
break-fix work by
using a variety of
tools. Conduct
routine monitoring
and maintenance of
the physical
hardware in the
datacenters. Access
to environment on
demand from
property owners.
Capable to perform
forensic
investigations, log
incident reports, and
require mandatory
security training and
policy requirements.
Operational
ownership and
maintenance of
critical security tools,
such as scanners and
log collection.
A UT H O RIZ ED
P RIVIL EGES A N D
IN T ERN A L O R F UN C T IO N S
RO L E EXT ERN A L SEN SIT IVIT Y L EVEL P ERF O RM ED A C C ESS T Y P E

Azure incident triage Internal Access to customer Manage Just-in-time access to


(rapid response data communications the environment,
engineers) among MCIO, with limited
support, and persistent access to
engineering teams. non-customer
Triage platform systems.
incidents,
deployment issues,
and service requests.

Azure deployment Internal Access to customer Deploy and upgrade Just-in-time access to
engineers data platform the environment,
components, with limited
software, and persistent access to
scheduled non-customer
configuration systems.
changes in support
of Azure.

Azure customer Internal Access to customer Debug and diagnose Just-in-time access to
outage support data platform outages and the environment,
(tenant) faults for individual with limited
compute tenants and persistent access to
Azure accounts. non-customer
Analyze faults. Drive systems.
critical fixes to the
platform or customer,
and drive technical
improvements across
support.

Azure live site Internal Access to customer Diagnose and Just-in-time access to
engineers data mitigate platform the environment,
(monitoring health by using with limited
engineers) and diagnostic tools. persistent access to
incident Drive fixes for volume non-customer
drivers, repair items systems.
resulting from
outages, and assist
outage restoration
actions.

Azure customers External N/A N/A N/A

Azure uses unique identifiers to authenticate organizational users and customers (or processes acting on behalf
of organizational users). This applies to all assets and devices that are part of the Azure environment.
Azure internal authentication
Communications between Azure internal components are protected with TLS encryption. In most cases, the
X.509 certificates are self-signed. Certificates with connections that can be accessed from outside the Azure
network are an exception, as are certificates for the FCs. FCs have certificates issued by a Microsoft Certificate of
Authority (CA) that is backed by a trusted root CA. This allows FC public keys to be rolled over easily.
Additionally, Microsoft developer tools use FC public keys. When developers submit new application images, the
images are encrypted with an FC public key in order to protect any embedded secrets.
Azure hardware device authentication
The FC maintains a set of credentials (keys and/or passwords) used to authenticate itself to various hardware
devices under its control. Microsoft uses a system to prevent access to these credentials. Specifically, the
transport, persistence, and use of these credentials is designed to prevent Azure developers, administrators, and
backup services and personnel access to sensitive, confidential, or private information.
Microsoft uses encryption based on the FC’s master identity public key. This occurs at FC setup and FC
reconfiguration times, to transfer the credentials used to access networking hardware devices. When the FC
needs the credentials, the FC retrieves and decrypts them.
Network devices
The Azure networking team configures network service accounts to enable an Azure client to authenticate to
network devices (routers, switches, and load balancers).

Secure service administration


Azure operations personnel are required to use secure admin workstations (SAWs). Customers can implement
similar controls by using privileged access workstations. With SAWs, administrative personnel use an
individually assigned administrative account that is separate from the user's standard user account. The SAW
builds on that account separation practice by providing a trustworthy workstation for those sensitive accounts.

Next steps
To learn more about what Microsoft does to help secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Azure network architecture
12/12/2021 • 2 minutes to read • Edit Online

The Azure network architecture provides connectivity from the Internet to the Azure datacenters. Any workload
deployed (IaaS, PaaS, and SaaS) on Azure is leveraging the Azure datacenter network.

Network topology
The network architecture of an Azure datacenter consists of the following components:
Edge network
Wide area network
Regional gateways network
Datacenter network

Network components
A brief description of the network components.
Edge network
Demarcation point between Microsoft networking and other networks (for example, Internet,
Enterprise network)
Provides Internet and ExpressRoute peering into Azure
Wide area network
Microsoft intelligent backbone network covering the globe
Provides connectivity between Azure regions
Regional gateway
Point of aggregation for all of the datacenters in an Azure region
Provides massive connectivity between datacenters within an Azure region (for example, multi
hundred terabits per datacenter)
Datacenter network
Provides connectivity between servers within the datacenter with low oversubscribed bandwidth
The above network components are designed to provide maximum availability to support always-on, always-
available cloud business. The redundancy is designed and built into the network from the physical aspect all the
way up to control protocol.

Datacenter network resiliency


Let’s illustrate the resiliency design principle using datacenter network.
The datacenter network is a modified version of a Clos network, providing high bi-sectional bandwidth for cloud
scale traffic. The network is constructed using a large number of commodity devices to reduce the impact
caused by individual hardware failure. These devices are strategically located in different physical locations with
separate power and cooling domain to reduce impact of an environment event. On the control plane, all
network devices are running as OSI model Layer 3 routing mode, which eliminates the historical issue of traffic
loop. All paths between different tiers are active to provide high redundancy and bandwidth using Equal-Cost
Multi-Path (ECMP) Routing.
The following diagram demonstrates that the datacenter network is constructed by different tiers of network
devices. The bars in the diagram represent groups of network devices which provide redundancy and high
bandwidth connectivity.

Next steps
To learn more about what Microsoft does to help secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
The Azure production network
12/12/2021 • 7 minutes to read • Edit Online

The users of the Azure production network include both external customers who access their own Azure
applications and internal Azure support personnel who manage the production network. This article discusses
the security access methods and protection mechanisms for establishing connections to the Azure production
network.

Internet routing and fault tolerance


A globally redundant internal and external Azure Domain Name Service (DNS) infrastructure, combined with
multiple primary and secondary DNS server clusters, provides fault tolerance. At the same time, additional
Azure network security controls, such as NetScaler, are used to prevent distributed denial of service (DDoS)
attacks and protect the integrity of Azure DNS services.
The Azure DNS servers are located at multiple datacenter facilities. The Azure DNS implementation incorporates
a hierarchy of secondary and primary DNS servers to publicly resolve Azure customer domain names. The
domain names usually resolve to a CloudApp.net address, which wraps the virtual IP (VIP) address for the
customer’s service. Unique to Azure, the VIP that corresponds to internal dedicated IP (DIP) address of the
tenant translation is done by the Microsoft load balancers responsible for that VIP.
Azure is hosted in geographically distributed Azure datacenters within the US, and it's built on state-of-the-art
routing platforms that implement robust, scalable architectural standards. Among the notable features are:
Multiprotocol Label Switching (MPLS)-based traffic engineering, which provides efficient link utilization and
graceful degradation of service if there is an outage.
Networks are implemented with “need plus one” (N+1) redundancy architectures or better.
Externally, datacenters are served by dedicated, high-bandwidth network circuits that redundantly connect
properties with over 1,200 internet service providers globally at multiple peering points. This connection
provides in excess of 2,000 gigabytes per second (GBps) of edge capacity.
Because Microsoft owns its own network circuits between datacenters, these attributes help the Azure offering
achieve 99.9+ percent network availability without the need for traditional third-party internet service
providers.

Connection to production network and associated firewalls


The Azure network internet traffic flow policy directs traffic to the Azure production network that's located in the
nearest regional datacenter within the US. Because the Azure production datacenters maintain consistent
network architecture and hardware, the traffic flow description that follows applies consistently to all
datacenters.
After internet traffic for Azure is routed to the nearest datacenter, a connection is established to the access
routers. These access routers serve to isolate traffic between Azure nodes and customer-instantiated VMs.
Network infrastructure devices at the access and edge locations are the boundary points where ingress and
egress filters are applied. These routers are configured through a tiered access-control list (ACL) to filter
unwanted network traffic and apply traffic rate limits, if necessary. Traffic that is allowed by ACL is routed to the
load balancers. Distribution routers are designed to allow only Microsoft-approved IP addresses, provide anti-
spoofing, and establish TCP connections that use ACLs.
External load-balancing devices are located behind the access routers to perform network address translation
(NAT) from internet-routable IPs to Azure internal IPs. The devices also route packets to valid production internal
IPs and ports, and they act as a protection mechanism to limit exposing the internal production network address
space.
By default, Microsoft enforces Hypertext Transfer Protocol Secure (HTTPS) for all traffic that's transmitted to
customers' web browsers, including sign-in and all traffic thereafter. The use of TLS v1.2 enables a secure tunnel
for traffic to flow through. ACLs on access and core routers ensure that the source of the traffic is consistent with
what is expected.
An important distinction in this architecture, when it's compared to traditional security architecture, is that there
are no dedicated hardware firewalls, specialized intrusion detection or prevention devices, or other security
appliances that are normally expected before connections are made to the Azure production environment.
Customers usually expect these hardware firewall devices in the Azure network; however, none are employed
within Azure. Almost exclusively, those security features are built into the software that runs the Azure
environment to provide robust, multi-layered security mechanisms, including firewall capabilities. Additionally,
the scope of the boundary and associated sprawl of critical security devices is easier to manage and inventory,
as shown in the preceding illustration, because it is managed by the software that's running Azure.

Core security and firewall features


Azure implements robust software security and firewall features at various levels to enforce security features
that are usually expected in a traditional environment to protect the core Security Authorization boundary.
Azure security features
Azure implements host-based software firewalls inside the production network. Several core security and
firewall features reside within the core Azure environment. These security features reflect a defense-in-depth
strategy within the Azure environment. Customer data in Azure is protected by the following firewalls:
Hyper visor firewall (packet filter) : This firewall is implemented in the hypervisor and configured by the
fabric controller (FC) agent. This firewall protects the tenant that runs inside the VM from unauthorized access.
By default, when a VM is created, all traffic is blocked and then the FC agent adds rules and exceptions in the
filter to allow authorized traffic.
Two categories of rules are programmed here:
Machine config or infrastructure rules : By default, all communication is blocked. Exceptions exist that
allow a VM to send and receive Dynamic Host Configuration Protocol (DHCP) communications and DNS
information, and send traffic to the “public” internet outbound to other VMs within the FC cluster and OS
Activation server. Because the VMs’ allowed list of outgoing destinations does not include Azure router
subnets and other Microsoft properties, the rules act as a layer of defense for them.
Role configuration file rules : Defines the inbound ACLs based on the tenants’ service model. For example,
if a tenant has a web front end on port 80 on a certain VM, port 80 is opened to all IP addresses. If the VM
has a worker role running, the worker role is opened only to the VM within the same tenant.
Native host firewall : Azure Service Fabric and Azure Storage run on a native OS, which has no hypervisor and,
therefore, Windows Firewall is configured with the preceding two sets of rules.
Host firewall : The host firewall protects the host partition, which runs the hypervisor. The rules are
programmed to allow only the FC and jump boxes to talk to the host partition on a specific port. The other
exceptions are to allow DHCP response and DNS replies. Azure uses a machine configuration file, which contains
a template of firewall rules for the host partition. A host firewall exception also exists that allows VMs to
communicate to host components, wire server, and metadata server, through specific protocol/ports.
Guest firewall : The Windows Firewall piece of the guest OS, which is configurable by customers on customer
VMs and storage.
Additional security features that are built into the Azure capabilities include:
Infrastructure components that are assigned IP addresses that are from DIPs. An attacker on the internet
cannot address traffic to those addresses because it would not reach Microsoft. Internet gateway routers
filter packets that are addressed solely to internal addresses, so they would not enter the production
network. The only components that accept traffic that's directed to VIPs are load balancers.
Firewalls that are implemented on all internal nodes have three primary security architecture
considerations for any given scenario:
Firewalls are placed behind the load balancer and accept packets from anywhere. These packets are
intended to be externally exposed and would correspond to the open ports in a traditional perimeter
firewall.
Firewalls accept packets only from a limited set of addresses. This consideration is part of the
defensive in-depth strategy against DDoS attacks. Such connections are cryptographically
authenticated.
Firewalls can be accessed only from select internal nodes. They accept packets only from an
enumerated list of source IP addresses, all of which are DIPs within the Azure network. For example,
an attack on the corporate network could direct requests to these addresses, but the attacks would be
blocked unless the source address of the packet was one in the enumerated list within the Azure
network.
The access router at the perimeter blocks outbound packets that are addressed to an address
that's inside the Azure network because of its configured static routes.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Azure SQL Database security features
12/12/2021 • 6 minutes to read • Edit Online

Azure SQL Database provides a relational database service in Azure. To protect customer data and provide
strong security features that customers expect from a relational database service, SQL Database has its own sets
of security capabilities. These capabilities build upon the controls that are inherited from Azure.

Security capabilities
Usage of the TDS protocol
Azure SQL Database supports only the tabular data stream (TDS) protocol, which requires the database to be
accessible over only the default port of TCP/1433.
Azure SQL Database firewall
To help protect customer data, Azure SQL Database includes a firewall functionality, which by default prevents all
access to SQL Database, as shown below.

The gateway firewall can limit addresses, which allows customers granular control to specify ranges of
acceptable IP addresses. The firewall grants access based on the originating IP address of each request.
Customers can achieve firewall configuration by using a management portal or programmatically using the
Azure SQL Database Management REST API. The Azure SQL Database gateway firewall by default prevents all
customer TDS access to Azure SQL Database. Customers must configure access by using access-control lists
(ACLs) to permit Azure SQL Database connections by source and destination internet addresses, protocols, and
port numbers.
DoSGuard
Denial of service (DoS) attacks are reduced by a SQL Database gateway service called DoSGuard. DoSGuard
actively tracks failed logins from IP addresses. If there are multiple failed logins from a specific IP address within
a period of time, the IP address is blocked from accessing any resources in the service for a pre-defined time
period.
In addition, the Azure SQL Database gateway performs:
Secure channel capability negotiations to implement TDS FIPS 140-2 validated encrypted connections when
it connects to the database servers.
Stateful TDS packet inspection while it accepts connections from clients. The gateway validates the
connection information and passes on the TDS packets to the appropriate physical server based on the
database name that's specified in the connection string.
The overarching principle for network security of the Azure SQL Database offering is to allow only the
connection and communication that is necessary to allow the service to operate. All other ports, protocols, and
connections are blocked by default. Virtual local area networks (VLANs) and ACLs are used to restrict network
communications by source and destination networks, protocols, and port numbers.
Mechanisms that are approved to implement network-based ACLs include ACLs on routers and load balancers.
These mechanisms are managed by Azure networking, guest VM firewall, and Azure SQL Database gateway
firewall rules, which are configured by the customer.

Data segregation and customer isolation


The Azure production network is structured such that publicly accessible system components are segregated
from internal resources. Physical and logical boundaries exist between web servers that provide access to the
public-facing Azure portal and the underlying Azure virtual infrastructure, where customer application instances
and customer data reside.
All publicly accessible information is managed within the Azure production network. The production network is
subject to two-factor authentication and boundary protection mechanisms, uses the firewall and security feature
set that is described in the previous section, and uses data isolation functions as noted in the next sections.
Unauthorized systems and isolation of the FC
Because the fabric controller (FC) is the central orchestrator of the Azure fabric, significant controls are in place
to mitigate threats to it, especially from potentially compromised FAs within customer applications. The FC does
not recognize any hardware whose device information (for example, MAC address) is not pre-loaded within the
FC. The DHCP servers on the FC have configured lists of MAC addresses of the nodes they are willing to boot.
Even if unauthorized systems are connected, they are not incorporated into fabric inventory, and therefore not
connected or authorized to communicate with any system within the fabric inventory. This reduces the risk of
unauthorized systems' communicating with the FC and gaining access to the VLAN and Azure.
VLAN isolation
The Azure production network is logically segregated into three primary VLANs:
The main VLAN: Interconnects untrusted customer nodes.
The FC VLAN: Contains trusted FCs and supporting systems.
The device VLAN: Contains trusted network and other infrastructure devices.
Packet filtering
The IPFilter and the software firewalls that are implemented on the root OS and guest OS of the nodes enforce
connectivity restrictions and prevent unauthorized traffic between VMs.
Hypervisor, root OS, and guest VMs
The isolation of the root OS from the guest VMs and the guest VMs from one another is managed by the
hypervisor and the root OS.
Types of rules on firewalls
A rule is defined as:
{Src IP, Src Port, Destination IP, Destination Port, Destination Protocol, In/Out, Stateful/Stateless, Stateful Flow
Timeout}.
Synchronous idle character (SYN) packets are allowed in or out only if any one of the rules permits it. For TCP,
Azure uses stateless rules where the principle is that it allows only all non-SYN packets into or out of the VM.
The security premise is that any host stack is resilient of ignoring a non-SYN if it has not seen a SYN packet
previously. The TCP protocol itself is stateful, and in combination with the stateless SYN-based rule achieves an
overall behavior of a stateful implementation.
For User Datagram Protocol (UDP), Azure uses a stateful rule. Every time a UDP packet matches a rule, a reverse
flow is created in the other direction. This flow has a built-in timeout.
Customers are responsible for setting up their own firewalls on top of what Azure provides. Here customers are
able to define the rules for inbound and outbound traffic.
Production configuration management
Standard secure configurations are maintained by respective operations teams in Azure and Azure SQL
Database. All configuration changes to production systems are documented and tracked through a central
tracking system. Software and hardware changes are tracked through the central tracking system. Networking
changes that relate to ACL are tracked using an ACL management service.
All configuration changes to Azure are developed and tested in the staging environment, and they are thereafter
deployed in production environment. Software builds are reviewed as part of testing. Security and privacy
checks are reviewed as part of entry checklist criteria. Changes are deployed on scheduled intervals by the
respective deployment team. Releases are reviewed and signed off by the respective deployment team
personnel before they are deployed into production.
Changes are monitored for success. On a failure scenario, the change is rolled back to its previous state or a
hotfix is deployed to address the failure with approval of the designated personnel. Source Depot, Git, TFS,
Master Data Services (MDS), runners, Azure security monitoring, the FC, and the WinFabric platform are used to
centrally manage, apply, and verify the configuration settings in the Azure virtual environment.
Similarly, hardware and network changes have established validation steps to evaluate their adherence to the
build requirements. The releases are reviewed and authorized through a coordinated change advisory board
(CAB) of respective groups across the stack.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Management and operation of the Azure
production network
12/12/2021 • 3 minutes to read • Edit Online

This article describes how Microsoft manages and operates the Azure production network to secure the Azure
datacenters.

Monitor, log, and report


The management and operation of the Azure production network is a coordinated effort between the operations
teams of Azure and Azure SQL Database. The teams use several system and application performance-
monitoring tools in the environment. And they use appropriate tools to monitor network devices, servers,
services, and application processes.
To ensure the secure execution of services running in the Azure environment, the operations teams implement
multiple levels of monitoring, logging, and reporting, including the following actions:
Primarily, the Microsoft Monitoring Agent (MMA) gathers monitoring and diagnostic log information
from many places, including the fabric controller (FC) and the root operating system (OS), and writes it to
log files. The agent eventually pushes a digested subset of the information into a pre-configured Azure
storage account. In addition, the freestanding monitoring and diagnostic service reads various
monitoring and diagnostic log data and summarizes the information. The monitoring and diagnostic
service writes the information to an integrated log. Azure uses the custom-built Azure security
monitoring, which is an extension to the Azure monitoring system. It has components that observe,
analyze, and report on security-pertinent events from various points in the platform.
The Azure SQL Database Windows Fabric platform provides management, deployment, development,
and operational oversight services for Azure SQL Database. The platform offers distributed, multi-step
deployment services, health monitoring, automatic repairs, and service version compliance. It provides
the following services:
Service modeling capabilities with high-fidelity development environment (datacenter clusters are
expensive and scarce).
One-click deployment and upgrade workflows for service bootstrap and maintenance.
Health reporting with automated repair workflows to enable self-healing.
Real time monitoring, alerting, and debugging facilities across the nodes of a distributed system.
Centralized collection of operational data and metrics for distributed root cause analysis and service
insight.
Operational tooling for deployment, change management, and monitoring.
The Azure SQL Database Windows Fabric platform and watchdog scripts run continuously and
monitor in real time.
If any anomalies occur, the incident response process followed by the Azure incident triage team is activated. The
appropriate Azure support personnel are notified to respond to the incident. Issue tracking and resolution are
documented and managed in a centralized ticketing system. System uptime metrics are available under the non-
disclosure agreement (NDA) and upon request.

Corporate network and multi-factor access to production


The corporate network user base includes Azure support personnel. The corporate network supports internal
corporate functions and includes access to internal applications that are used for Azure customer support. The
corporate network is both logically and physically separated from the Azure production network. Azure
personnel access the corporate network by using Azure workstations and laptops. All users must have an Azure
Active Directory (Azure AD) account, including a username and password, to access corporate network
resources. Corporate network access uses Azure AD accounts, which are issued to all Microsoft personnel,
contractors, and vendors and managed by Microsoft Information Technology. Unique user identifiers distinguish
personnel based on their employment status at Microsoft.
Access to internal Azure applications is controlled through authentication with Active Directory Federation
Services (AD FS). AD FS is a service hosted by Microsoft Information Technology that provides authentication of
corporate network users through applying a secure token and user claims. AD FS enables internal Azure
applications to authenticate users against the Microsoft corporate active directory domain. To access the
production network from the corporate network environment, users must authenticate by using multi-factor
authentication.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure infrastructure monitoring
Azure infrastructure integrity
Azure customer data protection
Azure infrastructure monitoring
12/12/2021 • 2 minutes to read • Edit Online

Configuration and change management


Azure reviews and updates configuration settings and baseline configurations of hardware, software, and
network devices annually. Changes are developed, tested, and approved prior to entering the production
environment from a development and/or test environment.
The baseline configurations that are required for Azure-based services are reviewed by the Azure security and
compliance team and by service teams. A service team review is part of the testing that occurs before the
deployment of their production service.

Vulnerability management
Security update management helps protect systems from known vulnerabilities. Azure uses integrated
deployment systems to manage the distribution and installation of security updates for Microsoft software.
Azure is also able to draw on the resources of the Microsoft Security Response Center (MSRC). The MSRC
identifies, monitors, responds to, and resolves security incidents and cloud vulnerabilities around the clock,
every day of the year.

Vulnerability scanning
Vulnerability scanning is performed on server operating systems, databases, and network devices. The
vulnerability scans are performed on a quarterly basis at minimum. Azure contracts with independent assessors
to perform penetration testing of the Azure boundary. Red-team exercises are also routinely performed and the
results are used to make security improvements.

Protective monitoring
Azure security has defined requirements for active monitoring. Service teams configure active monitoring tools
in accordance with these requirements. Active monitoring tools include the Microsoft Monitoring Agent (MMA)
and System Center Operations Manager. These tools are configured to provide time alerts to Azure security
personnel in situations that require immediate action.

Incident management
Microsoft implements a security incident management process to facilitate a coordinated response to incidents,
should one occur.
If Microsoft becomes aware of unauthorized access to customer data that's stored on its equipment or in its
facilities, or it becomes aware of unauthorized access to such equipment or facilities resulting in loss, disclosure,
or alteration of customer data, Microsoft takes the following actions:
Promptly notifies the customer of the security incident.
Promptly investigates the security incident and provides customers detailed information about the security
incident.
Takes reasonable and prompt steps to mitigate the effects and minimize any damage resulting from the
security incident.
An incident management framework has been established that defines roles and allocates responsibilities. The
Azure security incident management team is responsible for managing security incidents, including escalation,
and ensuring the involvement of specialist teams when necessary. Azure operations managers are responsible
for overseeing the investigation and resolution of security and privacy incidents.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure integrity
Azure customer data protection
Azure infrastructure integrity
12/12/2021 • 3 minutes to read • Edit Online

Software installation
All components in the software stack that are installed in the Azure environment are custom built following the
Microsoft Security Development Lifecycle (SDL) process. All software components, including operating system
(OS) images and SQL Database, are deployed as part of the change management and release management
process. The OS that runs on all nodes is a customized version of Windows Server 2008 or Windows Server
2012. The exact version is chosen by the fabric controller (FC) according to the role it intends for the OS to play.
In addition, the host OS does not allow installation of any unauthorized software components.
Some Azure components are deployed as Azure customers on a guest VM running on a guest OS.

Virus scans on builds


Azure software component (including OS) builds have to undergo a virus scan that uses the Endpoint Protection
anti-virus tool. Each virus scan creates a log within the associated build directory, detailing what was scanned
and the results of the scan. The virus scan is part of the build source code for every component within Azure.
Code is not moved to production without having a clean and successful virus scan. If any issues are noted, the
build is frozen and then goes to the security teams within Microsoft Security to identify where the "rogue" code
entered the build.

Closed and locked environment


By default, Azure infrastructure nodes and guest VMs do not have user accounts created on them. In addition,
default Windows administrator accounts are also disabled. Administrators from Azure live support can, with
proper authentication, log into these machines and administer the Azure production network for emergency
repairs.

Azure SQL Database authentication


As with any implementation of SQL Server, user account management must be tightly controlled. Azure SQL
Database supports only SQL Server authentication. To complement a customer's data security model, user
accounts with strong passwords and configured with specific rights should be used as well.

ACLs and firewalls between the Microsoft corporate network and an


Azure cluster
Access-control lists (ACLs) and firewalls between the service platform and the Microsoft corporate network
protect SQL Database instances from unauthorized insider access. Further, only users from IP address ranges
from the Microsoft corporate network can access the Windows Fabric platform-management endpoint.

ACLs and firewalls between nodes in a SQL Database cluster


As an additional protection, as part of the defense-in depth-strategy, ACLs and a firewall have been
implemented between nodes in a SQL Database cluster. All communication inside the Windows Fabric platform
cluster as well as all running code is trusted.
Custom monitoring agents
SQL Database employs custom monitoring agents (MAs), also called watchdogs, to monitor the health of the
SQL Database cluster.

Web protocols
Role instance monitoring and restart
Azure ensures that all deployed, running roles (internet-facing web, or back-end processing worker roles) are
subject to sustained health monitoring to ensure that they effectively and efficiently deliver the services for
which they’ve been provisioned. If a role becomes unhealthy, by either a critical fault in the application that's
being hosted or an underlying configuration problem within the role instance itself, the FC detects the problem
within the role instance and initiates a corrective state.
Compute connectivity
Azure ensures that the deployed application or service is reachable via standard web-based protocols. Virtual
instances of internet-facing web roles have external internet connectivity and are reachable directly by web
users. To protect the sensitivity and integrity of the operations that worker roles perform on behalf of the
publicly-accessible web role virtual instances, virtual instances of back-end processing worker roles have
external internet connectivity but cannot be accessed directly by external web users.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure customer data protection
Azure customer data protection
12/12/2021 • 4 minutes to read • Edit Online

Access to customer data by Microsoft operations and support personnel is denied by default. When access to
data related to a support case is granted, it is only granted using a just-in-time (JIT) model using policies that are
audited and vetted against our compliance and privacy policies. The access-control requirements are established
by the following Azure Security Policy:
No access to customer data, by default.
No user or administrator accounts on customer virtual machines (VMs).
Grant the least privilege that's required to complete task; audit and log access requests.
Azure support personnel are assigned unique corporate Active Directory accounts by Microsoft. Azure relies on
Microsoft corporate Active Directory, managed by Microsoft Information Technology (MSIT), to control access to
key information systems. Multi-factor authentication is required, and access is granted only from secure
consoles.
All access attempts are monitored and can be displayed via a basic set of reports.

Data protection
Azure provides customers with strong data security, both by default and as customer options.
Data segregation : Azure is a multi-tenant service, which means that multiple customer deployments and VMs
are stored on the same physical hardware. Azure uses logical isolation to segregate each customer’s data from
the data of others. Segregation provides the scale and economic benefits of multi-tenant services while
rigorously preventing customers from accessing one another’s data.
At-rest data protection : Customers are responsible for ensuring that data stored in Azure is encrypted in
accordance with their standards. Azure offers a wide range of encryption capabilities, giving customers the
flexibility to choose the solution that best meets their needs. Azure Key Vault helps customers easily maintain
control of keys that are used by cloud applications and services to encrypt data. Azure Disk Encryption enables
customers to encrypt VMs. Azure Storage Service Encryption makes it possible to encrypt all data placed into a
customer's storage account.
In-transit data protection : Microsoft provides a number of options that can be utilized by customers for
securing data in transit internally within the Azure network and externally across the Internet to the end user.
These include communication through Virtual Private Networks (utilizing IPsec/IKE encryption), Transport Layer
Security (TLS) 1.2 or later (via Azure components such as Application Gateway or Azure Front Door), protocols
directly on the Azure virtual machines (such as Windows IPsec or SMB), and more.
Additionally, "encryption by default" using MACsec (an IEEE standard at the data-link layer) is enabled for all
Azure traffic travelling between Azure datacenters to ensure confidentiality and integrity of customer data.
Data redundancy : Microsoft helps ensure that data is protected if there is a cyberattack or physical damage to
a datacenter. Customers may opt for:
In-country/in-region storage for compliance or latency considerations.
Out-of-country/out-of-region storage for security or disaster recovery purposes.
Data can be replicated within a selected geographic area for redundancy but cannot be transmitted outside it.
Customers have multiple options for replicating data, including the number of copies and the number and
location of replication datacenters.
When you create your storage account, select one of the following replication options:
Locally redundant storage (LRS) : Locally redundant storage maintains three copies of your data. LRS is
replicated three times within a single facility in a single region. LRS protects your data from normal hardware
failures, but not from a failure of a single facility.
Zone-redundant storage (ZRS) : Zone-redundant storage maintains three copies of your data. ZRS is
replicated three times across two to three facilities to provide higher durability than LRS. Replication occurs
within a single region or across two regions. ZRS helps ensure that your data is durable within a single
region.
Geo-redundant storage (GRS) : Geo-redundant storage is enabled for your storage account by default
when you create it. GRS maintains six copies of your data. With GRS, your data is replicated three times
within the primary region. Your data is also replicated three times in a secondary region hundreds of miles
away from the primary region, providing the highest level of durability. In the event of a failure at the
primary region, Azure Storage fails over to the secondary region. GRS helps ensure that your data is durable
in two separate regions.
Data destruction : When customers delete data or leave Azure, Microsoft follows strict standards for
overwriting storage resources before their reuse, as well as the physical destruction of decommissioned
hardware. Microsoft executes a complete deletion of data on customer request and on contract termination.

Customer data ownership


Microsoft does not inspect, approve, or monitor applications that customers deploy to Azure. Moreover,
Microsoft does not know what kind of data customers choose to store in Azure. Microsoft does not claim data
ownership over the customer information that's entered into Azure.

Records management
Azure has established internal records-retention requirements for back-end data. Customers are responsible for
identifying their own record retention requirements. For records that are stored in Azure, customers are
responsible for extracting their data and retaining their content outside of Azure for a customer-specified
retention period.
Azure allows customers to export data and audit reports from the product. The exports are saved locally to
retain the information for a customer-defined retention time period.

Electronic discovery (e-discovery)


Azure customers are responsible for complying with e-discovery requirements in their use of Azure services. If
Azure customers must preserve their customer data, they may export and save the data locally. Additionally,
customers can request exports of their data from the Azure Customer Support department. In addition to
allowing customers to export their data, Azure conducts extensive logging and monitoring internally.

Next steps
To learn more about what Microsoft does to secure the Azure infrastructure, see:
Azure facilities, premises, and physical security
Azure infrastructure availability
Azure information system components and boundaries
Azure network architecture
Azure production network
Azure SQL Database security features
Azure production operations and management
Azure infrastructure monitoring
Azure infrastructure integrity
Platform integrity and security overview
12/12/2021 • 2 minutes to read • Edit Online

The Azure fleet is composed of millions of servers (hosts) with thousands more added on a daily basis.
Thousands of hosts also undergo maintenance on a daily basis through reboots, operating system refreshes, or
repairs. Before a host can join the fleet and begin accepting customer workloads, Microsoft verifies that the host
is in a secure and trustworthy state. This verification ensures that malicious or inadvertent changes have not
occurred on boot sequence components during the supply chain or maintenance workflows.

Securing Azure hardware and firmware


This series of articles describe how Microsoft ensures integrity and security of hosts through various stages in
their lifecycle, from manufacturing to sunset. The articles address:
Firmware security
Platform code integrity
UEFI Secure Boot
Measured boot and host attestation
Project Cerberus
Encryption at rest
Hypervisor security

Next steps
Learn how Microsoft actively partners within the cloud hardware ecosystem to drive continuous
firmware security improvements.
Understand your shared responsibility in the cloud.
Firmware security
12/12/2021 • 2 minutes to read • Edit Online

This article describes how Microsoft secures the cloud hardware ecosystem and supply chains.

Securing the cloud hardware ecosystem


Microsoft actively partners within the cloud hardware ecosystem to drive continuous security improvements by:
Collaborating with Azure hardware and firmware partners (such as component manufacturers and
system integrators) to meet Azure hardware and firmware security requirements.
Enabling partners to perform continuous assessment and improvement of their products’ security
posture using Microsoft-defined requirements in areas such as:
Firmware secure boot
Firmware secure recovery
Firmware secure update
Firmware cryptography
Locked down hardware
Granular debug telemetry
System support for TPM 2.0 hardware to enable measured boot
Engaging in and contributing to the Open Compute Project (OCP) security project through the
development of specifications. Specifications promote consistency and clarity for secure design and
architecture in the ecosystem.

NOTE
An example of our contribution to the OCP Security Project is the Hardware Secure Boot specification.

Securing hardware and firmware supply chains


Cloud hardware suppliers and vendors for Azure are also required to adhere to supply chain security processes
and requirements developed by Microsoft. Hardware and firmware development and deployment processes are
required to follow the Microsoft Security Development Lifecycle (SDL) processes such as:
Threat modeling
Secure design reviews
Firmware reviews and penetration testing
Secure build and test environments
Security vulnerability management and incident response

Next steps
To learn more about what we do to drive platform integrity and security, see:
Platform code integrity
Secure boot
Measured boot and host attestation
Project Cerberus
Encryption at rest
Hypervisor security
Platform code integrity
12/12/2021 • 4 minutes to read • Edit Online

A significant challenge in operating a complex system like Microsoft Azure is ensuring that only authorized
software is running in the system. Unauthorized software presents several risks to any business:
Security risks such as dedicated attack tools, custom malware, and third-party software with known
vulnerabilities
Compliance risks when the approved change management process isn't used to bring in new software
Quality risk from externally developed software, which may not meet the operational requirements of the
business
In Azure, we face the same challenge and at significant complexity. We have thousands of servers running
software developed and maintained by thousands of engineers. This presents a large attack surface that cannot
be managed through business processes alone.

Adding an authorization gate


Azure uses a rich engineering process that implements gates on the security, compliance, and quality of the
software we deploy. This process includes access control to source code, conducting peer code reviews, doing
static analysis for security vulnerabilities, following Microsoft’s Security Development Lifecycle (SDL), and
conducting functional and quality testing. We need to guarantee that the software we deploy has flowed
through this process. Code integrity helps us achieve that guarantee.

Code integrity as an authorization gate


Code integrity is a kernel level service that became available starting in Windows Server 2016. Code integrity
can apply a strict execution control policy whenever a driver or a dynamically linked library (DLL) is loaded, an
executable binary is executed, or a script is run. Similar systems, such as DM-Verity, exist for Linux. A code
integrity policy consists of a set of authorization indicators, either code signing certificates or SHA256 file
hashes, which the kernel matches before loading or executing a binary or script.
Code Integrity allows a system administrator to define a policy that authorizes only binaries and scripts that
have been signed by particular certificates or match specified SHA256 hashes. The kernel enforces this policy by
blocking execution of everything that doesn't meet the set policy.
A concern with a code integrity policy is that unless the policy is perfectly correct, it can block critical software in
production and cause an outage. Given this concern, one may ask why it isn’t sufficient to use security
monitoring to detect when unauthorized software has executed. Code integrity has an audit mode that, instead
of preventing execution, can alert when unauthorized software is run. Alerting certainly can add much value in
addressing compliance risks, but for security risks such as ransomware or custom malware, delaying the
response by even a few seconds can be the difference between protection and an adversary gaining a persistent
foothold in your fleet. In Azure, we've invested significantly to manage any risk of code integrity contributing to
a customer impacting outage.

Build process
As discussed above, the Azure build system has a rich set of tests to ensure software changes are secure and
compliant. Once a build has progressed through validation, the build system signs it using an Azure build
certificate. The certificate indicates the build has passed through the entire change management process. The
final test that the build goes through is called Code Signature Validation (CSV). CSV confirms the newly built
binaries meet the code integrity policy before we deploy to production. This gives us high confidence that we
won't cause a customer impacting outage because of incorrectly signed binaries. If CSV finds a problem, the
build breaks and the relevant engineers are paged to investigate and fix the issue.

Safety during deployment


Even though we perform CSV for every build, there's still a chance that some change or inconsistency in
production may cause a code integrity related outage. For example, a machine may be running an old version of
the code integrity policy or it may be in an unhealthy state that produces false positives in code integrity. (At
Azure scale, we’ve seen it all.) As such, we need to continue to protect against the risk of an outage during
deployment.
All changes in Azure are required to deploy through a series of stages. The first of these are internal Azure
testing instances. The next stage is used only to serve other Microsoft product teams. The final stage serves
third-party customers. When a change is deployed, it moves to each of these stages in turn, and pauses to
measure the health of the stage. If the change is found to have no negative impact, then it moves to the next
stage. If we make a bad change to a code integrity policy, the change is detected during this staged deployment
and rolled back.

Incident response
Even with this layered protection, it's still possible that some server in the fleet may block properly authorized
software and cause a customer facing issue, one of our worst-case scenarios. Our final layer of defense is human
investigation. Each time code integrity blocks a file, it raises an alert for the on-call engineers to investigate. The
alert allows us to start security investigations and intervene, whether the issue is an indicator of a real attack, a
false positive, or other customer-impacting situation. This minimizes the time it takes to mitigate any code
integrity related issues.

Next steps
Learn how Windows 10 uses configurable code integrity.
To learn more about what we do to drive platform integrity and security, see:
Firmware security
Secure boot
Measured boot and host attestation
Project Cerberus
Encryption at rest
Hypervisor security
Secure Boot
12/12/2021 • 3 minutes to read • Edit Online

Secure Boot is a feature of the Unified Extensible Firmware Interface (UEFI) that requires all low-level firmware
and software components to be verified prior to loading. During boot, UEFI Secure Boot checks the signature of
each piece of boot software, including UEFI firmware drivers (also known as option ROMs), Extensible Firmware
Interface (EFI) applications, and the operating system drivers and binaries. If the signatures are valid or trusted
by the Original Equipment Manufacturer (OEM), the machine boots and the firmware gives control to the
operating system.

Components and process


Secure Boot relies on these critical components:
Platform key (PK) - Establishes trust between the platform owner (Microsoft) and the firmware. The public
half is PKpub and the private half is PKpriv.
Key enrollment key database (KEK) - Establishes trust between the OS and the platform firmware. The public
half is KEKpub and the private half is KEKpriv.
Signature database (db) - Holds the digests for trusted signers (public keys and certificates) of the firmware
and software code modules authorized to interact with platform firmware.
Revoked signatures database (dbx) – Holds revoked digests of code modules that have been identified to be
malicious, vulnerable, compromised, or untrusted. If a hash is in the signature db and the revoked signatures
db, the revoked signatures database takes precedent.
The following figure and process explains how these components are updated:

The OEM stores the Secure Boot digests on the machine’s nonvolatile RAM (NV-RAM) at the time of
manufacturing.
1. The signature database (db) is populated with the signers or image hashes of UEFI applications, operating
system loaders (such as the Microsoft Operating System Loader or Boot Manager), and UEFI drivers that are
trusted.
2. The revoked signatures database (dbx) is populated with digests of modules that are no longer trusted.
3. The key enrollment key (KEK) database is populated with signing keys that can be used to update the
signature database and revoked signatures database. The databases can be edited via updates that are
signed with the correct key or via updates by a physically present authorized user using firmware menus.
4. After the db, dbx, and KEK databases have been added and final firmware validation and testing is complete,
the OEM locks the firmware from editing and generates a platform key (PK). The PK can be used to sign
updates to the KEK or to turn off Secure Boot.
During each stage in the boot process, the digests of the firmware, bootloader, operating system, kernel drivers,
and other boot chain artifacts are calculated and compared to acceptable values. Firmware and software that are
discovered to be untrusted are not allowed to load. Thus, low-level malware injection or pre-boot malware
attacks can be blocked.

Secure Boot on the Azure fleet


Today, every machine that is onboarded and deployed to the Azure compute fleet to host customer workloads
comes from factory floors with Secure Boot enabled. Targeted tooling and processes are in place at every stage
in the hardware buildout and integration pipeline to ensure that Secure Boot enablement is not reverted either
by accident or by malicious intent.
Validating that the db and dbx digests are correct ensures:
Bootloader is present in one of the db entries
Bootloader’s signature is valid
Host boots with trusted software
By validating the signatures of KEKpub and PKpub, we can confirm that only trusted parties have permission to
modify the definitions of what software is considered trusted. Lastly, by ensuring that secure boot is active, we
can validate that these definitions are being enforced.

Next steps
To learn more about what we do to drive platform integrity and security, see:
Firmware security
Platform code integrity
Measured boot and host attestation
Project Cerberus
Encryption at rest
Hypervisor security
Measured boot and host attestation
12/12/2021 • 3 minutes to read • Edit Online

This article describes how Microsoft ensures integrity and security of hosts through measured boot and host
attestation.

Measured boot
The Trusted Platform Module (TPM) is a tamper-proof, cryptographically secure auditing component with
firmware supplied by a trusted third party. The boot configuration log contains hash-chained measurements
recorded in its Platform Configuration Registers (PCR) when the host last underwent the bootstrapping
sequence. The following figure shows this recording process. Incrementally adding a previously hashed
measurement to the next measurement’s hash and running the hashing algorithm on the union accomplishes
hash-chaining.

Attestation is accomplished when a host furnishes proof of its configuration state using its boot configuration
log (TCGLog). Forgery of a boot log is difficult because the TPM doesn't expose its PCR values other than the
read and extend operations. Furthermore, the credentials supplied by the Host Attestation Service are sealed to
specific PCR values. The use of hash-chaining makes it computationally infeasible to spoof or unseal the
credentials out-of-band.

Host Attestation Service


Host Attestation Service is a preventative measure that checks if host machines are trustworthy before they're
allowed to interact with customer data or workloads. Host Attestation Service checks by validating a compliance
statement (verifiable proof of the host’s compliance) sent by each host against an attestation policy (definition of
the secure state). The integrity of this system is assured by a root-of-trust provided by a TPM.
Host Attestation Service is present in each Azure cluster within a specialized locked-down environment. The
locked down environment includes other gatekeeper services that participate in the host machine bootstrapping
protocol. A public key infrastructure (PKI) acts as an intermediary for validating the provenance of attestation
requests and as an identity issuer (contingent upon successful host attestation). The post-attestation credentials
issued to the attesting host are sealed to its identity. Only the requesting host can unseal the credentials and
leverage them for obtaining incremental permissions. This prevents against man-in-the middle and spoofing
attacks.
If an Azure host arrives from factory with a security misconfiguration or is tampered with in the datacenter, its
TCGLog contains indicators of compromise flagged by the Host Attestation Service upon the next attestation,
which causes an attestation failure. Attestation failures prevent the Azure fleet from trusting the offending host.
This prevention effectively blocks all communications to and from the host and triggers an incident workflow.
Investigation and a detailed post-mortem analysis are conducted to determine root causes and any potential
indications of compromise. It's only after the analysis is complete that a host is remediated and has the
opportunity to join the Azure fleet and take on customer workloads.
Following is a high-level architecture of the host attestation service:

Attestation measurements
Following are examples of the many measurements captured today.
Secure Boot and Secure Boot keys
By validating that the signature database and revoked signatures database digests are correct, the Host
Attestation Service assures the client agent considers the right software to be trusted. By validating the
signatures of the public key enrollment key database and public platform key, the Host Attestation Service
confirms that only trusted parties have permission to modify the definitions of what software is considered
trusted. Lastly, by ensuring that secure boot is active the Host Attestation Service validates these definitions are
being enforced.
Debug controls
Debuggers are powerful tools for developers. However, the unfettered access to memory and other debug
commands could weaken data protection and system integrity if given to a non-trusted party. Host Attestation
Service ensures any kind of debugging is disabled on boot on production machines.
Code integrity
UEFI Secure Boot ensures that only trusted low-level software can run during the boot sequence. The same
checks, though, must also be applied in the post-boot environment to drivers and other executables with kernel-
mode access. To that end, a code integrity (CI) policy is used to define which drivers, binaries, and other
executables are considered trusted by specifying valid and invalid signatures. These policies are enforced.
Violations of policy generate alerts to the security incident response team for investigation.

Next steps
To learn more about what we do to drive platform integrity and security, see:
Firmware security
Platform code integrity
Secure boot
Project Cerberus
Encryption at rest
Hypervisor security
Project Cerberus
12/12/2021 • 2 minutes to read • Edit Online

Cerberus is a NIST 800-193 compliant hardware root-of-trust with an identity that cannot be cloned. Cerberus is
designed to further raise the security posture of Azure infrastructure by providing a strong anchor of trust for
firmware integrity.

Enabling an anchor of trust


Every Cerberus chip has a unique cryptographic identity that is established using a signed certificate chain
rooted to a Microsoft certificate authority (CA). Measurements obtained from Cerberus can be used to validate
integrity of components such as:
Host
Baseboard Management Controller (BMC)
All peripherals, including network interface card and system-on-a-chip (SoC)
This anchor of trust helps defend platform firmware from:
Compromised firmware binaries running on the platform
Malware and hackers that exploit bugs in the operating system, application, or hypervisor
Certain types of supply chain attacks (manufacturing, assembly, transit)
Malicious insiders with administrative privileges or access to hardware

Cerberus attestation
Cerberus authenticates firmware integrity for server components using a Platform Firmware Manifest (PFM).
PFM defines a list of authorized firmware versions and provides a platform measurement to the Azure Host
Attestation Service. The Host Attestation Service validates the measurements and makes a determination to only
allow trusted hosts to join the Azure fleet and host customer workloads.
In conjunction with the Host Attestation Service, Cerberus’ capabilities enhance and promote a highly secure
Azure production infrastructure.

NOTE
To learn more, see the Project Cerberus information on GitHub.

Next steps
To learn more about what we do to drive platform integrity and security, see:
Firmware security
Platform code integrity
Secure boot
Measured boot and host attestation
Encryption at rest
Hypervisor security
Azure Data Encryption at rest
12/12/2021 • 11 minutes to read • Edit Online

Microsoft Azure includes tools to safeguard data according to your company's security and compliance needs.
This paper focuses on:
How data is protected at rest across Microsoft Azure
Discusses the various components taking part in the data protection implementation,
Reviews pros and cons of the different key management protection approaches.
Encryption at Rest is a common security requirement. In Azure, organizations can encrypt data at rest without
the risk or cost of a custom key management solution. Organizations have the option of letting Azure
completely manage Encryption at Rest. Additionally, organizations have various options to closely manage
encryption or encryption keys.

What is encryption at rest?


Encryption is the secure encoding of data used to protect confidentiality of data. The Encryption at Rest designs
in Azure use symmetric encryption to encrypt and decrypt large amounts of data quickly according to a simple
conceptual model:
A symmetric encryption key is used to encrypt data as it is written to storage.
The same encryption key is used to decrypt that data as it is readied for use in memory.
Data may be partitioned, and different keys may be used for each partition.
Keys must be stored in a secure location with identity-based access control and audit policies. Data
encryption keys which are stored outside of secure locations are encrypted with a key encryption key kept in
a secure location.
In practice, key management and control scenarios, as well as scale and availability assurances, require
additional constructs. Microsoft Azure Encryption at Rest concepts and components are described below.

The purpose of encryption at rest


Encryption at rest provides data protection for stored data (at rest). Attacks against data at-rest include attempts
to obtain physical access to the hardware on which the data is stored, and then compromise the contained data.
In such an attack, a server's hard drive may have been mishandled during maintenance allowing an attacker to
remove the hard drive. Later the attacker would put the hard drive into a computer under their control to
attempt to access the data.
Encryption at rest is designed to prevent the attacker from accessing the unencrypted data by ensuring the data
is encrypted when on disk. If an attacker obtains a hard drive with encrypted data but not the encryption keys,
the attacker must defeat the encryption to read the data. This attack is much more complex and resource
consuming than accessing unencrypted data on a hard drive. For this reason, encryption at rest is highly
recommended and is a high priority requirement for many organizations.
Encryption at rest may also be required by an organization's need for data governance and compliance efforts.
Industry and government regulations such as HIPAA, PCI and FedRAMP, lay out specific safeguards regarding
data protection and encryption requirements. Encryption at rest is a mandatory measure required for
compliance with some of those regulations. For more information on Microsoft's approach to FIPS 140-2
validation, see Federal Information Processing Standard (FIPS) Publication 140-2.
In addition to satisfying compliance and regulatory requirements, encryption at rest provides defense-in-depth
protection. Microsoft Azure provides a compliant platform for services, applications, and data. It also provides
comprehensive facility and physical security, data access control, and auditing. However, it's important to
provide additional "overlapping" security measures in case one of the other security measures fails and
encryption at rest provides such a security measure.
Microsoft is committed to encryption at rest options across cloud services and giving customers control of
encryption keys and logs of key use. Additionally, Microsoft is working towards encrypting all customer data at
rest by default.

Azure Encryption at Rest Components


As described previously, the goal of encryption at rest is that data that is persisted on disk is encrypted with a
secret encryption key. To achieve that goal secure key creation, storage, access control, and management of the
encryption keys must be provided. Though details may vary, Azure services Encryption at Rest implementations
can be described in terms illustrated in the following diagram.

Azure Key Vault


The storage location of the encryption keys and access control to those keys is central to an encryption at rest
model. The keys need to be highly secured but manageable by specified users and available to specific services.
For Azure services, Azure Key Vault is the recommended key storage solution and provides a common
management experience across services. Keys are stored and managed in key vaults, and access to a key vault
can be given to users or services. Azure Key Vault supports customer creation of keys or import of customer
keys for use in customer-managed encryption key scenarios.
Azure Active Directory
Permissions to use the keys stored in Azure Key Vault, either to manage or to access them for Encryption at Rest
encryption and decryption, can be given to Azure Active Directory accounts.
Envelope Encryption with a Key Hierarchy
More than one encryption key is used in an encryption at rest implementation. Storing an encryption key in
Azure Key Vault ensures secure key access and central management of keys. However, service local access to
encryption keys is more efficient for bulk encryption and decryption than interacting with Key Vault for every
data operation, allowing for stronger encryption and better performance. Limiting the use of a single encryption
key decreases the risk that the key will be compromised and the cost of re-encryption when a key must be
replaced. Azure encryption at rest models use envelope encryption, where a key encryption key encrypts a data
encryption key. This model forms a key hierarchy which is better able to address performance and security
requirements:
Data Encr yption Key (DEK) – A symmetric AES256 key used to encrypt a partition or block of data,
sometimes also referred to as simply a Data Key. A single resource may have many partitions and many Data
Encryption Keys. Encrypting each block of data with a different key makes crypto analysis attacks more
difficult. And keeping DEKs local to the service encrypting and decrypting data maximizes performance.
Key Encr yption Key (KEK) – An encryption key used to encrypt the Data Encryption Keys using envelope
encryption, also referred to as wrapping. Use of a Key Encryption Key that never leaves Key Vault allows the
data encryption keys themselves to be encrypted and controlled. The entity that has access to the KEK may
be different than the entity that requires the DEK. An entity may broker access to the DEK to limit the access
of each DEK to a specific partition. Since the KEK is required to decrypt the DEKs, customers can
cryptographically erase DEKs and data by disabling of the KEK.
Resource providers and application instances store the encrypted Data Encryption Keys as metadata. Only an
entity with access to the Key Encryption Key can decrypt these Data Encryption Keys. Different models of key
storage are supported. For more information, see data encryption models.

Encryption at rest in Microsoft cloud services


Microsoft Cloud services are used in all three cloud models: IaaS, PaaS, SaaS. Below you have examples of how
they fit on each model:
Software services, referred to as Software as a Server or SaaS, which have applications provided by the cloud
such as Microsoft 365.
Platform services in which customers use the cloud for things like storage, analytics, and service bus
functionality in their applications.
Infrastructure services, or Infrastructure as a Service (IaaS) in which customer deploys operating systems and
applications that are hosted in the cloud and possibly leveraging other cloud services.
Encryption at rest for SaaS customers
Software as a Service (SaaS) customers typically have encryption at rest enabled or available in each service.
Microsoft 365 has several options for customers to verify or enable encryption at rest. For information about
Microsoft 365 services, see Encryption in Microsoft 365.
Encryption at rest for PaaS customers
Platform as a Service (PaaS) customer's data typically resides in a storage service such as Blob Storage but may
also be cached or stored in the application execution environment, such as a virtual machine. To see the
encryption at rest options available to you, examine the Data encryption models: supporting services table for
the storage and application platforms that you use.
Encryption at rest for IaaS customers
Infrastructure as a Service (IaaS) customers can have a variety of services and applications in use. IaaS services
can enable encryption at rest in their Azure hosted virtual machines and VHDs using Azure Disk Encryption.
Encrypted storage
Like PaaS, IaaS solutions can leverage other Azure services that store data encrypted at rest. In these cases, you
can enable the Encryption at Rest support as provided by each consumed Azure service. The Data encryption
models: supporting services table enumerates the major storage, services, and application platforms and the
model of Encryption at Rest supported.
Encrypted compute
All Managed Disks, Snapshots, and Images are encrypted using Storage Service Encryption using a service-
managed key. A more complete Encryption at Rest solution ensures that the data is never persisted in
unencrypted form. While processing the data on a virtual machine, data can be persisted to the Windows page
file or Linux swap file, a crash dump, or to an application log. To ensure this data is encrypted at rest, IaaS
applications can use Azure Disk Encryption on an Azure IaaS virtual machine (Windows or Linux) and virtual
disk.
Custom encryption at rest
It is recommended that whenever possible, IaaS applications leverage Azure Disk Encryption and Encryption at
Rest options provided by any consumed Azure services. In some cases, such as irregular encryption
requirements or non-Azure based storage, a developer of an IaaS application may need to implement
encryption at rest themselves. Developers of IaaS solutions can better integrate with Azure management and
customer expectations by leveraging certain Azure components. Specifically, developers should use the Azure
Key Vault service to provide secure key storage as well as provide their customers with consistent key
management options with that of most Azure platform services. Additionally, custom solutions should use
Azure-Managed Service Identities to enable service accounts to access encryption keys. For developer
information on Azure Key Vault and Managed Service Identities, see their respective SDKs.

Azure resource providers encryption model support


Microsoft Azure Services each support one or more of the encryption at rest models. For some services,
however, one or more of the encryption models may not be applicable. For services that support customer-
managed key scenarios, they may support only a subset of the key types that Azure Key Vault supports for key
encryption keys. Additionally, services may release support for these scenarios and key types at different
schedules. This section describes the encryption at rest support at the time of this writing for each of the major
Azure data storage services.
Azure disk encryption
Any customer using Azure Infrastructure as a Service (IaaS) features can achieve encryption at rest for their IaaS
VMs and disks through Azure Disk Encryption. For more information on Azure Disk encryption, see the Azure
Disk Encryption documentation.
Azure storage
All Azure Storage services (Blob storage, Queue storage, Table storage, and Azure Files) support server-side
encryption at rest; some services additionally support customer-managed keys and client-side encryption.
Server-side: All Azure Storage Services enable server-side encryption by default using service-managed
keys, which is transparent to the application. For more information, see Azure Storage Service Encryption for
Data at Rest. Azure Blob storage and Azure Files also support RSA 2048-bit customer-managed keys in Azure
Key Vault. For more information, see Storage Service Encryption using customer-managed keys in Azure Key
Vault.
Client-side: Azure Blobs, Tables, and Queues support client-side encryption. When using client-side
encryption, customers encrypt the data and upload the data as an encrypted blob. Key management is done
by the customer. For more information, see Client-Side Encryption and Azure Key Vault for Microsoft Azure
Storage.
Azure SQL Database
Azure SQL Database currently supports encryption at rest for Microsoft-managed service side and client-side
encryption scenarios.
Support for server encryption is currently provided through the SQL feature called Transparent Data Encryption.
Once an Azure SQL Database customer enables TDE key are automatically created and managed for them.
Encryption at rest can be enabled at the database and server levels. As of June 2017, Transparent Data
Encryption (TDE) is enabled by default on newly created databases. Azure SQL Database supports RSA 2048-bit
customer-managed keys in Azure Key Vault. For more information, see Transparent Data Encryption with Bring
Your Own Key support for Azure SQL Database and Data Warehouse.
Client-side encryption of Azure SQL Database data is supported through the Always Encrypted feature. Always
Encrypted uses a key that created and stored by the client. Customers can store the master key in a Windows
certificate store, Azure Key Vault, or a local Hardware Security Module. Using SQL Server Management Studio,
SQL users choose what key they'd like to use to encrypt which column.
Conclusion
Protection of customer data stored within Azure Services is of paramount importance to Microsoft. All Azure
hosted services are committed to providing Encryption at Rest options. Azure services support either service-
managed keys, customer-managed keys, or client-side encryption. Azure services are broadly enhancing
Encryption at Rest availability and new options are planned for preview and general availability in the upcoming
months.

Next steps
See data encryption models to learn more about service-managed keys and customer-managed keys.
Learn how Azure uses double encryption to mitigate threats that come with encrypting data.
Learn what Microsoft does to ensure platform integrity and security of hosts traversing the hardware and
firmware build-out, integration, operationalization, and repair pipelines.
Hypervisor security on the Azure fleet
12/12/2021 • 3 minutes to read • Edit Online

The Azure hypervisor system is based on Windows Hyper-V. The hypervisor system enables the computer
administrator to specify guest partitions that have separate address spaces. The separate address spaces allow
you to load an operating system and applications operating in parallel of the (host) operating system that
executes in the root partition of the computer. The host OS (also known as privileged root partition) has direct
access to all the physical devices and peripherals on the system (storage controllers, networking adaptions). The
host OS allows guest partitions to share the use of these physical devices by exposing “virtual devices” to each
guest partition. Thus, an operating system executing in a guest partition has access to virtualized peripheral
devices that are provided by virtualization services executing in the root partition.
The Azure hypervisor is built keeping the following security objectives in mind:

O B JEC T IVE SO URC E

Isolation A security policy mandates no information transfer between


VMs. This constraint requires capabilities in the Virtual
Machine Manager (VMM) and hardware for isolation of
memory, devices, the network, and managed resources such
as persisted data.

VMM integrity To achieve overall system integrity, the integrity of individual


hypervisor components is established and maintained.

Platform integrity The integrity of the hypervisor depends on the integrity of


the hardware and software on which it relies. Although the
hypervisor doesn't have direct control over the integrity of
the platform, Azure relies on hardware and firmware
mechanisms such as the Cerberus chip to protect and detect
the underlying platform integrity. The VMM and guests are
prevented from running if platform integrity is compromised.

Restricted access Management functions are exercised only by authorized


administrators connected over secure connections. A
principle of least privilege is enforced by Azure role-based
access control (Azure RBAC) mechanisms.

Audit Azure enables audit capability to capture and protect data


about what happens on a system so that it can later be
inspected.

Microsoft’s approach to hardening the Azure hypervisor and the virtualization subsystem can be broken down
into the following three categories.

Strongly defined security boundaries enforced by the hypervisor


The Azure hypervisor enforces multiple security boundaries between:
Virtualized “guest” partitions and privileged partition (“host”)
Multiple guests
Itself and the host
Itself and all guests
Confidentiality, integrity, and availability are assured for the hypervisor security boundaries. The boundaries
defend against a range of attacks including side-channel information leaks, denial-of-service, and elevation of
privilege.
The hypervisor security boundary also provides segmentation between tenants for network traffic, virtual
devices, storage, compute resources, and all other VM resources.

Defense-in-depth exploit mitigations


In the unlikely event a security boundary has a vulnerability, the Azure hypervisor includes multiple layers of
mitigations including:
Isolation of host-based process hosting cross-VM components
Virtualization-based security (VBS) for ensuring the integrity of user and kernel mode components from a
secure world
Multiple levels of exploit mitigations. Mitigations include address space layout randomization (ASLR), data
execution prevention (DEP), arbitrary code guard, control flow integrity, and data corruption prevention
Automatic initialization of stack variables at the compiler level
Kernel APIs that automatically zero-initialize kernel heap allocations made by Hyper-V
These mitigations are designed to make the development of an exploit for a cross-VM vulnerability infeasible.

Strong security assurance processes


The attack surface related to the hypervisor includes software networking, virtual devices, and all cross-VM
surfaces. The attack surface is tracked through automated build integration, which triggers periodic security
reviews.
All VM attack surfaces are threat modeled, code reviewed, fuzzed, and tested by our RED team for security
boundary violations. Microsoft has a bug bounty program that pays an award for relevant vulnerabilities in
eligible product versions for Microsoft Hyper-V.

NOTE
Learn more about strong security assurance processes in Hyper-V.

Next steps
To learn more about what we do to drive platform integrity and security, see:
Firmware security
Platform code integrity
Secure boot
Measured boot and host attestation
Project Cerberus
Encryption at rest
Isolation in the Azure Public Cloud
12/12/2021 • 23 minutes to read • Edit Online

Azure allows you to run applications and virtual machines (VMs) on shared physical infrastructure. One of the
prime economic motivations to running applications in a cloud environment is the ability to distribute the cost
of shared resources among multiple customers. This practice of multi-tenancy improves efficiency by
multiplexing resources among disparate customers at low costs. Unfortunately, it also introduces the risk of
sharing physical servers and other infrastructure resources to run your sensitive applications and VMs that may
belong to an arbitrary and potentially malicious user.
This article outlines how Azure provides isolation against both malicious and non-malicious users and serves as
a guide for architecting cloud solutions by offering various isolation choices to architects.

Tenant Level Isolation


One of the primary benefits of cloud computing is concept of a shared, common infrastructure across numerous
customers simultaneously, leading to economies of scale. This concept is called multi-tenancy. Microsoft works
continuously to ensure that the multi-tenant architecture of Microsoft Cloud Azure supports security,
confidentiality, privacy, integrity, and availability standards.
In the cloud-enabled workplace, a tenant can be defined as a client or organization that owns and manages a
specific instance of that cloud service. With the identity platform provided by Microsoft Azure, a tenant is simply
a dedicated instance of Azure Active Directory (Azure AD) that your organization receives and owns when it
signs up for a Microsoft cloud service.
Each Azure AD directory is distinct and separate from other Azure AD directories. Just like a corporate office
building is a secure asset specific to only your organization, an Azure AD directory was also designed to be a
secure asset for use by only your organization. The Azure AD architecture isolates customer data and identity
information from co-mingling. This means that users and administrators of one Azure AD directory cannot
accidentally or maliciously access data in another directory.
Azure Tenancy
Azure tenancy (Azure Subscription) refers to a “customer/billing” relationship and a unique tenant in Azure
Active Directory. Tenant level isolation in Microsoft Azure is achieved using Azure Active Directory and Azure
role-based access control offered by it. Each Azure subscription is associated with one Azure Active Directory
(AD) directory.
Users, groups, and applications from that directory can manage resources in the Azure subscription. You can
assign these access rights using the Azure portal, Azure command-line tools, and Azure Management APIs. An
Azure AD tenant is logically isolated using security boundaries so that no customer can access or compromise
co-tenants, either maliciously or accidentally. Azure AD runs on “bare metal” servers isolated on a segregated
network segment, where host-level packet filtering and Windows Firewall block unwanted connections and
traffic.

Access to data in Azure AD requires user authentication via a security token service (STS). Information on
the user’s existence, enabled state, and role is used by the authorization system to determine whether the
requested access to the target tenant is authorized for this user in this session.
Tenants are discrete containers and there is no relationship between these.
No access across tenants unless tenant admin grants it through federation or provisioning user accounts
from other tenants.
Physical access to servers that comprise the Azure AD service, and direct access to Azure AD’s back-end
systems, is restricted.
Azure AD users have no access to physical assets or locations, and therefore it is not possible for them to
bypass the logical Azure RBAC policy checks stated following.
For diagnostics and maintenance needs, an operational model that employs a just-in-time privilege elevation
system is required and used. Azure AD Privileged Identity Management (PIM) introduces the concept of an
eligible admin. Eligible admins should be users that need privileged access now and then, but not every day. The
role is inactive until the user needs access, then they complete an activation process and become an active
admin for a predetermined amount of time.

Azure Active Directory hosts each tenant in its own protected container, with policies and permissions to and
within the container solely owned and managed by the tenant.
The concept of tenant containers is deeply ingrained in the directory service at all layers, from portals all the
way to persistent storage.
Even when metadata from multiple Azure Active Directory tenants is stored on the same physical disk, there is
no relationship between the containers other than what is defined by the directory service, which in turn is
dictated by the tenant administrator.
Azure role -based access control (Azure RBAC )
Azure role-based access control (Azure RBAC) helps you to share various components available within an Azure
subscription by providing fine-grained access management for Azure. Azure RBAC enables you to segregate
duties within your organization and grant access based on what users need to perform their jobs. Instead of
giving everybody unrestricted permissions in Azure subscription or resources, you can allow only certain
actions.
Azure RBAC has three basic roles that apply to all resource types:
Owner has full access to all resources including the right to delegate access to others.
Contributor can create and manage all types of Azure resources but can’t grant access to others.
Reader can view existing Azure resources.

The rest of the Azure roles in Azure allow management of specific Azure resources. For example, the Virtual
Machine Contributor role allows the user to create and manage virtual machines. It does not give them access to
the Azure Virtual Network or the subnet that the virtual machine connects to.
Azure built-in roles list the roles available in Azure. It specifies the operations and scope that each built-in role
grants to users. If you're looking to define your own roles for even more control, see how to build Custom roles
in Azure RBAC.
Some other capabilities for Azure Active Directory include:
Azure AD enables SSO to SaaS applications, regardless of where they are hosted. Some applications are
federated with Azure AD, and others use password SSO. Federated applications can also support user
provisioning and password vaulting.
Access to data in Azure Storage is controlled via authentication. Each storage account has a primary key
(storage account key, or SAK) and a secondary secret key (the shared access signature, or SAS).
Azure AD provides Identity as a Service through federation by using Active Directory Federation Services,
synchronization, and replication with on-premises directories.
Azure AD Multi-Factor Authentication requires users to verify sign-ins by using a mobile app, phone call,
or text message. It can be used with Azure AD to help secure on-premises resources with the Multi-Factor
Authentication Server, and also with custom applications and directories using the SDK.
Azure AD Domain Services lets you join Azure virtual machines to an Active Directory domain without
deploying domain controllers. You can sign in to these virtual machines with your corporate Active
Directory credentials and administer domain-joined virtual machines by using Group Policy to enforce
security baselines on all your Azure virtual machines.
Azure Active Directory B2C provides a highly available global-identity management service for
consumer-facing applications that scales to hundreds of millions of identities. It can be integrated across
mobile and web platforms. Your consumers can sign in to all your applications through customizable
experiences by using their existing social accounts or by creating credentials.
Isolation from Microsoft Administrators & Data Deletion
Microsoft takes strong measures to protect your data from inappropriate access or use by unauthorized
persons. These operational processes and controls are backed by the Online Services Terms, which offer
contractual commitments that govern access to your data.
Microsoft engineers do not have default access to your data in the cloud. Instead, they are granted access,
under management oversight, only when necessary. That access is carefully controlled and logged, and
revoked when it is no longer needed.
Microsoft may hire other companies to provide limited services on its behalf. Subcontractors may access
customer data only to deliver the services for which, we have hired them to provide, and they are prohibited
from using it for any other purpose. Further, they are contractually bound to maintain the confidentiality of
our customers’ information.
Business services with audited certifications such as ISO/IEC 27001 are regularly verified by Microsoft and
accredited audit firms, which perform sample audits to attest that access, only for legitimate business purposes.
You can always access your own customer data at any time and for any reason.
If you delete any data, Microsoft Azure deletes the data, including any cached or backup copies. For in-scope
services, that deletion will occur within 90 days after the end of the retention period. (In-scope services are
defined in the Data Processing Terms section of our Online Services Terms.)
If a disk drive used for storage suffers a hardware failure, it is securely erased or destroyed before Microsoft
returns it to the manufacturer for replacement or repair. The data on the drive is overwritten to ensure that the
data cannot be recovered by any means.

Compute Isolation
Microsoft Azure provides various cloud-based computing services that include a wide selection of compute
instances & services that can scale up and down automatically to meet the needs of your application or
enterprise. These compute instance and service offer isolation at multiple levels to secure data without
sacrificing the flexibility in configuration that customers demand.
Isolated Virtual Machine Sizes
Azure Compute offers virtual machine sizes that are Isolated to a specific hardware type and dedicated to a
single customer. The Isolated sizes live and operate on specific hardware generation and will be deprecated
when the hardware generation is retired.
Isolated virtual machine sizes are best suited for workloads that require a high degree of isolation from other
customers’ workloads for reasons that include meeting compliance and regulatory requirements. Utilizing an
isolated size guarantees that your virtual machine will be the only one running on that specific server instance.
Additionally, as the Isolated size VMs are large, customers may choose to subdivide the resources of these VMs
by using Azure support for nested virtual machines.
The current Isolated virtual machine offerings include:
Standard_E80ids_v4
Standard_E80is_v4
Standard_E104i_v5
Standard_E104is_v5
Standard_E104id_v5
Standard_E104ids_v5
Standard_F72s_v2
Standard_M128ms
Standard_DC8_v2
NOTE
Isolated VM Sizes have a hardware limited lifespan. Please see below for details

Deprecation of Isolated VM Sizes


Isolated VM sizes have a hardware limited lifespan. Azure will issue reminders 12 months in advance of the
official deprecation date of the sizes and will provide an updated isolated offering for your consideration.

SIZ E ISO L AT IO N RET IREM EN T DAT E

Standard_DS15_v2 May 15, 2021

Standard_D15_v2 May 15, 2021

Standard_G5 February 15, 2022

Standard_GS5 February 15, 2022

Standard_E64i_v3 February 15, 2022

Standard_E64is_v3 February 15, 2022

Standard_DC8_v2 February 15, 2022

FAQ
Q: Is the size going to get retired or only its "isolation" feature?
A : Currently, only the isolation feature of the VM sizes is being retired. The deprecated isolated sizes will
continue to exist in non-isolated state. If isolation is not needed, there is no action to be taken and the VM will
continue to work as expected.
Q: Is there a downtime when my vm lands on a non-isolated hardware?
A : If there is no need of isolation, no action is needed and there will be no downtime. On contrary if isolation is
required, our announcement will include the recommended replacement size. Selecting the replacement size will
require our customers to resize their VMs.
Q: Is there any cost delta for moving to a non-isolated virtual machine?
A : No
Q: When are the other isolated sizes going to retire?
A : We will provide reminders 12 months in advance of the official deprecation of the isolated size. Our latest
announcement includes isolation feature retirement of Standard_G5, Standard_GS5, Standard_E64i_v3 and
Standard_E64i_v3.
Q: I'm an Azure Service Fabric Customer relying on the Silver or Gold Durability Tiers. Does this change
impact me?
A : No. The guarantees provided by Service Fabric's Durability Tiers will continue to function even after this
change. If you require physical hardware isolation for other reasons, you may still need to take one of the
actions described above.
Q: What are the milestones for D15_v2 or DS15_v2 isolation retirement?
A:

DAT E A C T IO N

May 15, 20201 D/DS15_v2 isolation retirement announcement

May 15, 2021 D/DS15_v2 isolation guarantee removed

1 Existing customer using these sizes will receive an announcement email with detailed instructions on the next
steps.
Q: What are the milestones for G5, Gs5, E64i_v3 and E64is_v3 isolation retirement?
A:

DAT E A C T IO N

Feb 15, 20211 G5/GS5/E64i_v3/E64is_v3 isolation retirement


announcement

Feb 28, 2022 G5/GS5/E64i_v3/E64is_v3 isolation guarantee removed

1 Existing customer using these sizes will receive an announcement email with detailed instructions on the next
steps.

Next steps
Customers can also choose to further subdivide the resources of these Isolated virtual machines by using Azure
support for nested virtual machines.
Dedicated hosts
In addition to the isolated hosts described in the preceding section, Azure also offers dedicated hosts. Dedicated
hosts in Azure is a service that provides physical servers that can host one or more virtual machines, and which
are dedicated to a single Azure subscription. Dedicated hosts provide hardware isolation at the physical server
level. No other VMs will be placed on your hosts. Dedicated hosts are deployed in the same datacenters and
share the same network and underlying storage infrastructure as other, non-isolated hosts. For more
information, see the detailed overview of Azure dedicated hosts.
Hyper-V & Root OS Isolation Between Root VM & Guest VMs
Azure’s compute platform is based on machine virtualization—meaning that all customer code executes in a
Hyper-V virtual machine. On each Azure node (or network endpoint), there is a Hypervisor that runs directly
over the hardware and divides a node into a variable number of Guest Virtual Machines (VMs).
Each node also has one special Root VM, which runs the Host OS. A critical boundary is the isolation of the root
VM from the guest VMs and the guest VMs from one another, managed by the hypervisor and the root OS. The
hypervisor/root OS pairing leverages Microsoft's decades of operating system security experience, and more
recent learning from Microsoft's Hyper-V, to provide strong isolation of guest VMs.
The Azure platform uses a virtualized environment. User instances operate as standalone virtual machines that
do not have access to a physical host server.
The Azure hypervisor acts like a micro-kernel and passes all hardware access requests from guest virtual
machines to the host for processing by using a shared-memory interface called VM Bus. This prevents users
from obtaining raw read/write/execute access to the system and mitigates the risk of sharing system resources.
Advanced VM placement algorithm & protection from side channel attacks
Any cross-VM attack involves two steps: placing an adversary-controlled VM on the same host as one of the
victim VMs, and then breaching the isolation boundary to either steal sensitive victim information or affect its
performance for greed or vandalism. Microsoft Azure provides protection at both steps by using an advanced
VM placement algorithm and protection from all known side channel attacks including noisy neighbor VMs.
The Azure Fabric Controller
The Azure Fabric Controller is responsible for allocating infrastructure resources to tenant workloads, and it
manages unidirectional communications from the host to virtual machines. The VM placing algorithm of the
Azure fabric controller is highly sophisticated and nearly impossible to predict as physical host level.
The Azure hypervisor enforces memory and process separation between virtual machines, and it securely
routes network traffic to guest OS tenants. This eliminates possibility of and side channel attack at VM level.
In Azure, the root VM is special: it runs a hardened operating system called the root OS that hosts a fabric agent
(FA). FAs are used in turn to manage guest agents (GA) within guest operating systems on customer VMs. FAs
also manage storage nodes.
The collection of Azure hypervisor, root OS/FA, and customer VMs/GAs comprises a compute node. FAs are
managed by a fabric controller (FC), which exists outside of compute and storage nodes (compute and storage
clusters are managed by separate FCs). If a customer updates their application’s configuration file while it’s
running, the FC communicates with the FA, which then contacts GAs, which notify the application of the
configuration change. In the event of a hardware failure, the FC will automatically find available hardware and
restart the VM there.

Communication from a Fabric Controller to an agent is unidirectional. The agent implements an SSL-protected
service that only responds to requests from the controller. It cannot initiate connections to the controller or
other privileged internal nodes. The FC treats all responses as if they were untrusted.
Isolation extends from the Root VM from Guest VMs, and the Guest VMs from one another. Compute nodes are
also isolated from storage nodes for increased protection.
The hypervisor and the host OS provide network packet - filters to help assure that untrusted virtual machines
cannot generate spoofed traffic or receive traffic not addressed to them, direct traffic to protected infrastructure
endpoints, or send/receive inappropriate broadcast traffic.
Additional Rules Configured by Fabric Controller Agent to Isolate VM
By default, all traffic is blocked when a virtual machine is created, and then the fabric controller agent configures
the packet filter to add rules and exceptions to allow authorized traffic.
There are two categories of rules that are programmed:
Machine configuration or infrastructure rules: By default, all communication is blocked. There are
exceptions to allow a virtual machine to send and receive DHCP and DNS traffic. Virtual machines can also
send traffic to the “public” internet and send traffic to other virtual machines within the same Azure Virtual
Network and the OS activation server. The virtual machines’ list of allowed outgoing destinations does not
include Azure router subnets, Azure management, and other Microsoft properties.
Role configuration file: This defines the inbound Access Control Lists (ACLs) based on the tenant's service
model.
VLAN Isolation
There are three VLANs in each cluster:
The main VLAN – interconnects untrusted customer nodes
The FC VLAN – contains trusted FCs and supporting systems
The device VLAN – contains trusted network and other infrastructure devices
Communication is permitted from the FC VLAN to the main VLAN, but cannot be initiated from the main VLAN
to the FC VLAN. Communication is also blocked from the main VLAN to the device VLAN. This assures that even
if a node running customer code is compromised, it cannot attack nodes on either the FC or device VLANs.

Storage Isolation
Logical Isolation Between Compute and Storage
As part of its fundamental design, Microsoft Azure separates VM-based computation from storage. This
separation enables computation and storage to scale independently, making it easier to provide multi-tenancy
and isolation.
Therefore, Azure Storage runs on separate hardware with no network connectivity to Azure Compute except
logically. This means that when a virtual disk is created, disk space is not allocated for its entire capacity. Instead,
a table is created that maps addresses on the virtual disk to areas on the physical disk and that table is initially
empty. The first time a customer writes data on the vir tual disk , space on the physical disk is
allocated, and a pointer to it is placed in the table.
Isolation Using Storage Access control
Access Control in Azure Storage has a simple access control model. Each Azure subscription can create one
or more Storage Accounts. Each Storage Account has a single secret key that is used to control access to all data
in that Storage Account.
Access to Azure Storage data (including Tables) can be controlled through a SAS (Shared Access
Signature) token, which grants scoped access. The SAS is created through a query template (URL), signed with
the SAK (Storage Account Key). That signed URL can be given to another process (that is, delegated), which can
then fill in the details of the query and make the request of the storage service. A SAS enables you to grant
time-based access to clients without revealing the storage account’s secret key.
The SAS means that we can grant a client limited permissions, to objects in our storage account for a specified
period of time and with a specified set of permissions. We can grant these limited permissions without having to
share your account access keys.
IP Level Storage Isolation
You can establish firewalls and define an IP address range for your trusted clients. With an IP address range, only
clients that have an IP address within the defined range can connect to Azure Storage.
IP storage data can be protected from unauthorized users via a networking mechanism that is used to allocate a
dedicated or dedicated tunnel of traffic to IP storage.
Encryption
Azure offers the following types of Encryption to protect data:
Encryption in transit
Encryption at rest
Encryption in Transit
Encryption in transit is a mechanism of protecting data when it is transmitted across networks. With Azure
Storage, you can secure data using:
Transport-level encryption, such as HTTPS when you transfer data into or out of Azure Storage.
Wire encryption, such as SMB 3.0 encryption for Azure File shares.
Client-side encryption, to encrypt the data before it is transferred into storage and to decrypt the data after it
is transferred out of storage.
Encryption at Rest
For many organizations, data encryption at rest is a mandatory step towards data privacy, compliance, and data
sovereignty. There are three Azure features that provide encryption of data that is “at rest”:
Storage Service Encryption allows you to request that the storage service automatically encrypt data when
writing it to Azure Storage.
Client-side Encryption also provides the feature of encryption at rest.
Azure Disk Encryption allows you to encrypt the OS disks and data disks used by an IaaS virtual machine.
Azure Disk Encryption
Azure Disk Encryption for virtual machines (VMs) helps you address organizational security and compliance
requirements by encrypting your VM disks (including boot and data disks) with keys and policies you control in
Azure Key Vault.
The Disk Encryption solution for Windows is based on Microsoft BitLocker Drive Encryption, and the Linux
solution is based on dm-crypt.
The solution supports the following scenarios for IaaS VMs when they are enabled in Microsoft Azure:
Integration with Azure Key Vault
Standard tier VMs: A, D, DS, G, GS, and so forth, series IaaS VMs
Enabling encryption on Windows and Linux IaaS VMs
Disabling encryption on OS and data drives for Windows IaaS VMs
Disabling encryption on data drives for Linux IaaS VMs
Enabling encryption on IaaS VMs that are running Windows client OS
Enabling encryption on volumes with mount paths
Enabling encryption on Linux VMs that are configured with disk striping (RAID) by using mdadm
Enabling encryption on Linux VMs by using LVM(Logical Volume Manager) for data disks
Enabling encryption on Windows VMs that are configured by using storage spaces
All Azure public regions are supported
The solution does not support the following scenarios, features, and technology in the release:
Basic tier IaaS VMs
Disabling encryption on an OS drive for Linux IaaS VMs
IaaS VMs that are created by using the classic VM creation method
Integration with your on-premises Key Management Service
Azure Files (shared file system), Network File System (NFS), dynamic volumes, and Windows VMs that are
configured with software-based RAID systems

SQL Database Isolation


SQL Database is a relational database service in the Microsoft cloud based on the market-leading Microsoft SQL
Server engine and capable of handling mission-critical workloads. SQL Database offers predictable data
isolation at account level, geography / region based and based on networking— all with near-zero
administration.
SQL Database Application Model
Microsoft SQL Database is a cloud-based relational database service built on SQL Server technologies. It
provides a highly available, scalable, multi-tenant database service hosted by Microsoft in cloud.
From an application perspective, SQL Database provides the following hierarchy: Each level has one-to-many
containment of levels below.
The account and subscription are Microsoft Azure platform concepts to associate billing and management.
Logical SQL servers and databases are SQL Database-specific concepts and are managed by using SQL
Database, provided OData and TSQL interfaces or via the Azure portal.
Servers in SQL Database are not physical or VM instances, instead they are collections of databases, sharing
management and security policies, which are stored in so called “logical master” database.

Logical master databases include:


SQL logins used to connect to the server
Firewall rules
Billing and usage-related information for databases from the same server are not guaranteed to be on the same
physical instance in the cluster, instead applications must provide the target database name when connecting.
From a customer perspective, a server is created in a geo-graphical region while the actual creation of the
server happens in one of the clusters in the region.
Isolation through Network Topology
When a server is created and its DNS name is registered, the DNS name points to the so called “Gateway VIP”
address in the specific data center where the server was placed.
Behind the VIP (virtual IP address), we have a collection of stateless gateway services. In general, gateways get
involved when there is coordination needed between multiple data sources (master database, user database,
etc.). Gateway services implement the following:
TDS connection proxying. This includes locating user database in the backend cluster, implementing the
login sequence and then forwarding the TDS packets to the backend and back.
Database management. This includes implementing a collection of workflows to do CREATE/ALTER/DROP
database operations. The database operations can be invoked by either sniffing TDS packets or explicit OData
APIs.
CREATE/ALTER/DROP login/user operations
Server management operations via OData API

The tier behind the gateways is called “back-end”. This is where all the data is stored in a highly available fashion.
Each piece of data is said to belong to a “partition” or “failover unit”, each of them having at least three replicas.
Replicas are stored and replicated by SQL Server engine and managed by a failover system often referred to as
“fabric”.
Generally, the back-end system does not communicate outbound to other systems as a security precaution. This
is reserved to the systems in the front-end (gateway) tier. The gateway tier machines have limited privileges on
the back-end machines to minimize the attack surface as a defense-in-depth mechanism.
Isolation by Machine Function and Access
SQL Database (is composed of services running on different machine functions. SQL Database is divided into
“backend” Cloud Database and “front-end” (Gateway/Management) environments, with the general principle of
traffic only going into back-end and not out. The front-end environment can communicate to the outside world
of other services and in general, has only limited permissions in the back-end (enough to call the entry points it
needs to invoke).

Networking Isolation
Azure deployment has multiple layers of network isolation. The following diagram shows various layers of
network isolation Azure provides to customers. These layers are both native in the Azure platform itself and
customer-defined features. Inbound from the Internet, Azure DDoS provides isolation against large-scale attacks
against Azure. The next layer of isolation is customer-defined public IP addresses (endpoints), which are used to
determine which traffic can pass through the cloud service to the virtual network. Native Azure virtual network
isolation ensures complete isolation from all other networks, and that traffic only flows through user configured
paths and methods. These paths and methods are the next layer, where NSGs, UDR, and network virtual
appliances can be used to create isolation boundaries to protect the application deployments in the protected
network.

Traffic isolation: A virtual network is the traffic isolation boundary on the Azure platform. Virtual machines
(VMs) in one virtual network cannot communicate directly to VMs in a different virtual network, even if both
virtual networks are created by the same customer. Isolation is a critical property that ensures customer VMs
and communication remains private within a virtual network.
Subnet offers an additional layer of isolation with in virtual network based on IP range. IP addresses in the
virtual network, you can divide a virtual network into multiple subnets for organization and security. VMs and
PaaS role instances deployed to subnets (same or different) within a VNet can communicate with each other
without any extra configuration. You can also configure network security group (NSGs) to allow or deny network
traffic to a VM instance based on rules configured in access control list (ACL) of NSG. NSGs can be associated
with either subnets or individual VM instances within that subnet. When an NSG is associated with a subnet, the
ACL rules apply to all the VM instances in that subnet.

Next Steps
Learn about Network Isolation Options for Machines in Windows Azure Virtual Networks. This includes
the classic front-end and back-end scenario where machines in a particular back-end network or
subnetwork may only allow certain clients or other computers to connect to a particular endpoint based
on an allowlist of IP addresses.
Learn about virtual machine isolation in Azure. Azure Compute offers virtual machine sizes that are
isolated to a specific hardware type and dedicated to a single customer.
Azure identity management security overview
12/12/2021 • 8 minutes to read • Edit Online

Identity management is the process of authenticating and authorizing security principals. It also involves
controlling information about those principals (identities). Security principals (identities) may include services,
applications, users, groups, etc. Microsoft identity and access management solutions help IT protect access to
applications and resources across the corporate datacenter and into the cloud. Such protection enables
additional levels of validation, such as Multi-Factor Authentication and Conditional Access policies. Monitoring
suspicious activity through advanced security reporting, auditing, and alerting helps mitigate potential security
issues. Azure Active Directory Premium provides single sign-on (SSO) to thousands of cloud software as a
service (SaaS) apps and access to web apps that you run on-premises.
By taking advantage of the security benefits of Azure Active Directory (Azure AD), you can:
Create and manage a single identity for each user across your hybrid enterprise, keeping users, groups, and
devices in sync.
Provide SSO access to your applications, including thousands of pre-integrated SaaS apps.
Enable application access security by enforcing rules-based Multi-Factor Authentication for both on-premises
and cloud applications.
Provision secure remote access to on-premises web applications through Azure AD Application Proxy.
The goal of this article is to provide an overview of the core Azure security features that help with identity
management. We also provide links to articles that give details of each feature so you can learn more.
The article focuses on the following core Azure Identity management capabilities:
Single sign-on
Reverse proxy
Multi-Factor Authentication
Azure role-based access control (Azure RBAC)
Security monitoring, alerts, and machine learning-based reports
Consumer identity and access management
Device registration
Privileged identity management
Identity protection
Hybrid identity management/Azure AD connect
Azure AD access reviews

Single sign-on
SSO means being able to access all the applications and resources that you need to do business, by signing in
only once using a single user account. Once signed in, you can access all of the applications you need without
being required to authenticate (for example, type a password) a second time.
Many organizations rely upon SaaS applications such as Microsoft 365, Box, and Salesforce for user productivity.
Historically, IT staff needed to individually create and update user accounts in each SaaS application, and users
had to remember a password for each SaaS application.
Azure AD extends on-premises Active Directory environments into the cloud, enabling users to use their
primary organizational account to sign in not only to their domain-joined devices and company resources, but
also to all the web and SaaS applications they need for their jobs.
Not only do users not have to manage multiple sets of usernames and passwords, you can provision or de-
provision application access automatically, based on their organizational groups and their employee status.
Azure AD introduces security and access governance controls with which you can centrally manage users'
access across SaaS applications.
Learn more:
Overview on SSO
Video on authentication fundamentals
Quickstart series on application management

Reverse proxy
Azure AD Application Proxy lets you publish on-premises applications, such as SharePoint sites, Outlook Web
App, and IIS-based apps inside your private network and provides secure access to users outside your network.
Application Proxy provides remote access and SSO for many types of on-premises web applications with the
thousands of SaaS applications that Azure AD supports. Employees can sign in to your apps from home on their
own devices and authenticate through this cloud-based proxy.
Learn more:
Enabling Azure AD Application Proxy
Publish applications using Azure AD Application Proxy
Single sign-on with Application Proxy
Working with Conditional Access

Multi-Factor Authentication
Azure AD Multi-Factor Authentication is a method of authentication that requires the use of more than one
verification method and adds a critical second layer of security to user sign-ins and transactions. Multi-Factor
Authentication helps safeguard access to data and applications while meeting user demand for a simple sign-in
process. It delivers strong authentication via a range of verification options: phone calls, text messages, or
mobile app notifications or verification codes and third-party OAuth tokens.
Learn more:
Multi-Factor Authentication
What is Azure AD Multi-Factor Authentication?
How Azure AD Multi-Factor Authentication works

Azure RBAC
Azure RBAC is an authorization system built on Azure Resource Manager that provides fine-grained access
management of resources in Azure. Azure RBAC allows you to granularly control the level of access that users
have. For example, you can limit a user to only manage virtual networks and another user to manage all
resources in a resource group. Azure includes several built-in roles that you can use. The following lists four
fundamental built-in roles. The first three apply to all resource types.
Owner - Has full access to all resources including the right to delegate access to others.
Contributor - Can create and manage all types of Azure resources but can't grant access to others.
Reader - Can view existing Azure resources.
User Access Administrator - Lets you manage user access to Azure resources.
Learn more:
What is Azure role-based access control (Azure RBAC)?
Azure built-in roles

Security monitoring, alerts, and machine learning-based reports


Security monitoring, alerts, and machine learning-based reports that identify inconsistent access patterns can
help you protect your business. You can use Azure AD access and usage reports to gain visibility into the
integrity and security of your organization’s directory. With this information, a directory administrator can better
determine where possible security risks might lie so that they can adequately plan to mitigate those risks.
In the Azure portal, reports fall into the following categories:
Anomaly repor ts : Contain sign-in events that we found to be anomalous. Our goal is to make you aware of
such activity and enable you to determine whether an event is suspicious.
Integrated Application repor ts : Provide insights into how cloud applications are being used in your
organization. Azure AD offers integration with thousands of cloud applications.
Error repor ts : Indicate errors that might occur when you provision accounts to external applications.
User-specific repor ts : Display device sign-in activity data for a specific user.
Activity logs : Contain a record of all audited events within the last 24 hours, last 7 days, or last 30 days, and
group activity changes and password reset and registration activity.
Learn more:
View your access and usage reports
Get started with Azure Active Directory reporting
Azure Active Directory reporting guide

Consumer identity and access management


Azure AD B2C is a highly available, global, identity management service for consumer-facing applications that
scales to hundreds of millions of identities. It can be integrated across mobile and web platforms. Your
consumers can sign in to all your applications through customizable experiences by using their existing social
accounts or by creating new credentials.
In the past, application developers who wanted to sign up customers and sign them in to their applications
would have written their own code. And they would have used on-premises databases or systems to store
usernames and passwords. Azure AD B2C offers your organization a better way to integrate consumer identity
management into applications with the help of a secure, standards-based platform and a large set of extensible
policies.
When you use Azure AD B2C, your consumers can sign up for your applications by using their existing social
accounts (Facebook, Google, Amazon, LinkedIn) or by creating new credentials (email address and password, or
username and password).
Learn more:
What is Azure Active Directory B2C?
Azure Active Directory B2C preview: Sign up and sign in consumers in your applications
Azure Active Directory B2C Preview: Types of applications

Device registration
Azure AD device registration is the foundation for device-based Conditional Access scenarios. When a device is
registered, Azure AD device registration provides the device with an identity that it uses to authenticate the
device when a user signs in. The authenticated device and the attributes of the device can then be used to
enforce Conditional Access policies for applications that are hosted in the cloud and on-premises.
When combined with a mobile device management solution such as Intune, the device attributes in Azure AD
are updated with additional information about the device. You can then create Conditional Access rules that
enforce access from devices to meet your standards for security and compliance.
Learn more:
Get started with Azure AD device registration
Automatic device registration with Azure AD for Windows domain-joined devices
Set up automatic registration of Windows domain-joined devices with Azure AD

Privileged identity management


With Azure AD Privileged Identity Management, you can manage, control, and monitor your privileged identities
and access to resources in Azure AD as well as other Microsoft online services, such as Microsoft 365 and
Microsoft Intune.
Users sometimes need to carry out privileged operations in Azure or Microsoft 365 resources, or in other SaaS
apps. This need often means that organizations have to give users permanent privileged access in Azure AD.
Such access is a growing security risk for cloud-hosted resources, because organizations can't sufficiently
monitor what the users are doing with their administrator privileges. Additionally, if a user account with
privileged access is compromised, that one breach could affect the organization's overall cloud security. Azure
AD Privileged Identity Management helps to mitigate this risk.
With Azure AD Privileged Identity Management, you can:
See which users are Azure AD administrators.
Enable on-demand, just-in-time (JIT) administrative access to Microsoft services such as Microsoft 365 and
Intune.
Get reports about administrator access history and changes in administrator assignments.
Get alerts about access to a privileged role.
Learn more:
What is Azure AD Privileged Identity Management?
Assign Azure AD directory roles in PIM

Identity protection
Azure AD Identity Protection is a security service that provides a consolidated view into risk detections and
potential vulnerabilities that affect your organization’s identities. Identity Protection takes advantage of existing
Azure AD anomaly-detection capabilities, which are available through Azure AD Anomalous Activity reports.
Identity Protection also introduces new risk detection types that can detect anomalies in real time.
Learn more:
Azure AD Identity Protection
Channel 9: Azure AD and Identity Show: Identity Protection Preview

Hybrid identity management/Azure AD connect


Microsoft’s identity solutions span on-premises and cloud-based capabilities, creating a single user identity for
authentication and authorization to all resources, regardless of location. We call this hybrid identity. Azure AD
Connect is the Microsoft tool designed to meet and accomplish your hybrid identity goals. This allows you to
provide a common identity for your users for Microsoft 365, Azure, and SaaS applications integrated with Azure
AD. It provides the following features:
Synchronization
AD FS and federation integration
Pass through authentication
Health Monitoring
Learn more:
Hybrid identity white paper
Azure Active Directory
Azure AD team blog

Azure AD access reviews


Azure Active Directory (Azure AD) access reviews enable organizations to efficiently manage group
memberships, access to enterprise applications, and privileged role assignments.
Learn more:
Azure AD access reviews
Manage user access with Azure AD access reviews
Azure Identity Management and access control
security best practices
12/12/2021 • 22 minutes to read • Edit Online

In this article, we discuss a collection of Azure identity management and access control security best practices.
These best practices are derived from our experience with Azure AD and the experiences of customers like
yourself.
For each best practice, we explain:
What the best practice is
Why you want to enable that best practice
What might be the result if you fail to enable the best practice
Possible alternatives to the best practice
How you can learn to enable the best practice
This Azure identity management and access control security best practices article is based on a consensus
opinion and Azure platform capabilities and feature sets, as they exist at the time this article was written.
The intention in writing this article is to provide a general roadmap to a more robust security posture after
deployment guided by our “5 steps to securing your identity infrastructure” checklist, which walks you through
some of our core features and services.
Opinions and technologies change over time and this article will be updated on a regular basis to reflect those
changes.
Azure identity management and access control security best practices discussed in this article include:
Treat identity as the primary security perimeter
Centralize identity management
Manage connected tenants
Enable single sign-on
Turn on Conditional Access
Plan for routine security improvements
Enable password management
Enforce multi-factor verification for users
Use role-based access control
Lower exposure of privileged accounts
Control locations where resources are located
Use Azure AD for storage authentication

Treat identity as the primary security perimeter


Many consider identity to be the primary perimeter for security. This is a shift from the traditional focus on
network security. Network perimeters keep getting more porous, and that perimeter defense can’t be as
effective as it was before the explosion of BYOD devices and cloud applications.
Azure Active Directory (Azure AD) is the Azure solution for identity and access management. Azure AD is a
multitenant, cloud-based directory and identity management service from Microsoft. It combines core directory
services, application access management, and identity protection into a single solution.
The following sections list best practices for identity and access security using Azure AD.
Best practice : Center security controls and detections around user and service identities. Detail : Use Azure AD
to collocate controls and identities.

Centralize identity management


In a hybrid identity scenario we recommend that you integrate your on-premises and cloud directories.
Integration enables your IT team to manage accounts from one location, regardless of where an account is
created. Integration also helps your users be more productive by providing a common identity for accessing
both cloud and on-premises resources.
Best practice : Establish a single Azure AD instance. Consistency and a single authoritative sources will increase
clarity and reduce security risks from human errors and configuration complexity. Detail : Designate a single
Azure AD directory as the authoritative source for corporate and organizational accounts.
Best practice : Integrate your on-premises directories with Azure AD.
Detail : Use Azure AD Connect to synchronize your on-premises directory with your cloud directory.

NOTE
There are factors that affect the performance of Azure AD Connect. Ensure Azure AD Connect has enough capacity to
keep underperforming systems from impeding security and productivity. Large or complex organizations (organizations
provisioning more than 100,000 objects) should follow the recommendations to optimize their Azure AD Connect
implementation.

Best practice : Don’t synchronize accounts to Azure AD that have high privileges in your existing Active
Directory instance. Detail : Don’t change the default Azure AD Connect configuration that filters out these
accounts. This configuration mitigates the risk of adversaries pivoting from cloud to on-premises assets (which
could create a major incident).
Best practice : Turn on password hash synchronization.
Detail : Password hash synchronization is a feature used to synch user password hashes from an on-premises
Active Directory instance to a cloud-based Azure AD instance. This sync helps to protect against leaked
credentials being replayed from previous attacks.
Even if you decide to use federation with Active Directory Federation Services (AD FS) or other identity
providers, you can optionally set up password hash synchronization as a backup in case your on-premises
servers fail or become temporarily unavailable. This sync enables users to sign in to the service by using the
same password that they use to sign in to their on-premises Active Directory instance. It also allows Identity
Protection to detect compromised credentials by comparing synchronized password hashes with passwords
known to be compromised, if a user has used the same email address and password on other services that
aren't connected to Azure AD.
For more information, see Implement password hash synchronization with Azure AD Connect sync.
Best practice : For new application development, use Azure AD for authentication. Detail : Use the correct
capabilities to support authentication:
Azure AD for employees
Azure AD B2B for guest users and external partners
Azure AD B2C to control how customers sign up, sign in, and manage their profiles when they use your
applications
Organizations that don’t integrate their on-premises identity with their cloud identity can have more overhead
in managing accounts. This overhead increases the likelihood of mistakes and security breaches.

NOTE
You need to choose which directories critical accounts will reside in and whether the admin workstation used is managed
by new cloud services or existing processes. Using existing management and identity provisioning processes can decrease
some risks but can also create the risk of an attacker compromising an on-premises account and pivoting to the cloud.
You might want to use a different strategy for different roles (for example, IT admins vs. business unit admins). You have
two options. First option is to create Azure AD Accounts that aren’t synchronized with your on-premises Active Directory
instance. Join your admin workstation to Azure AD, which you can manage and patch by using Microsoft Intune. Second
option is to use existing admin accounts by synchronizing to your on-premises Active Directory instance. Use existing
workstations in your Active Directory domain for management and security.

Manage connected tenants


Your security organization needs visibility to assess risk and to determine whether the policies of your
organization, and any regulatory requirements, are being followed. You should ensure that your security
organization has visibility into all subscriptions connected to your production environment and network (via
Azure ExpressRoute or site-to-site VPN). A Global Administrator in Azure AD can elevate their access to the User
Access Administrator role and see all subscriptions and managed groups connected to your environment.
See elevate access to manage all Azure subscriptions and management groups to ensure that you and your
security group can view all subscriptions or management groups connected to your environment. You should
remove this elevated access after you’ve assessed risks.

Enable single sign-on


In a mobile-first, cloud-first world, you want to enable single sign-on (SSO) to devices, apps, and services from
anywhere so your users can be productive wherever and whenever. When you have multiple identity solutions
to manage, this becomes an administrative problem not only for IT but also for users who have to remember
multiple passwords.
By using the same identity solution for all your apps and resources, you can achieve SSO. And your users can
use the same set of credentials to sign in and access the resources that they need, whether the resources are
located on-premises or in the cloud.
Best practice : Enable SSO.
Detail : Azure AD extends on-premises Active Directory to the cloud. Users can use their primary work or school
account for their domain-joined devices, company resources, and all of the web and SaaS applications that they
need to get their jobs done. Users don’t have to remember multiple sets of usernames and passwords, and their
application access can be automatically provisioned (or deprovisioned) based on their organization group
memberships and their status as an employee. And you can control that access for gallery apps or for your own
on-premises apps that you’ve developed and published through the Azure AD Application Proxy.
Use SSO to enable users to access their SaaS applications based on their work or school account in Azure AD.
This is applicable not only for Microsoft SaaS apps, but also other apps, such as Google Apps and Salesforce. You
can configure your application to use Azure AD as a SAML-based identity provider. As a security control, Azure
AD does not issue a token that allows users to sign in to the application unless they have been granted access
through Azure AD. You can grant access directly, or through a group that users are a member of.
Organizations that don’t create a common identity to establish SSO for their users and applications are more
exposed to scenarios where users have multiple passwords. These scenarios increase the likelihood of users
reusing passwords or using weak passwords.
Turn on Conditional Access
Users can access your organization's resources by using a variety of devices and apps from anywhere. As an IT
admin, you want to make sure that these devices meet your standards for security and compliance. Just focusing
on who can access a resource is not sufficient anymore.
To balance security and productivity, you need to think about how a resource is accessed before you can make a
decision about access control. With Azure AD Conditional Access, you can address this requirement. With
Conditional Access, you can make automated access control decisions based on conditions for accessing your
cloud apps.
Best practice : Manage and control access to corporate resources.
Detail : Configure common Azure AD Conditional Access policies based on a group, location, and application
sensitivity for SaaS apps and Azure AD–connected apps.
Best practice : Block legacy authentication protocols. Detail : Attackers exploit weaknesses in older protocols
every day, particularly for password spray attacks. Configure Conditional Access to block legacy protocols.

Plan for routine security improvements


Security is always evolving, and it is important to build into your cloud and identity management framework a
way to regularly show growth and discover new ways to secure your environment.
Identity Secure Score is a set of recommended security controls that Microsoft publishes that works to provide
you a numerical score to objectively measure your security posture and help plan future security improvements.
You can also view your score in comparison to those in other industries as well as your own trends over time.
Best practice : Plan routine security reviews and improvements based on best practices in your industry.
Detail : Use the Identity Secure Score feature to rank your improvements over time.

Enable password management


If you have multiple tenants or you want to enable users to reset their own passwords, it’s important that you
use appropriate security policies to prevent abuse.
Best practice : Set up self-service password reset (SSPR) for your users.
Detail : Use the Azure AD self-service password reset feature.
Best practice : Monitor how or if SSPR is really being used.
Detail : Monitor the users who are registering by using the Azure AD Password Reset Registration Activity
report. The reporting feature that Azure AD provides helps you answer questions by using prebuilt reports. If
you're appropriately licensed, you can also create custom queries.
Best practice : Extend cloud-based password policies to your on-premises infrastructure. Detail : Enhance
password policies in your organization by performing the same checks for on-premises password changes as
you do for cloud-based password changes. Install Azure AD password protection for Windows Server Active
Directory agents on-premises to extend banned password lists to your existing infrastructure. Users and admins
who change, set, or reset passwords on-premises are required to comply with the same password policy as
cloud-only users.

Enforce multi-factor verification for users


We recommend that you require two-step verification for all of your users. This includes administrators and
others in your organization who can have a significant impact if their account is compromised (for example,
financial officers).
There are multiple options for requiring two-step verification. The best option for you depends on your goals,
the Azure AD edition you’re running, and your licensing program. See How to require two-step verification for a
user to determine the best option for you. See the Azure AD and Azure AD Multi-Factor Authentication pricing
pages for more information about licenses and pricing.
Following are options and benefits for enabling two-step verification:
Option 1 : Enable MFA for all users and login methods with Azure AD Security Defaults Benefit : This option
enables you to easily and quickly enforce MFA for all users in your environment with a stringent policy to:
Challenge administrative accounts and administrative logon mechanisms
Require MFA challenge via Microsoft Authenticator for all users
Restrict legacy authentication protocols.
This method is available to all licensing tiers but is not able to be mixed with existing Conditional Access policies.
You can find more information in Azure AD Security Defaults
Option 2 : Enable Multi-Factor Authentication by changing user state.
Benefit : This is the traditional method for requiring two-step verification. It works with both Azure AD Multi-
Factor Authentication in the cloud and Azure Multi-Factor Authentication Server. Using this method requires
users to perform two-step verification every time they sign in and overrides Conditional Access policies.
To determine where Multi-Factor Authentication needs to be enabled, see Which version of Azure AD MFA is
right for my organization?.
Option 3 : Enable Multi-Factor Authentication with Conditional Access policy. Benefit : This option allows you to
prompt for two-step verification under specific conditions by using Conditional Access. Specific conditions can
be user sign-in from different locations, untrusted devices, or applications that you consider risky. Defining
specific conditions where you require two-step verification enables you to avoid constant prompting for your
users, which can be an unpleasant user experience.
This is the most flexible way to enable two-step verification for your users. Enabling a Conditional Access policy
works only for Azure AD Multi-Factor Authentication in the cloud and is a premium feature of Azure AD. You can
find more information on this method in Deploy cloud-based Azure AD Multi-Factor Authentication.
Option 4 : Enable Multi-Factor Authentication with Conditional Access policies by evaluating Risk-based
Conditional Access policies.
Benefit : This option enables you to:
Detect potential vulnerabilities that affect your organization’s identities.
Configure automated responses to detected suspicious actions that are related to your organization’s
identities.
Investigate suspicious incidents and take appropriate action to resolve them.
This method uses the Azure AD Identity Protection risk evaluation to determine if two-step verification is
required based on user and sign-in risk for all cloud applications. This method requires Azure Active Directory
P2 licensing. You can find more information on this method in Azure Active Directory Identity Protection.

NOTE
Option 2, enabling Multi-Factor Authentication by changing the user state, overrides Conditional Access policies. Because
options 3 and 4 use Conditional Access policies, you cannot use option 2 with them.

Organizations that don’t add extra layers of identity protection, such as two-step verification, are more
susceptible for credential theft attack. A credential theft attack can lead to data compromise.

Use role-based access control


Access management for cloud resources is critical for any organization that uses the cloud. Azure role-based
access control (Azure RBAC) helps you manage who has access to Azure resources, what they can do with those
resources, and what areas they have access to.
Designating groups or individual roles responsible for specific functions in Azure helps avoid confusion that can
lead to human and automation errors that create security risks. Restricting access based on the need to know
and least privilege security principles is imperative for organizations that want to enforce security policies for
data access.
Your security team needs visibility into your Azure resources in order to assess and remediate risk. If the security
team has operational responsibilities, they need additional permissions to do their jobs.
You can use Azure RBAC to assign permissions to users, groups, and applications at a certain scope. The scope
of a role assignment can be a subscription, a resource group, or a single resource.
Best practice : Segregate duties within your team and grant only the amount of access to users that they need
to perform their jobs. Instead of giving everybody unrestricted permissions in your Azure subscription or
resources, allow only certain actions at a particular scope. Detail : Use Azure built-in roles in Azure to assign
privileges to users.

NOTE
Specific permissions create unneeded complexity and confusion, accumulating into a “legacy” configuration that’s difficult
to fix without fear of breaking something. Avoid resource-specific permissions. Instead, use management groups for
enterprise-wide permissions and resource groups for permissions within subscriptions. Avoid user-specific permissions.
Instead, assign access to groups in Azure AD.

Best practice : Grant security teams with Azure responsibilities access to see Azure resources so they can assess
and remediate risk. Detail : Grant security teams the Azure RBAC Security Reader role. You can use the root
management group or the segment management group, depending on the scope of responsibilities:
Root management group for teams responsible for all enterprise resources
Segment management group for teams with limited scope (commonly because of regulatory or other
organizational boundaries)
Best practice : Grant the appropriate permissions to security teams that have direct operational responsibilities.
Detail : Review the Azure built-in roles for the appropriate role assignment. If the built-in roles don't meet the
specific needs of your organization, you can create Azure custom roles. As with built-in roles, you can assign
custom roles to users, groups, and service principals at subscription, resource group, and resource scopes.
Best practices : Grant Microsoft Defender for Cloud access to security roles that need it. Defender for Cloud
allows security teams to quickly identify and remediate risks. Detail : Add security teams with these needs to the
Azure RBAC Security Admin role so they can view security policies, view security states, edit security policies,
view alerts and recommendations, and dismiss alerts and recommendations. You can do this by using the root
management group or the segment management group, depending on the scope of responsibilities.
Organizations that don’t enforce data access control by using capabilities like Azure RBAC might be giving more
privileges than necessary to their users. This can lead to data compromise by allowing users to access types of
data (for example, high business impact) that they shouldn’t have.

Lower exposure of privileged accounts


Securing privileged access is a critical first step to protecting business assets. Minimizing the number of people
who have access to secure information or resources reduces the chance of a malicious user getting access, or an
authorized user inadvertently affecting a sensitive resource.
Privileged accounts are accounts that administer and manage IT systems. Cyber attackers target these accounts
to gain access to an organization’s data and systems. To secure privileged access, you should isolate the
accounts and systems from the risk of being exposed to a malicious user.
We recommend that you develop and follow a roadmap to secure privileged access against cyber attackers. For
information about creating a detailed roadmap to secure identities and access that are managed or reported in
Azure AD, Microsoft Azure, Microsoft 365, and other cloud services, review Securing privileged access for hybrid
and cloud deployments in Azure AD.
The following summarizes the best practices found in Securing privileged access for hybrid and cloud
deployments in Azure AD:
Best practice : Manage, control, and monitor access to privileged accounts.
Detail : Turn on Azure AD Privileged Identity Management. After you turn on Privileged Identity Management,
you’ll receive notification email messages for privileged access role changes. These notifications provide early
warning when additional users are added to highly privileged roles in your directory.
Best practice : Ensure all critical admin accounts are managed Azure AD accounts. Detail : Remove any
consumer accounts from critical admin roles (for example, Microsoft accounts like hotmail.com, live.com, and
outlook.com).
Best practice : Ensure all critical admin roles have a separate account for administrative tasks in order to avoid
phishing and other attacks to compromise administrative privileges. Detail : Create a separate admin account
that’s assigned the privileges needed to perform the administrative tasks. Block the use of these administrative
accounts for daily productivity tools like Microsoft 365 email or arbitrary web browsing.
Best practice : Identify and categorize accounts that are in highly privileged roles.
Detail : After turning on Azure AD Privileged Identity Management, view the users who are in the global
administrator, privileged role administrator, and other highly privileged roles. Remove any accounts that are no
longer needed in those roles, and categorize the remaining accounts that are assigned to admin roles:
Individually assigned to administrative users, and can be used for non-administrative purposes (for example,
personal email)
Individually assigned to administrative users and designated for administrative purposes only
Shared across multiple users
For emergency access scenarios
For automated scripts
For external users
Best practice : Implement “just in time” (JIT) access to further lower the exposure time of privileges and
increase your visibility into the use of privileged accounts.
Detail : Azure AD Privileged Identity Management lets you:
Limit users to only taking on their privileges JIT.
Assign roles for a shortened duration with confidence that the privileges are revoked automatically.
Best practice : Define at least two emergency access accounts.
Detail : Emergency access accounts help organizations restrict privileged access in an existing Azure Active
Directory environment. These accounts are highly privileged and are not assigned to specific individuals.
Emergency access accounts are limited to scenarios where normal administrative accounts can’t be used.
Organizations must limit the emergency account's usage to only the necessary amount of time.
Evaluate the accounts that are assigned or eligible for the global admin role. If you don’t see any cloud-only
accounts by using the *.onmicrosoft.com domain (intended for emergency access), create them. For more
information, see Managing emergency access administrative accounts in Azure AD.
Best practice : Have a “break glass" process in place in case of an emergency. Detail : Follow the steps in
Securing privileged access for hybrid and cloud deployments in Azure AD.
Best practice : Require all critical admin accounts to be password-less (preferred), or require Multi-Factor
Authentication. Detail : Use the Microsoft Authenticator app to sign in to any Azure AD account without using a
password. Like Windows Hello for Business, the Microsoft Authenticator uses key-based authentication to
enable a user credential that’s tied to a device and uses biometric authentication or a PIN.
Require Azure AD Multi-Factor Authentication at sign-in for all individual users who are permanently assigned
to one or more of the Azure AD admin roles: Global Administrator, Privileged Role Administrator, Exchange
Online Administrator, and SharePoint Online Administrator. Enable Multi-Factor Authentication for your admin
accounts and ensure that admin account users have registered.
Best practice : For critical admin accounts, have an admin workstation where production tasks aren’t allowed
(for example, browsing and email). This will protect your admin accounts from attack vectors that use browsing
and email and significantly lower your risk of a major incident. Detail : Use an admin workstation. Choose a level
of workstation security:
Highly secure productivity devices provide advanced security for browsing and other productivity tasks.
Privileged Access Workstations (PAWs) provide a dedicated operating system that’s protected from internet
attacks and threat vectors for sensitive tasks.
Best practice : Deprovision admin accounts when employees leave your organization. Detail : Have a process in
place that disables or deletes admin accounts when employees leave your organization.
Best practice : Regularly test admin accounts by using current attack techniques. Detail : Use Microsoft 365
Attack Simulator or a third-party offering to run realistic attack scenarios in your organization. This can help you
find vulnerable users before a real attack occurs.
Best practice : Take steps to mitigate the most frequently used attacked techniques.
Detail : Identify Microsoft accounts in administrative roles that need to be switched to work or school accounts
Ensure separate user accounts and mail forwarding for global administrator accounts
Ensure that the passwords of administrative accounts have recently changed
Turn on password hash synchronization
Require Multi-Factor Authentication for users in all privileged roles as well as exposed users
Obtain your Microsoft 365 Secure Score (if using Microsoft 365)
Review the Microsoft 365 security guidance (if using Microsoft 365)
Configure Microsoft 365 Activity Monitoring (if using Microsoft 365)
Establish incident/emergency response plan owners
Secure on-premises privileged administrative accounts
If you don’t secure privileged access, you might find that you have too many users in highly privileged roles and
are more vulnerable to attacks. Malicious actors, including cyber attackers, often target admin accounts and
other elements of privileged access to gain access to sensitive data and systems by using credential theft.

Control locations where resources are created


Enabling cloud operators to perform tasks while preventing them from breaking conventions that are needed to
manage your organization's resources is very important. Organizations that want to control the locations where
resources are created should hard code these locations.
You can use Azure Resource Manager to create security policies whose definitions describe the actions or
resources that are specifically denied. You assign those policy definitions at the desired scope, such as the
subscription, the resource group, or an individual resource.

NOTE
Security policies are not the same as Azure RBAC. They actually use Azure RBAC to authorize users to create those
resources.

Organizations that are not controlling how resources are created are more susceptible to users who might
abuse the service by creating more resources than they need. Hardening the resource creation process is an
important step to securing a multitenant scenario.

Actively monitor for suspicious activities


An active identity monitoring system can quickly detect suspicious behavior and trigger an alert for further
investigation. The following table lists two Azure AD capabilities that can help organizations monitor their
identities:
Best practice : Have a method to identify:
Attempts to sign in without being traced.
Brute force attacks against a particular account.
Attempts to sign in from multiple locations.
Sign-ins from infected devices.
Suspicious IP addresses.
Detail : Use Azure AD Premium anomaly reports. Have processes and procedures in place for IT admins to run
these reports on a daily basis or on demand (usually in an incident response scenario).
Best practice : Have an active monitoring system that notifies you of risks and can adjust risk level (high,
medium, or low) to your business requirements.
Detail : Use Azure AD Identity Protection, which flags the current risks on its own dashboard and sends daily
summary notifications via email. To help protect your organization's identities, you can configure risk-based
policies that automatically respond to detected issues when a specified risk level is reached.
Organizations that don’t actively monitor their identity systems are at risk of having user credentials
compromised. Without knowledge that suspicious activities are taking place through these credentials,
organizations can’t mitigate this type of threat.

Use Azure AD for storage authentication


Azure Storage supports authentication and authorization with Azure AD for Blob storage and Queue storage.
With Azure AD authentication, you can use the Azure role-based access control to grant specific permissions to
users, groups, and applications down to the scope of an individual blob container or queue.
We recommend that you use Azure AD for authenticating access to storage.

Next step
See Azure security best practices and patterns for more security best practices to use when you’re designing,
deploying, and managing your cloud solutions by using Azure.
Five steps to securing your identity infrastructure
12/12/2021 • 14 minutes to read • Edit Online

If you're reading this document, you're aware of the significance of security. You likely already carry the
responsibility for securing your organization. If you need to convince others of the importance of security, send
them to read the latest Microsoft Security Intelligence report.
This document will help you get a more secure posture using the capabilities of Azure Active Directory by using
a five-step checklist to inoculate your organization against cyber-attacks.
This checklist will help you quickly deploy critical recommended actions to protect your organization
immediately by explaining how to:
Strengthen your credentials.
Reduce your attack surface area.
Automate threat response.
Utilize cloud intelligence.
Enable end-user self-service.
Make sure you keep track of which features and steps are complete while reading this checklist.

NOTE
Many of the recommendations in this document apply only to applications that are configured to use Azure Active
Directory as their identity provider. Configuring apps for Single Sign-On assures the benefits of credential policies, threat
detection, auditing, logging, and other features add to those applications. Azure AD Application Management is the
foundation - on which all these recommendations are based.

The recommendations in this document are aligned with the Identity Secure Score, an automated assessment of
your Azure AD tenant’s identity security configuration. Organizations can use the Identity Secure Score page in
the Azure AD portal to find gaps in their current security configuration to ensure they follow current Microsoft
best practices for security. Implementing each recommendation in the Secure Score page will increase your
score and allow you to track your progress, plus help you compare your implementation against other similar
size organizations or your industry.
NOTE
Many of the features described here require an Azure AD Premium subscription, while some are free. Please review our
Azure Active Directory pricing and Azure AD Deployment checklist for more information.

Before you begin: Protect privileged accounts with MFA


Before you begin this checklist, make sure you don't get compromised while you're reading this checklist. You
first need to protect your privileged accounts.
Attackers who get control of privileged accounts can do tremendous damage, so it's critical to protect these
accounts first. Enable and require Azure AD Multi-Factor Authentication (MFA) for all administrators in your
organization using Azure AD Security Defaults or Conditional Access. If you haven't implemented MFA, do it
now! It's that important.
All set? Let's get started on the checklist.

Step 1 - Strengthen your credentials


Most enterprise security breaches originate with an account compromised with one of a handful of methods
such as password spray, breach replay, or phishing. Learn more about these attacks in this video (45 min):

Make sure your organization uses strong authentication


Given the frequency of passwords being guessed, phished, stolen with malware, or reused, it's critical to back
the password with some form of strong credential – learn more about Azure AD Multi-Factor Authentication.
To easily enable the basic level of identity security, you can use the one-click enablement with Azure AD Security
Defaults. Security defaults enforce Azure AD MFA for all users in a tenant and blocks sign-ins from legacy
protocols tenant-wide.
Start banning commonly attacked passwords and turn off traditional complexity, and expiration rules.
Many organizations use the traditional complexity (requiring special characters, numbers, uppercase, and
lowercase) and password expiration rules. Microsoft's research has shown these policies cause users to choose
passwords that are easier to guess.
Azure AD's dynamic banned password feature uses current attacker behavior to prevent users from setting
passwords that can easily be guessed. This capability is always on when users are created in the cloud, but is
now also available for hybrid organizations when they deploy Azure AD password protection for Windows
Server Active Directory. Azure AD password protection blocks users from choosing these common passwords
and can be extended to block password containing custom keywords you specify. For example, you can prevent
your users from choosing passwords containing your company’s product names or a local sport team.
Microsoft recommends adopting the following modern password policy based on NIST guidance:
1. Require passwords have at least 8 characters. Longer isn't necessarily better, as they cause users to choose
predictable passwords, save passwords in files, or write them down.
2. Disable expiration rules, which drive users to easily guessed passwords such as Spring2019!
3. Disable character-composition requirements and prevent users from choosing commonly attacked
passwords, as they cause users to choose predictable character substitutions in passwords.
You can use PowerShell to prevent passwords from expiring for users if you create identities in Azure AD
directly. Hybrid organizations should implement these policies using domain group policy settings or Windows
PowerShell.
Protect against leaked credentials and add resilience against outages
If your organization uses a hybrid identity solution with pass-through authentication or federation, then you
should enable password hash sync for the following two reasons:
The Users with leaked credentials report in the Azure AD management warns you of username and
password pairs, which have been exposed on the "dark web." An incredible volume of passwords is leaked
via phishing, malware, and password reuse on third-party sites that are later breached. Microsoft finds many
of these leaked credentials and will tell you, in this report, if they match credentials in your organization – but
only if you enable password hash sync or have cloud-only identities!
In the event of an on-premises outage (for example, in a ransomware attack) you can switch over to using
cloud authentication using password hash sync. This backup authentication method will allow you to
continue accessing apps configured for authentication with Azure Active Directory, including Microsoft 365.
In this case, IT staff won't need to resort to personal email accounts to share data until the on-premises
outage is resolved.
Learn more about how password hash sync works.

NOTE
If you enable password hash sync and are using Azure AD Domain services, Kerberos (AES 256) hashes and optionally
NTLM (RC4, no salt) hashes will also be encrypted and synchronized to Azure AD.

Implement AD FS extranet smart lockout


Organizations, which configure applications to authenticate directly to Azure AD benefit from Azure AD smart
lockout. If you use AD FS in Windows Server 2012R2, implement AD FS extranet lockout protection. If you use
AD FS on Windows Server 2016, implement extranet smart lockout. AD FS Smart Extranet lockout protects
against brute force attacks, which target AD FS while preventing users from being locked out in Active Directory.
Take advantage of intrinsically secure, easier to use credentials
Using Windows Hello, you can replace passwords with strong two-factor authentication on PCs and mobile
devices. This authentication consists of a new type of user credential that is tied securely to a device and uses a
biometric or PIN.

Step 2 - Reduce your attack surface


Given the pervasiveness of password compromise, minimizing the attack surface in your organization is critical.
Eliminating use of older, less secure protocols, limiting access entry points, and exercising more significant
control of administrative access to resources can help reduce the attack surface area.
Block legacy authentication
Apps using their own legacy methods to authenticate with Azure AD and access company data, pose another
risk for organizations. Examples of apps using legacy authentication are POP3, IMAP4, or SMTP clients. Legacy
authentication apps authenticate on behalf of the user and prevent Azure AD from doing advanced security
evaluations. The alternative, modern authentication, will reduce your security risk, because it supports multi-
factor authentication and Conditional Access. We recommend the following three actions:
1. Block legacy authentication if you use AD FS.
2. Setup SharePoint Online and Exchange Online to use modern authentication.
3. If you have Azure AD Premium, use Conditional Access policies to block legacy authentication, otherwise use
Azure AD Security Defaults.
Block invalid authentication entry points
Using the assume breach mentality, you should reduce the impact of compromised user credentials when they
happen. For each app in your environment consider the valid use cases: which groups, which networks, which
devices and other elements are authorized – then block the rest. With Azure AD Conditional Access, you can
control how authorized users access their apps and resources based on specific conditions you define.
Restrict user consent operations
It’s important to understand the various Azure AD application consent experiences, the types of permissions and
consent, and their implications on your organization’s security posture. By default, all users in Azure AD can
grant applications that leverage the Microsoft identity platform to access your organization’s data. While
allowing users to consent by themselves does allow users to easily acquire useful applications that integrate
with Microsoft 365, Azure and other services, it can represent a risk if not used and monitored carefully.
Microsoft recommends restricting user consent to allow end-user consent only for apps from verified publishers
and only for permissions you select. If end-user consent is restricted, previous consent grants will still be
honored but all future consent operations must be performed by an administrator. For restricted cases, admin
consent can be requested by users through an integrated admin consent request workflow or through your own
support processes. Before restricting end-user consent, use our recommendations to plan this change in your
organization. For applications you wish to allow all users to access, consider granting consent on behalf of all
users, making sure users who have not yet consented individually will be able to access the app. If you do not
want these applications to be available to all users in all scenarios, use application assignment and Conditional
Access to restrict user access to specific apps.
Make sure users can request admin approval for new applications to reduce user friction, minimize support
volume, and prevent users from signing up for applications using non-Azure AD credentials. Once you regulate
your consent operations, administrators should audit app and consented permissions on a regular basis.
Implement Azure AD Privileged Identity Management
Another impact of "assume breach" is the need to minimize the likelihood a compromised account can operate
with a privileged role.
Azure AD Privileged Identity Management (PIM) helps you minimized account privileges by helping you:
Identify and manage users assigned to administrative roles.
Understand unused or excessive privilege roles you should remove.
Establish rules to make sure privileged roles are protected by multi-factor authentication.
Establish rules to make sure privileged roles are granted only long enough to accomplish the privileged task.
Enable Azure AD PIM, then view the users who are assigned administrative roles and remove unnecessary
accounts in those roles. For remaining privileged users, move them from permanent to eligible. Finally, establish
appropriate policies to make sure when they need to gain access to those privileged roles, they can do so
securely, with the necessary change control.
As part of deploying your privileged account process, follow the best practice to create at least two emergency
accounts to make sure you still have access to Azure AD if you lock yourself out.

Step 3 - Automate threat response


Azure Active Directory has many capabilities that automatically intercept attacks, to remove the latency between
detection and response. You can reduce the costs and risks, when you reduce the time criminals use to embed
themselves into your environment. Here are the concrete steps you can take.
Implement user risk security policy using Azure AD Identity Protection
User risk indicates the likelihood a user's identity has been compromised and is calculated based on the user
risk detections that are associated with a user's identity. A user risk policy is a Conditional Access policy that
evaluates the risk level to a specific user or group. Based on Low, Medium, High risk-level, a policy can be
configured to block access or require a secure password change using multi-factor authentication. Microsoft's
recommendation is to require a secure password change for users on high risk.

Implement sign-in risk policy using Azure AD Identity Protection


Sign-in risk is the likelihood someone other than the account owner is attempting to sign on using the identity.
A sign-in risk policy is a Conditional Access policy that evaluates the risk level to a specific user or group. Based
on the risk level (high/medium/low), a policy can be configured to block access or force multi-factor
authentication. Make sure you force multi-factor authentication on Medium or above risk sign-ins.

Step 4 - Utilize cloud intelligence


Auditing and logging of security-related events and related alerts are essential components of an efficient
protection strategy. Security logs and reports provide you with an electronic record of suspicious activities and
help you detect patterns that may indicate attempted or successful external penetration of the network, and
internal attacks. You can use auditing to monitor user activity, document regulatory compliance, do forensic
analysis, and more. Alerts provide notifications of security events.
Monitor Azure AD
Microsoft Azure services and features provide you with configurable security auditing and logging options to
help you identify gaps in your security policies and mechanisms and address those gaps to help prevent
breaches. You can use Azure Logging and Auditing and use Audit activity reports in the Azure Active Directory
portal.
Monitor Azure AD Connect Health in hybrid environments
Monitoring AD FS with Azure AD Connect Health provides you with greater insight into potential issues and
visibility of attacks on your AD FS infrastructure. Azure AD Connect Health delivers alerts with details, resolution
steps, and links to related documentation; usage analytics for several metrics related to authentication traffic;
performance monitoring and reports.

Monitor Azure AD Identity Protection events


Azure AD Identity Protection is a notification, monitoring and reporting tool you can use to detect potential
vulnerabilities affecting your organization's identities. It detects risk detections, such as leaked credentials,
impossible travel, and sign-ins from infected devices, anonymous IP addresses, IP addresses associated with the
suspicious activity, and unknown locations. Enable notification alerts to receive email of users at risk and/or a
weekly digest email.
Azure AD Identity Protection provides two important reports you should monitor daily:
1. Risky sign-in reports will surface user sign-in activities you should investigate, the legitimate owner may not
have performed the sign-in.
2. Risky user reports will surface user accounts that may have been compromised, such as leaked credential
that was detected or the user signed in from different locations causing an impossible travel event.
Audit apps and consented permissions
Users can be tricked into navigating to a compromised web site or apps that will gain access to their profile
information and user data, such as their email. A malicious actor can use the consented permissions it received
to encrypt their mailbox content and demand a ransom to regain your mailbox data. Administrators should
review and audit the permissions given by users or disable the ability of users to give consent by default.
In addition to auditing the permissions given by users, you can locate risky or unwanted OAuth applications in
premium environments.

Step 5 - Enable end-user self-service


As much as possible you'll want to balance security with productivity. Along the same lines of approaching your
journey with the mindset that you're setting a foundation for security in the long run, you can remove friction
from your organization by empowering your users while remaining vigilant.
Implement self-service password reset
Azure AD's self-service password reset (SSPR) offers a simple means for IT administrators to allow users to reset
or unlock their passwords or accounts without help desk or administrator intervention. The system includes
detailed reporting that tracks when users have reset their passwords, along with notifications to alert you to
misuse or abuse.
Implement self-service group and application access
Azure AD provides the ability to non-administrators to manage access to resources, using security groups,
Microsoft 365 groups, application roles, and access package catalogs. Self-service group management enables
group owners to manage their own groups, without needing to be assigned an administrative role. Users can
also create and manage Microsoft 365 groups without relying on administrators to handle their requests, and
unused groups expire automatically. Azure AD entitlement management further enables delegation and
visibility, with comprehensive access request workflows and automatic expiration. You can delegate to non-
administrators the ability to configure their own access packages for groups, Teams, applications, and
SharePoint Online sites they own, with custom policies for who is required to approve access, including
configuring employee's managers and business partner sponsors as approvers.
Implement Azure AD access reviews
With Azure AD access reviews, you can manage access package and group memberships, access to enterprise
applications, and privileged role assignments to make sure you maintain a security standard. Regular oversight
by the users themselves, resource owners, and other reviewers ensure that users don't retain access for
extended periods of time when they no longer need it.

Summary
There are many aspects to a secure Identity infrastructure, but this five-step checklist will help you quickly
accomplish a safer and secure identity infrastructure:
Strengthen your credentials.
Reduce your attack surface area.
Automate threat response.
Utilize cloud intelligence.
Enable more predictable and complete end-user security with self-help.
We appreciate how seriously you take Identity Security and hope this document is a useful roadmap to a more
secure posture for your organization.

Next steps
If you need assistance to plan and deploy the recommendations, refer to the Azure AD project deployment plans
for help.
If you're confident all these steps are complete, use Microsoft’s Identity Secure Score, which will keep you up to
date with the latest best practices and security threats.
Passwordless authentication options for Azure
Active Directory
12/12/2021 • 9 minutes to read • Edit Online

Features like multi-factor authentication (MFA) are a great way to secure your organization, but users often get
frustrated with the additional security layer on top of having to remember their passwords. Passwordless
authentication methods are more convenient because the password is removed and replaced with something
you have, plus something you are or something you know.

A UT H EN T IC AT IO N SO M ET H IN G Y O U H AVE SO M ET H IN G Y O U A RE O R K N O W

Passwordless Windows 10 Device, phone, or security Biometric or PIN


key

Each organization has different needs when it comes to authentication. Microsoft global Azure and Azure
Government offer the following three passwordless authentication options that integrate with Azure Active
Directory (Azure AD):
Windows Hello for Business
Microsoft Authenticator app
FIDO2 security keys

Windows Hello for Business


Windows Hello for Business is ideal for information workers that have their own designated Windows PC. The
biometric and PIN credentials are directly tied to the user's PC, which prevents access from anyone other than
the owner. With public key infrastructure (PKI) integration and built-in support for single sign-on (SSO),
Windows Hello for Business provides a convenient method for seamlessly accessing corporate resources on-
premises and in the cloud.
The following steps show how the sign-in process works with Azure AD:
1. A user signs into Windows using biometric or PIN gesture. The gesture unlocks the Windows Hello for
Business private key and is sent to the Cloud Authentication security support provider, referred to as the
Cloud AP provider.
2. The Cloud AP provider requests a nonce (a random arbitrary number that can be used just once) from Azure
AD.
3. Azure AD returns a nonce that's valid for 5 minutes.
4. The Cloud AP provider signs the nonce using the user's private key and returns the signed nonce to the
Azure AD.
5. Azure AD validates the signed nonce using the user's securely registered public key against the nonce
signature. After validating the signature, Azure AD then validates the returned signed nonce. When the nonce
is validated, Azure AD creates a primary refresh token (PRT) with session key that is encrypted to the device's
transport key and returns it to the Cloud AP provider.
6. The Cloud AP provider receives the encrypted PRT with session key. Using the device's private transport key,
the Cloud AP provider decrypts the session key and protects the session key using the device's Trusted
Platform Module (TPM).
7. The Cloud AP provider returns a successful authentication response to Windows. The user is then able to
access Windows as well as cloud and on-premises applications without the need to authenticate again (SSO).
The Windows Hello for Business planning guide can be used to help you make decisions on the type of
Windows Hello for Business deployment and the options you'll need to consider.

Microsoft Authenticator App


You can also allow your employee's phone to become a passwordless authentication method. You may already
be using the Microsoft Authenticator App as a convenient multi-factor authentication option in addition to a
password. You can also use the Authenticator App as a passwordless option.

The Authenticator App turns any iOS or Android phone into a strong, passwordless credential. Users can sign in
to any platform or browser by getting a notification to their phone, matching a number displayed on the screen
to the one on their phone, and then using their biometric (touch or face) or PIN to confirm. Refer to Download
and install the Microsoft Authenticator app for installation details.
Passwordless authentication using the Authenticator app follows the same basic pattern as Windows Hello for
Business. It's a little more complicated as the user needs to be identified so that Azure AD can find the Microsoft
Authenticator App version being used:
1. The user enters their username.
2. Azure AD detects that the user has a strong credential and starts the Strong Credential flow.
3. A notification is sent to the app via Apple Push Notification Service (APNS) on iOS devices, or via Firebase
Cloud Messaging (FCM) on Android devices.
4. The user receives the push notification and opens the app.
5. The app calls Azure AD and receives a proof-of-presence challenge and nonce.
6. The user completes the challenge by entering their biometric or PIN to unlock private key.
7. The nonce is signed with the private key and sent back to Azure AD.
8. Azure AD performs public/private key validation and returns a token.
To get started with passwordless sign-in, complete the following how-to:
Enable passwordless sign using the Authenticator app

FIDO2 security keys


The FIDO (Fast IDentity Online) Alliance helps to promote open authentication standards and reduce the use of
passwords as a form of authentication. FIDO2 is the latest standard that incorporates the web authentication
(WebAuthn) standard.
FIDO2 security keys are an unphishable standards-based passwordless authentication method that can come in
any form factor. Fast Identity Online (FIDO) is an open standard for passwordless authentication. FIDO allows
users and organizations to leverage the standard to sign in to their resources without a username or password
using an external security key or a platform key built into a device.
Users can register and then select a FIDO2 security key at the sign-in interface as their main means of
authentication. These FIDO2 security keys are typically USB devices, but could also use Bluetooth or NFC. With a
hardware device that handles the authentication, the security of an account is increased as there's no password
that could be exposed or guessed.
FIDO2 security keys can be used to sign in to their Azure AD or hybrid Azure AD joined Windows 10 devices and
get single-sign on to their cloud and on-premises resources. Users can also sign in to supported browsers.
FIDO2 security keys are a great option for enterprises who are very security sensitive or have scenarios or
employees who aren't willing or able to use their phone as a second factor.
We have a reference document for which browsers support FIDO2 authentication with Azure AD, as well as best
practices for developers wanting to support FIDO2 auth in the applications they develop.

The following process is used when a user signs in with a FIDO2 security key:
1. The user plugs the FIDO2 security key into their computer.
2. Windows detects the FIDO2 security key.
3. Windows sends an authentication request.
4. Azure AD sends back a nonce.
5. The user completes their gesture to unlock the private key stored in the FIDO2 security key's secure enclave.
6. The FIDO2 security key signs the nonce with the private key.
7. The primary refresh token (PRT) token request with signed nonce is sent to Azure AD.
8. Azure AD verifies the signed nonce using the FIDO2 public key.
9. Azure AD returns PRT to enable access to on-premises resources.
FIDO2 security key providers
The following providers offer FIDO2 security keys of different form factors that are known to be compatible with
the passwordless experience. We encourage you to evaluate the security properties of these keys by contacting
the vendor as well as FIDO Alliance.

F IP S
P RO VIDER B IO M ET RIC USB NFC BLE C ERT IF IED C O N TA C T

AuthenTrend https://authe
ntrend.com/a
bout-us/#pg-
35-3

Ensurity https://www.e
nsurity.com/c
ontact

Excelsecu https://www.e
xcelsecu.com/
productdetail/
esecufido2sec
u.html

Feitian https://shop.ft
safe.us/pages/
microsoft

Fortinet https://www.f
ortinet.com/

GoTrustID Inc. https://www.g


otrustid.com/i
dem-key

HID https://www.h
idglobal.com/
contact-us

Hypersecu https://www.h
ypersecu.com
/hyperfido

IDmelon https://www.i
Technologies dmelon.com/
Inc. #idmelon
F IP S
P RO VIDER B IO M ET RIC USB NFC BLE C ERT IF IED C O N TA C T

Kensington https://www.k
ensington.co
m/solutions/p
roduct-
category/why
-biometrics/

KONA I https://konai.c
om/business/
security/fido

NEOWAVE https://neowa
ve.fr/en/prod
ucts/fido-
range/

Nymi https://www.n
ymi.com/nymi
-band

OneSpan Inc. https://www.o


nespan.com/p
roducts/fido

Thales Group https://cpl.tha


lesgroup.com/
access-
management/
authenticator
s/fido-devices

Thetis https://thetis.i
o/collections/f
ido2

Token2 https://www.t
Switzerland oken2.swiss/s
hop/product/t
oken2-t2f2-
alu-fido2-u2f-
and-totp-
security-key

TrustKey https://www.tr
Solutions ustkeysolutio
ns.com/securi
ty-keys/

VinCSS https://passw
ordless.vincss.
net

Yubico https://www.y
ubico.com/sol
utions/passw
ordless/
NOTE
If you purchase and plan to use NFC-based security keys, you need a supported NFC reader for the security key. The NFC
reader isn't an Azure requirement or limitation. Check with the vendor for your NFC-based security key for a list of
supported NFC readers.

If you're a vendor and want to get your device on this list of supported devices, check out our guidance on how
to become a Microsoft-compatible FIDO2 security key vendor.
To get started with FIDO2 security keys, complete the following how-to:
Enable passwordless sign using FIDO2 security keys

Supported scenarios
The following considerations apply:
Administrators can enable passwordless authentication methods for their tenant.
Administrators can target all users or select users/groups within their tenant for each method.
Users can register and manage these passwordless authentication methods in their account portal.
Users can sign in with these passwordless authentication methods:
Microsoft Authenticator App: Works in scenarios where Azure AD authentication is used, including
across all browsers, during Windows 10 setup, and with integrated mobile apps on any operating
system.
Security keys: Work on lock screen for Windows 10 and the web in supported browsers like Microsoft
Edge (both legacy and new Edge).
Users can use passwordless credentials to access resources in tenants where they are a guest, but they
may still be required to perform MFA in that resource tenant. For more information, see Possible double
multi-factor authentication.
Users may not register passwordless credentials within a tenant where they are a guest, the same way
that they do not have a password managed in that tenant.

Choose a passwordless method


The choice between these three passwordless options depends on your company's security, platform, and app
requirements.
Here are some factors for you to consider when choosing Microsoft passwordless technology:

PA SSW O RDL ESS SIGN - IN


W IN DO W S H EL LO F O R W IT H T H E M IC RO SO F T
B USIN ESS A UT H EN T IC ATO R A P P F IDO 2 SEC URIT Y K EY S

Pre-requisite Windows 10, version 1809 Microsoft Authenticator Windows 10, version 1903
or later app or later
Azure Active Directory Phone (iOS and Android Azure Active Directory
devices running Android 6.0
or above.)

Mode Platform Software Hardware


PA SSW O RDL ESS SIGN - IN
W IN DO W S H EL LO F O R W IT H T H E M IC RO SO F T
B USIN ESS A UT H EN T IC ATO R A P P F IDO 2 SEC URIT Y K EY S

Systems and devices PC with a built-in Trusted PIN and biometrics FIDO2 security devices that
Platform Module (TPM) recognition on phone are Microsoft compatible
PIN and biometrics
recognition

User experience Sign in using a PIN or Sign in using a mobile Sign in using FIDO2
biometric recognition (facial, phone with fingerprint scan, security device (biometrics,
iris, or fingerprint) with facial or iris recognition, or PIN, and NFC)
Windows devices. PIN. User can access device
Windows Hello Users sign in to work or based on organization
authentication is tied to the personal account from their controls and authenticate
device; the user needs both PC or mobile phone. based on PIN, biometrics
the device and a sign-in using devices such as USB
component such as a PIN security keys and NFC-
or biometric factor to access enabled smartcards, keys,
corporate resources. or wearables.

Enabled scenarios Password-less experience Password-less anywhere Password-less experience


with Windows device. solution using mobile for workers using
Applicable for dedicated phone. biometrics, PIN, and NFC.
work PC with ability for Applicable for accessing Applicable for shared PCs
single sign-on to device and work or personal and where a mobile phone
applications. applications on the web is not a viable option (such
from any device. as for help desk personnel,
public kiosk, or hospital
team)

Use the following table to choose which method will support your requirements and users.

PA SSW O RDL ESS


P ERSO N A SC EN A RIO EN VIRO N M EN T T EC H N O LO GY

Admin Secure access to a device Assigned Windows 10 Windows Hello for Business
for management tasks device and/or FIDO2 security key

Admin Management tasks on non- Mobile or non-windows Passwordless sign-in with


Windows devices device the Microsoft Authenticator
app

Information worker Productivity work Assigned Windows 10 Windows Hello for Business
device and/or FIDO2 security key

Information worker Productivity work Mobile or non-windows Passwordless sign-in with


device the Microsoft Authenticator
app

Frontline worker Kiosks in a factory, plant, Shared Windows 10 devices FIDO2 Security keys
retail, or data entry

Next steps
To get started with passwordless in Azure AD, complete one of the following how-tos:
Enable FIDO2 security key passwordless sign-in
Enable phone-based passwordless sign-in with the Authenticator app
External Links
FIDO Alliance
FIDO2 CTAP specification
Azure network security overview
12/12/2021 • 22 minutes to read • Edit Online

Network security could be defined as the process of protecting resources from unauthorized access or attack by
applying controls to network traffic. The goal is to ensure that only legitimate traffic is allowed. Azure includes a
robust networking infrastructure to support your application and service connectivity requirements. Network
connectivity is possible between resources located in Azure, between on-premises and Azure hosted resources,
and to and from the internet and Azure.
This article covers some of the options that Azure offers in the area of network security. You can learn about:
Azure networking
Network access control
Azure Firewall
Secure remote access and cross-premises connectivity
Availability
Name resolution
Perimeter network (DMZ) architecture
Azure DDoS protection
Azure Front Door
Traffic manager
Monitoring and threat detection

Azure networking
Azure requires virtual machines to be connected to an Azure Virtual Network. A virtual network is a logical
construct built on top of the physical Azure network fabric. Each virtual network is isolated from all other virtual
networks. This helps ensure that network traffic in your deployments is not accessible to other Azure customers.
Learn more:
Virtual network overview

Network access control


Network access control is the act of limiting connectivity to and from specific devices or subnets within a virtual
network. The goal of network access control is to limit access to your virtual machines and services to approved
users and devices. Access controls are based on decisions to allow or deny connections to and from your virtual
machine or service.
Azure supports several types of network access control, such as:
Network layer control
Route control and forced tunneling
Virtual network security appliances
Network layer control
Any secure deployment requires some measure of network access control. The goal of network access control is
to restrict virtual machine communication to the necessary systems. Other communication attempts are
blocked.
NOTE
Storage Firewalls are covered in the Azure storage security overview article

Network security rules (NSGs )


If you need basic network level access control (based on IP address and the TCP or UDP protocols), you can use
Network Security Groups (NSGs). An NSG is a basic, stateful, packet filtering firewall, and it enables you to
control access based on a 5-tuple. NSGs include functionality to simplify management and reduce the chances
of configuration mistakes:
Augmented security rules simplify NSG rule definition and allow you to create complex rules rather than
having to create multiple simple rules to achieve the same result.
Ser vice tags are Microsoft created labels that represent a group of IP addresses. They update dynamically
to include IP ranges that meet the conditions that define inclusion in the label. For example, if you want to
create a rule that applies to all Azure storage on the east region you can use Storage.EastUS
Application security groups allow you to deploy resources to application groups and control the access to
those resources by creating rules that use those application groups. For example, if you have webservers
deployed to the 'Webservers' application group you can create a rule that applies a NSG allowing 443 traffic
from the Internet to all systems in the 'Webservers' application group.
NSGs do not provide application layer inspection or authenticated access controls.
Learn more:
Network Security Groups
Defender for Cloud just in time VM access
Microsoft Defender for Cloud can manage the NSGs on VMs and lock access to the VM until a user with the
appropriate Azure role-based access control Azure RBAC permissions requests access. When the user is
successfully authorized Defender for Cloud makes modifications to the NSGs to allow access to selected ports
for the time specified. When the time expires the NSGs are restored to their previous secured state.
Learn more:
Microsoft Defender for Cloud Just in Time Access
Service endpoints
Service endpoints are another way to apply control over your traffic. You can limit communication with
supported services to just your VNets over a direct connection. Traffic from your VNet to the specified Azure
service remains on the Microsoft Azure backbone network.
Learn more:
Service endpoints
Route control and forced tunneling
The ability to control routing behavior on your virtual networks is critical. If routing is configured incorrectly,
applications and services hosted on your virtual machine might connect to unauthorized devices, including
systems owned and operated by potential attackers.
Azure networking supports the ability to customize the routing behavior for network traffic on your virtual
networks. This enables you to alter the default routing table entries in your virtual network. Control of routing
behavior helps you make sure that all traffic from a certain device or group of devices enters or leaves your
virtual network through a specific location.
For example, you might have a virtual network security appliance on your virtual network. You want to make
sure that all traffic to and from your virtual network goes through that virtual security appliance. You can do this
by configuring User Defined Routes (UDRs) in Azure.
Forced tunneling is a mechanism you can use to ensure that your services are not allowed to initiate a
connection to devices on the internet. Note that this is different from accepting incoming connections and then
responding to them. Front-end web servers need to respond to requests from internet hosts, and so internet-
sourced traffic is allowed inbound to these web servers and the web servers are allowed to respond.
What you don't want to allow is a front-end web server to initiate an outbound request. Such requests might
represent a security risk because these connections can be used to download malware. Even if you do want
these front-end servers to initiate outbound requests to the internet, you might want to force them to go
through your on-premises web proxies. This enables you to take advantage of URL filtering and logging.
Instead, you would want to use forced tunneling to prevent this. When you enable forced tunneling, all
connections to the internet are forced through your on-premises gateway. You can configure forced tunneling
by taking advantage of UDRs.
Learn more:
What are User Defined Routes and IP Forwarding
Virtual network security appliances
While NSGs, UDRs, and forced tunneling provide you a level of security at the network and transport layers of
the OSI model, you might also want to enable security at levels higher than the network.
For example, your security requirements might include:
Authentication and authorization before allowing access to your application
Intrusion detection and intrusion response
Application layer inspection for high-level protocols
URL filtering
Network level antivirus and Antimalware
Anti-bot protection
Application access control
Additional DDoS protection (above the DDoS protection provided by the Azure fabric itself)
You can access these enhanced network security features by using an Azure partner solution. You can find the
most current Azure partner network security solutions by visiting the Azure Marketplace, and searching for
"security" and "network security."

Azure Firewall
Azure Firewall is a managed, cloud-based network security service that protects your Azure Virtual Network
resources. It is a fully stateful firewall as a service with built-in high availability and unrestricted cloud scalability.
Some features include:
High availability
Cloud scalability
Application FQDN filtering rules
Network traffic filtering rules
Learn more:
Azure Firewall overview

Secure remote access and cross-premises connectivity


Setup, configuration, and management of your Azure resources needs to be done remotely. In addition, you
might want to deploy hybrid IT solutions that have components on-premises and in the Azure public cloud.
These scenarios require secure remote access.
Azure networking supports the following secure remote access scenarios:
Connect individual workstations to a virtual network
Connect your on-premises network to a virtual network with a VPN
Connect your on-premises network to a virtual network with a dedicated WAN link
Connect virtual networks to each other
Connect individual workstations to a virtual network
You might want to enable individual developers or operations personnel to manage virtual machines and
services in Azure. For example, let's say you need access to a virtual machine on a virtual network. But your
security policy does not allow RDP or SSH remote access to individual virtual machines. In this case, you can use
a point-to-site VPN connection.
The point-to-site VPN connection enables you to set up a private and secure connection between the user and
the virtual network. When the VPN connection is established, the user can RDP or SSH over the VPN link into
any virtual machine on the virtual network. (This assumes that the user can authenticate and is authorized.)
Point-to-site VPN supports:
Secure Socket Tunneling Protocol (SSTP), a proprietary SSL-based VPN protocol. An SSL VPN solution
can penetrate firewalls, since most firewalls open TCP port 443, which TLS/SSL uses. SSTP is only
supported on Windows devices. Azure supports all versions of Windows that have SSTP (Windows 7 and
later).
IKEv2 VPN, a standards-based IPsec VPN solution. IKEv2 VPN can be used to connect from Mac devices
(OSX versions 10.11 and above).
OpenVPN
Learn more:
Configure a point-to-site connection to a virtual network using PowerShell
Connect your on-premises network to a virtual network with a VPN
You might want to connect your entire corporate network, or portions of it, to a virtual network. This is common
in hybrid IT scenarios, where organizations extend their on-premises datacenter into Azure. In many cases,
organizations host parts of a service in Azure, and parts on-premises. For example,they might do so when a
solution includes front-end web servers in Azure and back-end databases on-premises. These types of "cross-
premises" connections also make management of Azure located resources more secure, and enable scenarios
such as extending Active Directory domain controllers into Azure.
One way to accomplish this is to use a site-to-site VPN. The difference between a site-to-site VPN and a point-
to-site VPN is that the latter connects a single device to a virtual network. A site-to-site VPN connects an entire
network (such as your on-premises network) to a virtual network. Site-to-site VPNs to a virtual network use the
highly secure IPsec tunnel mode VPN protocol.
Learn more:
Create a Resource Manager VNet with a site-to-site VPN connection using the Azure portal
About VPN Gateway
Connect your on-premises network to a virtual network with a dedicated WAN link
Point-to-site and site-to-site VPN connections are effective for enabling cross-premises connectivity. However,
some organizations consider them to have the following drawbacks:
VPN connections move data over the internet. This exposes these connections to potential security issues
involved with moving data over a public network. In addition, reliability and availability for internet
connections cannot be guaranteed.
VPN connections to virtual networks might not have the bandwidth for some applications and purposes, as
they max out at around 200 Mbps.
Organizations that need the highest level of security and availability for their cross-premises connections
typically use dedicated WAN links to connect to remote sites. Azure provides you the ability to use a dedicated
WAN link that you can use to connect your on-premises network to a virtual network. Azure ExpressRoute,
Express route direct, and Express route global reach enable this.
Learn more:
ExpressRoute technical overview
ExpressRoute direct
Express route global reach
Connect virtual networks to each other
It is possible to use many virtual networks for your deployments. There are various reasons why you might do
this. You might want to simplify management, or you might want increased security. Regardless of the
motivation for putting resources on different virtual networks, there might be times when you want resources
on each of the networks to connect with one another.
One option is for services on one virtual network to connect to services on another virtual network, by "looping
back" through the internet. The connection starts on one virtual network, goes through the internet, and then
comes back to the destination virtual network. This option exposes the connection to the security issues
inherent in any internet-based communication.
A better option might be to create a site-to-site VPN that connects between two virtual networks. This method
uses the same IPSec tunnel mode protocol as the cross-premises site-to-site VPN connection mentioned above.
The advantage of this approach is that the VPN connection is established over the Azure network fabric, instead
of connecting over the internet. This provides you an extra layer of security, compared to site-to-site VPNs that
connect over the internet.
Learn more:
Configure a VNet-to-VNet Connection by using Azure Resource Manager and PowerShell
Another way to connect your virtual networks is VNET peering. This feature allows you to connect two Azure
networks so that communication between them happens over the Microsoft backbone infrastructure without it
ever going over the Internet. VNET peering can connect two VNETs within the same region or two VNETs across
Azure regions. NSGs can be used to limit connectivity between different subnets or systems.

Availability
Availability is a key component of any security program. If your users and systems can't access what they need
to access over the network, the service can be considered compromised. Azure has networking technologies
that support the following high-availability mechanisms:
HTTP-based load balancing
Network level load balancing
Global load balancing
Load balancing is a mechanism designed to equally distribute connections among multiple devices. The goals of
load balancing are:
To increase availability. When you load balance connections across multiple devices, one or more of the
devices can become unavailable without compromising the service. The services running on the remaining
online devices can continue to serve the content from the service.
To increase performance. When you load balance connections across multiple devices, a single device doesn't
have to handle all processing. Instead, the processing and memory demands for serving the content is
spread across multiple devices.
HTTP-based load balancing
Organizations that run web-based services often desire to have an HTTP-based load balancer in front of those
web services. This helps ensure adequate levels of performance and high availability. Traditional, network-based
load balancers rely on network and transport layer protocols. HTTP-based load balancers, on the other hand,
make decisions based on characteristics of the HTTP protocol.
Azure Application Gateway provides HTTP-based load balancing for your web-based services. Application
Gateway supports:
Cookie-based session affinity. This capability makes sure that connections established to one of the servers
behind that load balancer stays intact between the client and server. This ensures stability of transactions.
TLS offload. When a client connects with the load balancer, that session is encrypted by using the HTTPS
(TLS) protocol. However, in order to increase performance, you can use the HTTP (unencrypted) protocol to
connect between the load balancer and the web server behind the load balancer. This is referred to as "TLS
offload," because the web servers behind the load balancer don't experience the processor overhead
involved with encryption. The web servers can therefore service requests more quickly.
URL-based content routing. This feature makes it possible for the load balancer to make decisions about
where to forward connections based on the target URL. This provides a lot more flexibility than solutions that
make load balancing decisions based on IP addresses.
Learn more:
Application Gateway overview
Network level load balancing
In contrast to HTTP-based load balancing, network level load balancing makes decisions based on IP address
and port (TCP or UDP) numbers. You can gain the benefits of network level load balancing in Azure by using
Azure Load Balancer. Some key characteristics of Load Balancer include:
Network level load balancing based on IP address and port numbers.
Support for any application layer protocol.
Load balances to Azure virtual machines and cloud services role instances.
Can be used for both internet-facing (external load balancing) and non-internet facing (internal load
balancing) applications and virtual machines.
Endpoint monitoring, which is used to determine if any of the services behind the load balancer have
become unavailable.
Learn more:
Internet-facing load balancer between multiple virtual machines or services
Internal load balancer overview
Global load balancing
Some organizations want the highest level of availability possible. One way to reach this goal is to host
applications in globally distributed datacenters. When an application is hosted in datacenters located throughout
the world, it's possible for an entire geopolitical region to become unavailable, and still have the application up
and running.
This load-balancing strategy can also yield performance benefits. You can direct requests for the service to the
datacenter that is nearest to the device that is making the request.
In Azure, you can gain the benefits of global load balancing by using Azure Traffic Manager.
Learn more:
What is Traffic Manager?

Name resolution
Name resolution is a critical function for all services you host in Azure. From a security perspective, compromise
of the name resolution function can lead to an attacker redirecting requests from your sites to an attacker's site.
Secure name resolution is a requirement for all your cloud hosted services.
There are two types of name resolution you need to address:
Internal name resolution. This is used by services on your virtual networks, your on-premises networks, or
both. Names used for internal name resolution are not accessible over the internet. For optimal security, it's
important that your internal name resolution scheme is not accessible to external users.
External name resolution. This is used by people and devices outside of your on-premises networks and
virtual networks. These are the names that are visible to the internet, and are used to direct connection to
your cloud-based services.
For internal name resolution, you have two options:
A virtual network DNS server. When you create a new virtual network, a DNS server is created for you. This
DNS server can resolve the names of the machines located on that virtual network. This DNS server is not
configurable, is managed by the Azure fabric manager, and can therefore help you secure your name
resolution solution.
Bring your own DNS server. You have the option of putting a DNS server of your own choosing on your
virtual network. This DNS server can be an Active Directory integrated DNS server, or a dedicated DNS
server solution provided by an Azure partner, which you can obtain from the Azure Marketplace.
Learn more:
Virtual network overview
Manage DNS Servers used by a virtual network
For external name resolution, you have two options:
Host your own external DNS server on-premises.
Host your own external DNS server with a service provider.
Many large organizations host their own DNS servers on-premises. They can do this because they have the
networking expertise and global presence to do so.
In most cases, it's better to host your DNS name resolution services with a service provider. These service
providers have the network expertise and global presence to ensure very high availability for your name
resolution services. Availability is essential for DNS services, because if your name resolution services fail, no
one will be able to reach your internet facing services.
Azure provides you with a highly available and high-performing external DNS solution in the form of Azure
DNS. This external name resolution solution takes advantage of the worldwide Azure DNS infrastructure. It
allows you to host your domain in Azure, using the same credentials, APIs, tools, and billing as your other Azure
services. As part of Azure, it also inherits the strong security controls built into the platform.
Learn more:
Azure DNS overview
Azure DNS private zones allows you to configure private DNS names for Azure resources rather than the
automatically assigned names without the need to add a custom DNS solution.

Perimeter network architecture


Many large organizations use perimeter networks to segment their networks, and create a buffer-zone between
the internet and their services. The perimeter portion of the network is considered a low-security zone, and no
high-value assets are placed in that network segment. You'll typically see network security devices that have a
network interface on the perimeter network segment. Another network interface is connected to a network that
has virtual machines and services that accept inbound connections from the internet.
You can design perimeter networks in a number of different ways. The decision to deploy a perimeter network,
and then what type of perimeter network to use if you decide to use one, depends on your network security
requirements.
Learn more:
Microsoft Cloud Services and Network Security

Azure DDoS protection


Distributed denial of service (DDoS) attacks are some of the largest availability and security concerns facing
customers that are moving their applications to the cloud. A DDoS attack attempts to exhaust an application's
resources, making the application unavailable to legitimate users. DDoS attacks can be targeted at any endpoint
that is publicly reachable through the internet. Microsoft provides DDoS protection known as Basic as part of
the Azure Platform. This comes at no charge and includes always on monitoring and real-time mitigation of
common network level attacks. In addition to the protections included with DDoS protection Basic you can
enable the Standard option. DDoS Protection Standard features include:
Native platform integration: Natively integrated into Azure. Includes configuration through the Azure
portal. DDoS Protection Standard understands your resources and resource configuration.
Turn-key protection: Simplified configuration immediately protects all resources on a virtual network as
soon as DDoS Protection Standard is enabled. No intervention or user definition is required. DDoS Protection
Standard instantly and automatically mitigates the attack, once it is detected.
Always-on traffic monitoring: Your application traffic patterns are monitored 24 hour a day, 7 days a
week, looking for indicators of DDoS attacks. Mitigation is performed when protection policies are exceeded.
Attack Mitigation Repor ts Attack Mitigation Reports use aggregated network flow data to provide
detailed information about attacks targeted at your resources.
Attack Mitigation Flow Logs Attack Mitigation Flow Logs allow you to review the dropped traffic,
forwarded traffic and other attack data in near real-time during an active DDoS attack.
Adaptive tuning: Intelligent traffic profiling learns your application's traffic over time, and selects and
updates the profile that is the most suitable for your service. The profile adjusts as traffic changes over time.
Layer 3 to layer 7 protection: Provides full stack DDoS protection, when used with a web application firewall.
Extensive mitigation scale: Over 60 different attack types can be mitigated, with global capacity, to protect
against the largest known DDoS attacks.
Attack metrics: Summarized metrics from each attack are accessible through Azure Monitor.
Attack aler ting: Alerts can be configured at the start and stop of an attack, and over the attack's duration,
using built-in attack metrics. Alerts integrate into your operational software like Microsoft Azure Monitor
logs, Splunk, Azure Storage, Email, and the Azure portal.
Cost guarantee: Data-transfer and application scale-out service credits for documented DDoS attacks.
DDoS Rapid responsive DDoS Protection Standard customers now have access to Rapid Response team
during an active attack. DRR can help with attack investigation, custom mitigations during an attack and
post-attack analysis.
Learn more:
DDOS protection overview

Azure Front Door


Azure Front Door Service enables you to define, manage, and monitor the global routing of your web traffic. It
optimizes your traffic's routing for best performance and high availability. Azure Front Door allows you to
author custom web application firewall (WAF) rules for access control to protect your HTTP/HTTPS workload
from exploitation based on client IP addresses, country code, and http parameters. Additionally, Front Door also
enables you to create rate limiting rules to battle malicious bot traffic, it includes TLS offloading and per-
HTTP/HTTPS request, application-layer processing.
Front Door platform itself is protected by Azure DDoS Protection Basic. For further protection, Azure DDoS
Protection Standard may be enabled at your VNETs and safeguard resources from network layer (TCP/UDP)
attacks via auto tuning and mitigation. Front Door is a layer 7 reverse proxy, it only allows web traffic to pass
through to back end servers and block other types of traffic by default.
Learn more:
For more information on the whole set of Azure Front door capabilities you can review the Azure Front Door
overview

Azure Traffic manager


Azure Traffic Manager is a DNS-based traffic load balancer that enables you to distribute traffic optimally to
services across global Azure regions, while providing high availability and responsiveness. Traffic Manager uses
DNS to direct client requests to the most appropriate service endpoint based on a traffic-routing method and
the health of the endpoints. An endpoint is any Internet-facing service hosted inside or outside of Azure. Traffic
manager monitors the end points and does not direct traffic to any endpoints that are unavailable.
Learn more:
Azure Traffic manager overview

Monitoring and threat detection


Azure provides capabilities to help you in this key area with early detection, monitoring, and collecting and
reviewing network traffic.
Azure Network Watcher
Azure Network Watcher can help you troubleshoot, and provides a whole new set of tools to assist with the
identification of security issues.
Security Group View helps with auditing and security compliance of Virtual Machines. Use this feature to
perform programmatic audits, comparing the baseline policies defined by your organization to effective rules
for each of your VMs. This can help you identify any configuration drift.
Packet capture allows you to capture network traffic to and from the virtual machine. You can collect network
statistics and troubleshoot application issues, which can be invaluable in the investigation of network intrusions.
You can also use this feature together with Azure Functions to start network captures in response to specific
Azure alerts.
For more information on Network Watcher and how to start testing some of the functionality in your labs, see
Azure network watcher monitoring overview.
NOTE
For the most up-to-date notifications on availability and status of this service, check the Azure updates page.

Microsoft Defender for Cloud


Microsoft Defender for Cloud helps you prevent, detect, and respond to threats, and provides you increased
visibility into, and control over, the security of your Azure resources. It provides integrated security monitoring
and policy management across your Azure subscriptions, helps detect threats that might otherwise go
unnoticed, and works with a large set of security solutions.
Defender for Cloud helps you optimize and monitor network security by:
Providing network security recommendations.
Monitoring the state of your network security configuration.
Alerting you to network based threats, both at the endpoint and network levels.
Learn more:
Introduction to Microsoft Defender for Cloud
Virtual Network TAP
Azure virtual network TAP (Terminal Access Point) allows you to continuously stream your virtual machine
network traffic to a network packet collector or analytics tool. The collector or analytics tool is provided by a
network virtual appliance partner. You can use the same virtual network TAP resource to aggregate traffic from
multiple network interfaces in the same or different subscriptions.
Learn more:
Virtual network TAP
Logging
Logging at a network level is a key function for any network security scenario. In Azure, you can log information
obtained for NSGs to get network level logging information. With NSG logging, you get information from:
Activity logs. Use these logs to view all operations submitted to your Azure subscriptions. These logs are
enabled by default, and can be used within the Azure portal. They were previously known as audit or
operational logs.
Event logs. These logs provide information about what NSG rules were applied.
Counter logs. These logs let you know how many times each NSG rule was applied to deny or allow traffic.
You can also use Microsoft Power BI, a powerful data visualization tool, to view and analyze these logs. Learn
more:
Azure Monitor logs for Network Security Groups (NSGs)
Azure best practices for network security
12/12/2021 • 16 minutes to read • Edit Online

This article discusses a collection of Azure best practices to enhance your network security. These best practices
are derived from our experience with Azure networking and the experiences of customers like yourself.
For each best practice, this article explains:
What the best practice is
Why you want to enable that best practice
What might be the result if you fail to enable the best practice
Possible alternatives to the best practice
How you can learn to enable the best practice
These best practices are based on a consensus opinion, and Azure platform capabilities and feature sets, as they
exist at the time this article was written. Opinions and technologies change over time and this article will be
updated on a regular basis to reflect those changes.

Use strong network controls


You can connect Azure virtual machines (VMs) and appliances to other networked devices by placing them on
Azure virtual networks. That is, you can connect virtual network interface cards to a virtual network to allow
TCP/IP-based communications between network-enabled devices. Virtual machines connected to an Azure
virtual network can connect to devices on the same virtual network, different virtual networks, the internet, or
your own on-premises networks.
As you plan your network and the security of your network, we recommend that you centralize:
Management of core network functions like ExpressRoute, virtual network and subnet provisioning, and IP
addressing.
Governance of network security elements, such as network virtual appliance functions like ExpressRoute,
virtual network and subnet provisioning, and IP addressing.
If you use a common set of management tools to monitor your network and the security of your network, you
get clear visibility into both. A straightforward, unified security strategy reduces errors because it increases
human understanding and the reliability of automation.

Logically segment subnets


Azure virtual networks are similar to LANs on your on-premises network. The idea behind an Azure virtual
network is that you create a network, based on a single private IP address space, on which you can place all your
Azure virtual machines. The private IP address spaces available are in the Class A (10.0.0.0/8), Class B
(172.16.0.0/12), and Class C (192.168.0.0/16) ranges.
Best practices for logically segmenting subnets include:
Best practice : Don't assign allow rules with broad ranges (for example, allow 0.0.0.0 through 255.255.255.255).
Detail : Ensure troubleshooting procedures discourage or ban setting up these types of rules. These allow rules
lead to a false sense of security and are frequently found and exploited by red teams.
Best practice : Segment the larger address space into subnets.
Detail : Use CIDR-based subnetting principles to create your subnets.
Best practice : Create network access controls between subnets. Routing between subnets happens
automatically, and you don't need to manually configure routing tables. By default, there are no network access
controls between the subnets that you create on an Azure virtual network.
Detail : Use a network security group to protect against unsolicited traffic into Azure subnets. Network security
groups are simple, stateful packet inspection devices that use the 5-tuple approach (source IP, source port,
destination IP, destination port, and layer 4 protocol) to create allow/deny rules for network traffic. You allow or
deny traffic to and from a single IP address, to and from multiple IP addresses, or to and from entire subnets.
When you use network security groups for network access control between subnets, you can put resources that
belong to the same security zone or role in their own subnets.
Best practice : Avoid small virtual networks and subnets to ensure simplicity and flexibility.
Detail : Most organizations add more resources than initially planned, and re-allocating addresses is labor
intensive. Using small subnets adds limited security value, and mapping a network security group to each
subnet adds overhead. Define subnets broadly to ensure that you have flexibility for growth.
Best practice : Simplify network security group rule management by defining Application Security Groups.
Detail : Define an Application Security Group for lists of IP addresses that you think might change in the future
or be used across many network security groups. Be sure to name Application Security Groups clearly so others
can understand their content and purpose.

Adopt a Zero Trust approach


Perimeter-based networks operate on the assumption that all systems within a network can be trusted. But
today's employees access their organization's resources from anywhere on a variety of devices and apps, which
makes perimeter security controls irrelevant. Access control policies that focus only on who can access a
resource are not enough. To master the balance between security and productivity, security admins also need to
factor in how a resource is being accessed.
Networks need to evolve from traditional defenses because networks might be vulnerable to breaches: an
attacker can compromise a single endpoint within the trusted boundary and then quickly expand a foothold
across the entire network. Zero Trust networks eliminate the concept of trust based on network location within a
perimeter. Instead, Zero Trust architectures use device and user trust claims to gate access to organizational data
and resources. For new initiatives, adopt Zero Trust approaches that validate trust at the time of access.
Best practices are:
Best practice : Give Conditional Access to resources based on device, identity, assurance, network location, and
more.
Detail : Azure AD Conditional Access lets you apply the right access controls by implementing automated access
control decisions based on the required conditions. For more information, see Manage access to Azure
management with Conditional Access.
Best practice : Enable port access only after workflow approval.
Detail : You can use just-in-time VM access in Microsoft Defender for Cloud to lock down inbound traffic to your
Azure VMs, reducing exposure to attacks while providing easy access to connect to VMs when needed.
Best practice : Grant temporary permissions to perform privileged tasks, which prevents malicious or
unauthorized users from gaining access after the permissions have expired. Access is granted only when users
need it.
Detail : Use just-in-time access in Azure AD Privileged Identity Management or in a third-party solution to grant
permissions to perform privileged tasks.
Zero Trust is the next evolution in network security. The state of cyberattacks drives organizations to take the
"assume breach" mindset, but this approach shouldn't be limiting. Zero Trust networks protect corporate data
and resources while ensuring that organizations can build a modern workplace by using technologies that
empower employees to be productive anytime, anywhere, in any way.

Control routing behavior


When you put a virtual machine on an Azure virtual network, the VM can connect to any other VM on the same
virtual network, even if the other VMs are on different subnets. This is possible because a collection of system
routes enabled by default allows this type of communication. These default routes allow VMs on the same
virtual network to initiate connections with each other, and with the internet (for outbound communications to
the internet only).
Although the default system routes are useful for many deployment scenarios, there are times when you want
to customize the routing configuration for your deployments. You can configure the next-hop address to reach
specific destinations.
We recommend that you configure user-defined routes when you deploy a security appliance for a virtual
network. We talk about this in a later section titled secure your critical Azure service resources to only your
virtual networks.

NOTE
User-defined routes are not required, and the default system routes usually work.

Use virtual network appliances


Network security groups and user-defined routing can provide a certain measure of network security at the
network and transport layers of the OSI model. But in some situations, you want or need to enable security at
high levels of the stack. In such situations, we recommend that you deploy virtual network security appliances
provided by Azure partners.
Azure network security appliances can deliver better security than what network-level controls provide. Network
security capabilities of virtual network security appliances include:
Firewalling
Intrusion detection/intrusion prevention
Vulnerability management
Application control
Network-based anomaly detection
Web filtering
Antivirus
Botnet protection
To find available Azure virtual network security appliances, go to the Azure Marketplace and search for "security"
and "network security."

Deploy perimeter networks for security zones


A perimeter network (also known as a DMZ) is a physical or logical network segment that provides an additional
layer of security between your assets and the internet. Specialized network access control devices on the edge of
a perimeter network allow only desired traffic into your virtual network.
Perimeter networks are useful because you can focus your network access control management, monitoring,
logging, and reporting on the devices at the edge of your Azure virtual network. A perimeter network is where
you typically enable distributed denial of service (DDoS) prevention, intrusion detection/intrusion prevention
systems (IDS/IPS), firewall rules and policies, web filtering, network antimalware, and more. The network
security devices sit between the internet and your Azure virtual network and have an interface on both
networks.
Although this is the basic design of a perimeter network, there are many different designs, like back-to-back, tri-
homed, and multi-homed.
Based on the Zero Trust concept mentioned earlier, we recommend that you consider using a perimeter network
for all high security deployments to enhance the level of network security and access control for your Azure
resources. You can use Azure or a third-party solution to provide an additional layer of security between your
assets and the internet:
Azure native controls. Azure Firewall and the web application firewall in Application Gateway offer basic
security with a fully stateful firewall as a service, built-in high availability, unrestricted cloud scalability, FQDN
filtering, support for OWASP core rule sets, and simple setup and configuration.
Third-party offerings. Search the Azure Marketplace for next-generation firewall (NGFW) and other third-
party offerings that provide familiar security tools and significantly enhanced levels of network security.
Configuration might be more complex, but a third-party offering might allow you to use existing capabilities
and skillsets.

Avoid exposure to the internet with dedicated WAN links


Many organizations have chosen the hybrid IT route. With hybrid IT, some of the company's information assets
are in Azure, and others remain on-premises. In many cases, some components of a service are running in
Azure while other components remain on-premises.
In a hybrid IT scenario, there is usually some type of cross-premises connectivity. Cross-premises connectivity
allows the company to connect its on-premises networks to Azure virtual networks. Two cross-premises
connectivity solutions are available:
Site-to-site VPN. It's a trusted, reliable, and established technology, but the connection takes place over the
internet. Bandwidth is constrained to a maximum of about 1.25 Gbps. Site-to-site VPN is a desirable option in
some scenarios.
Azure ExpressRoute . We recommend that you use ExpressRoute for your cross-premises connectivity.
ExpressRoute lets you extend your on-premises networks into the Microsoft cloud over a private connection
facilitated by a connectivity provider. With ExpressRoute, you can establish connections to Microsoft cloud
services like Azure, Microsoft 365, and Dynamics 365. ExpressRoute is a dedicated WAN link between your
on-premises location or a Microsoft Exchange hosting provider. Because this is a telco connection, your data
doesn't travel over the internet, so it isn't exposed to the potential risks of internet communications.
The location of your ExpressRoute connection can affect firewall capacity, scalability, reliability, and network
traffic visibility. You'll need to identify where to terminate ExpressRoute in existing (on-premises) networks. You
can:
Terminate outside the firewall (the perimeter network paradigm) if you require visibility into the traffic, if you
need to continue an existing practice of isolating datacenters, or if you're solely putting extranet resources on
Azure.
Terminate inside the firewall (the network extension paradigm). This is the default recommendation. In all
other cases, we recommend treating Azure as an nth datacenter.

Optimize uptime and performance


If a service is down, information can't be accessed. If performance is so poor that the data is unusable, you can
consider the data to be inaccessible. From a security perspective, you need to do whatever you can to make sure
that your services have optimal uptime and performance.
A popular and effective method for enhancing availability and performance is load balancing. Load balancing is
a method of distributing network traffic across servers that are part of a service. For example, if you have front-
end web servers as part of your service, you can use load balancing to distribute the traffic across your multiple
front-end web servers.
This distribution of traffic increases availability because if one of the web servers becomes unavailable, the load
balancer stops sending traffic to that server and redirects it to the servers that are still online. Load balancing
also helps performance, because the processor, network, and memory overhead for serving requests is
distributed across all the load-balanced servers.
We recommend that you employ load balancing whenever you can, and as appropriate for your services.
Following are scenarios at both the Azure virtual network level and the global level, along with load-balancing
options for each.
Scenario : You have an application that:
Requires requests from the same user/client session to reach the same back-end virtual machine. Examples
of this are shopping cart apps and web mail servers.
Accepts only a secure connection, so unencrypted communication to the server is not an acceptable option.
Requires multiple HTTP requests on the same long-running TCP connection to be routed or load balanced to
different back-end servers.
Load-balancing option : Use Azure Application Gateway, an HTTP web traffic load balancer. Application
Gateway supports end-to-end TLS encryption and TLS termination at the gateway. Web servers can then be
unburdened from encryption and decryption overhead and traffic flowing unencrypted to the back-end servers.
Scenario : You need to load balance incoming connections from the internet among your servers located in an
Azure virtual network. Scenarios are when you:
Have stateless applications that accept incoming requests from the internet.
Don't require sticky sessions or TLS offload. Sticky sessions is a method used with Application Load
Balancing, to achieve server-affinity.
Load-balancing option : Use the Azure portal to create an external load balancer that spreads incoming
requests across multiple VMs to provide a higher level of availability.
Scenario : You need to load balance connections from VMs that are not on the internet. In most cases, the
connections that are accepted for load balancing are initiated by devices on an Azure virtual network, such as
SQL Server instances or internal web servers.
Load-balancing option : Use the Azure portal to create an internal load balancer that spreads incoming
requests across multiple VMs to provide a higher level of availability.
Scenario : You need global load balancing because you:
Have a cloud solution that is widely distributed across multiple regions and requires the highest level of
uptime (availability) possible.
Need the highest level of uptime possible to make sure that your service is available even if an entire
datacenter becomes unavailable.
Load-balancing option : Use Azure Traffic Manager. Traffic Manager makes it possible to load balance
connections to your services based on the location of the user.
For example, if the user makes a request to your service from the EU, the connection is directed to your services
located in an EU datacenter. This part of Traffic Manager global load balancing helps to improve performance
because connecting to the nearest datacenter is faster than connecting to datacenters that are far away.
Disable RDP/SSH Access to virtual machines
It's possible to reach Azure virtual machines by using Remote Desktop Protocol (RDP) and the Secure Shell
(SSH) protocol. These protocols enable the management VMs from remote locations and are standard in
datacenter computing.
The potential security problem with using these protocols over the internet is that attackers can use brute force
techniques to gain access to Azure virtual machines. After the attackers gain access, they can use your VM as a
launch point for compromising other machines on your virtual network or even attack networked devices
outside Azure.
We recommend that you disable direct RDP and SSH access to your Azure virtual machines from the internet.
After direct RDP and SSH access from the internet is disabled, you have other options that you can use to access
these VMs for remote management.
Scenario : Enable a single user to connect to an Azure virtual network over the internet.
Option : Point-to-site VPN is another term for a remote access VPN client/server connection. After the point-to-
site connection is established, the user can use RDP or SSH to connect to any VMs located on the Azure virtual
network that the user connected to via point-to-site VPN. This assumes that the user is authorized to reach those
VMs.
Point-to-site VPN is more secure than direct RDP or SSH connections because the user has to authenticate twice
before connecting to a VM. First, the user needs to authenticate (and be authorized) to establish the point-to-site
VPN connection. Second, the user needs to authenticate (and be authorized) to establish the RDP or SSH
session.
Scenario : Enable users on your on-premises network to connect to VMs on your Azure virtual network.
Option : A site-to-site VPN connects an entire network to another network over the internet. You can use a site-
to-site VPN to connect your on-premises network to an Azure virtual network. Users on your on-premises
network connect by using the RDP or SSH protocol over the site-to-site VPN connection. You don't have to allow
direct RDP or SSH access over the internet.
Scenario : Use a dedicated WAN link to provide functionality similar to the site-to-site VPN.
Option : Use ExpressRoute. It provides functionality similar to the site-to-site VPN. The main differences are:
The dedicated WAN link doesn't traverse the internet.
Dedicated WAN links are typically more stable and perform better.

Secure your critical Azure service resources to only your virtual


networks
Use Azure Private Link to access Azure PaaS Services (for example, Azure Storage and SQL Database) over
a private endpoint in your virtual network. Private Endpoints allow you to secure your critical Azure service
resources to only your virtual networks. Traffic from your virtual network to the Azure service always remains
on the Microsoft Azure backbone network. Exposing your virtual network to the public internet is no longer
necessary to consume Azure PaaS Services.
Azure Private Link provide the following benefits:
Improved security for your Azure ser vice resources : With Azure Private Link, Azure service resources
can be secured to your virtual network using private endpoint. Securing service resources to a private
endpoint in virtual network provides improved security by fully removing public internet access to resources,
and allowing traffic only from private endpoint in your virtual network.
Privately access Azure ser vice resources on the Azure platform : Connect your virtual network to
services in Azure using private endpoints. There is no need for a public IP address. The Private Link platform
will handle the connectivity between the consumer and services over the Azure backbone network.
Access from On-premises and peered networks : Access services running in Azure from on-premises
over ExpressRoute private peering, VPN tunnels, and peered virtual networks using private endpoints. There's
no need to configure ExpressRoute Microsoft peering or traverse the internet to reach the service. Private
Link provides a secure way to migrate workloads to Azure.
Protection against data leakage : A private endpoint is mapped to an instance of a PaaS resource instead
of the entire service. Consumers can only connect to the specific resource. Access to any other resource in
the service is blocked. This mechanism provides protection against data leakage risks.
Global reach : Connect privately to services running in other regions. The consumer's virtual network could
be in region A and it can connect to services in region B.
Simple to set up and manage : You no longer need reserved, public IP addresses in your virtual networks
to secure Azure resources through an IP firewall. There are no NAT or gateway devices required to set up the
private endpoints. Private endpoints are configured through a simple workflow. On service side, you can also
manage the connection requests on your Azure service resource with ease. Azure Private Link works for
consumers and services belonging to different Azure Active Directory tenants too.
To learn more about private endpoints and the Azure services and regions that private endpoints are available
for, see Azure Private Link.

Next steps
See Azure security best practices and patterns for more security best practices to use when you're designing,
deploying, and managing your cloud solutions by using Azure.
Fundamental best practices
12/12/2021 • 2 minutes to read • Edit Online

The following sections give prescriptive guidance to build DDoS-resilient services on Azure.

Design for security


Ensure that security is a priority throughout the entire lifecycle of an application, from design and
implementation to deployment and operations. Applications can have bugs that allow a relatively low volume of
requests to use an inordinate amount of resources, resulting in a service outage.
To help protect a service running on Microsoft Azure, you should have a good understanding of your application
architecture and focus on the five pillars of software quality. You should know typical traffic volumes, the
connectivity model between the application and other applications, and the service endpoints that are exposed
to the public internet.
Ensuring that an application is resilient enough to handle a denial of service that's targeted at the application
itself is most important. Security and privacy are built into the Azure platform, beginning with the Security
Development Lifecycle (SDL). The SDL addresses security at every development phase and ensures that Azure is
continually updated to make it even more secure.

Design for scalability


Scalability is how well a system can handle increased load. Design your applications to scale horizontally to
meet the demand of an amplified load, specifically in the event of a DDoS attack. If your application depends on
a single instance of a service, it creates a single point of failure. Provisioning multiple instances makes your
system more resilient and more scalable.
For Azure App Service, select an App Service plan that offers multiple instances. For Azure Cloud Services,
configure each of your roles to use multiple instances. For Azure Virtual Machines, ensure that your virtual
machine (VM) architecture includes more than one VM and that each VM is included in an availability set. We
recommend using virtual machine scale sets for autoscaling capabilities.

Defense in depth
The idea behind defense in depth is to manage risk by using diverse defensive strategies. Layering security
defenses in an application reduces the chance of a successful attack. We recommend that you implement secure
designs for your applications by using the built-in capabilities of the Azure platform.
For example, the risk of attack increases with the size (surface area) of the application. You can reduce the
surface area by using an approval list to close down the exposed IP address space and listening ports that are
not needed on the load balancers (Azure Load Balancer and Azure Application Gateway). Network security
groups (NSGs) are another way to reduce the attack surface. You can use service tags and application security
groups to minimize complexity for creating security rules and configuring network security, as a natural
extension of an application’s structure.
You should deploy Azure services in a virtual network whenever possible. This practice allows service resources
to communicate through private IP addresses. Azure service traffic from a virtual network uses public IP
addresses as source IP addresses by default. Using service endpoints will switch service traffic to use virtual
network private addresses as the source IP addresses when they're accessing the Azure service from a virtual
network.
We often see customers' on-premises resources getting attacked along with their resources in Azure. If you're
connecting an on-premises environment to Azure, we recommend that you minimize exposure of on-premises
resources to the public internet. You can use the scale and advanced DDoS protection capabilities of Azure by
deploying your well-known public entities in Azure. Because these publicly accessible entities are often a target
for DDoS attacks, putting them in Azure reduces the impact on your on-premises resources.

Next steps
Learn how to create a DDoS protection plan.
Prevent dangling DNS entries and avoid subdomain
takeover
12/12/2021 • 9 minutes to read • Edit Online

This article describes the common security threat of subdomain takeover and the steps you can take to mitigate
against it.

What is a subdomain takeover?


Subdomain takeovers are a common, high-severity threat for organizations that regularly create, and delete
many resources. A subdomain takeover can occur when you have a DNS record that points to a deprovisioned
Azure resource. Such DNS records are also known as "dangling DNS" entries. CNAME records are especially
vulnerable to this threat. Subdomain takeovers enable malicious actors to redirect traffic intended for an
organization’s domain to a site performing malicious activity.
A common scenario for a subdomain takeover:
1. CREATION:
a. You provision an Azure resource with a fully qualified domain name (FQDN) of
app-contogreat-dev-001.azurewebsites.net .

b. You assign a CNAME record in your DNS zone with the subdomain greatapp.contoso.com that
routes traffic to your Azure resource.
2. DEPROVISIONING:
a. The Azure resource is deprovisioned or deleted after it is no longer needed.
At this point, the CNAME record greatapp.contoso.com should be removed from your DNS zone. If
the CNAME record isn't removed, it's advertised as an active domain but doesn't route traffic to an
active Azure resource. This is the definition of a “dangling” DNS record.
b. The dangling subdomain, greatapp.contoso.com , is now vulnerable and can be taken over by being
assigned to another Azure subscription’s resource.
3. TAKEOVER:
a. Using commonly available methods and tools, a threat actor discovers the dangling subdomain.
b. The threat actor provisions an Azure resource with the same FQDN of the resource you previously
controlled. In this example, app-contogreat-dev-001.azurewebsites.net .
c. Traffic being sent to the subdomain greatapp.contoso.com is now routed to the malicious actor’s
resource where they control the content.
The risks of subdomain takeover
When a DNS record points to a resource that isn't available, the record itself should have been removed from
your DNS zone. If it hasn't been deleted, it's a “dangling DNS” record and creates the possibility for subdomain
takeover.
Dangling DNS entries make it possible for threat actors to take control of the associated DNS name to host a
malicious website or service. Malicious pages and services on an organization's subdomain might result in:
Loss of control over the content of the subdomain - Negative press about your organization's
inability to secure its content, as well as the brand damage and loss of trust.
Cookie har vesting from unsuspecting visitors - It's common for web apps to expose session
cookies to subdomains (*.contoso.com), consequently any subdomain can access them. Threat actors can
use subdomain takeover to build an authentic looking page, trick unsuspecting users to visit it, and
harvest their cookies (even secure cookies). A common misconception is that using SSL certificates
protects your site, and your users' cookies, from a takeover. However, a threat actor can use the hijacked
subdomain to apply for and receive a valid SSL certificate. Valid SSL certificates grant them access to
secure cookies and can further increase the perceived legitimacy of the malicious site.
Phishing campaigns - Authentic-looking subdomains might be used in phishing campaigns. This is
true for malicious sites and for MX records that would allow the threat actor to receive emails addressed
to a legitimate subdomain of a known-safe brand.
Fur ther risks - Malicious sites might be used to escalate into other classic attacks such as XSS, CSRF,
CORS bypass, and more.

Identify dangling DNS entries


To identify DNS entries within your organization that might be dangling, use Microsoft's GitHub-hosted
PowerShell tools "Get-DanglingDnsRecords".
This tool helps Azure customers list all domains with a CNAME associated to an existing Azure resource that was
created on their subscriptions or tenants.
If your CNAMEs are in other DNS services and point to Azure resources, provide the CNAMEs in an input file to
the tool.
The tool supports the Azure resources listed in the following table. The tool extracts, or takes as inputs, all the
tenant's CNAMEs.

SERVIC E TYPE F Q DN P RO P ERT Y EXA M P L E

Azure Front Door microsoft.network/frontdoo properties.cName abc.azurefd.net


rs

Azure Blob Storage microsoft.storage/storageac properties.primaryEndpoint abc.


counts s.blob blob.core.windows.net

Azure CDN microsoft.cdn/profiles/endp properties.hostName abc.azureedge.net


oints

Public IP addresses microsoft.network/publicipa properties.dnsSettings.fqdn abc.EastUs.cloudapp.azure.com


ddresses

Azure Traffic Manager microsoft.network/trafficma properties.dnsConfig.fqdn abc.trafficmanager.net


nagerprofiles

Azure Container Instance microsoft.containerinstance/ properties.ipAddress.fqdn abc.EastUs.azurecontainer.io


containergroups

Azure API Management microsoft.apimanagement/s properties.hostnameConfig abc.azure-api.net


ervice urations.hostName

Azure App Service microsoft.web/sites properties.defaultHostName abc.azurewebsites.net

Azure App Service - Slots microsoft.web/sites/slots properties.defaultHostName abc-


def.azurewebsites.net

Prerequisites
Run the query as a user who has:
at least reader level access to the Azure subscriptions
read access to Azure resource graph
If you're a global administrator of your organization’s tenant, elevate your account to have access to all of your
organization’s subscription using the guidance in Elevate access to manage all Azure subscriptions and
management groups.

TIP
Azure Resource Graph has throttling and paging limits that you should consider if you have a large Azure environment.
Learn more about working with large Azure resource data sets.
The tool uses subscription batching to avoid these limitations.

Run the script


Learn more about the PowerShell script, Get-DanglingDnsRecords.ps1 , and download it from GitHub:
https://aka.ms/Get-DanglingDnsRecords.
Remediate dangling DNS entries
Review your DNS zones and identify CNAME records that are dangling or have been taken over. If subdomains
are found to be dangling or have been taken over, remove the vulnerable subdomains and mitigate the risks
with the following steps:
1. From your DNS zone, remove all CNAME records that point to FQDNs of resources no longer
provisioned.
2. To enable traffic to be routed to resources in your control, provision additional resources with the FQDNs
specified in the CNAME records of the dangling subdomains.
3. Review your application code for references to specific subdomains and update any incorrect or outdated
subdomain references.
4. Investigate whether any compromise has occurred and take action per your organization’s incident
response procedures. Tips and best practices for investigating this issue can be found below.
If your application logic is such that secrets such as OAuth credentials were sent to the dangling
subdomain, or privacy-sensitive information was sent to the dangling subdomains, that data might have
been exposed to third-parties.
5. Understand why the CNAME record was not removed from your DNS zone when the resource was
deprovisioned and take steps to ensure that DNS records are updated appropriately when Azure
resources are deprovisioned in the future.

Prevent dangling DNS entries


Ensuring that your organization has implemented processes to prevent dangling DNS entries and the resulting
subdomain takeovers is a crucial part of your security program.
Some Azure services offer features to aid in creating preventative measures and are detailed below. Other
methods to prevent this issue must be established through your organization’s best practices or standard
operating procedures.
Enable Microsoft Defender for App Service
Microsoft Defender for Cloud's integrated cloud workload protection platform (CWPP), Microsoft Defender for
Cloud, offers a range of plans to protect your Azure, hybrid, and multi-cloud resources and workloads.
The Microsoft Defender for App Ser vice plan includes dangling DNS detection. With this plan enabled,
you'll get security alerts if you decommission an App Service website but don't remove its custom domain from
your DNS registrar.
Microsoft Defender for Cloud's dangling DNS protection is available whether your domains are managed with
Azure DNS or an external domain registrar and applies to App Service on both Windows and Linux.
Learn more about this and other benefits of this Microsoft Defender plans in Introduction to Microsoft Defender
for App Service.
Use Azure DNS alias records
Azure DNS's alias records can prevent dangling references by coupling the lifecycle of a DNS record with an
Azure resource. For example, consider a DNS record that's qualified as an alias record to point to a public IP
address or a Traffic Manager profile. If you delete those underlying resources, the DNS alias record becomes an
empty record set. It no longer references the deleted resource. It's important to note that there are limits to what
you can protect with alias records. Today, the list is limited to:
Azure Front Door
Traffic Manager profiles
Azure Content Delivery Network (CDN) endpoints
Public IPs
Despite the limited service offerings today, we recommend using alias records to defend against subdomain
takeover whenever possible.
Learn more about the capabilities of Azure DNS's alias records.
Use Azure App Service's custom domain verification
When creating DNS entries for Azure App Service, create an asuid.{subdomain} TXT record with the Domain
Verification ID. When such a TXT record exists, no other Azure Subscription can validate the Custom Domain that
is, take it over.
These records don't prevent someone from creating the Azure App Service with the same name that's in your
CNAME entry. Without the ability to prove ownership of the domain name, threat actors can't receive traffic or
control the content.
Learn more about how to map an existing custom DNS name to Azure App Service.
Build and automate processes to mitigate the threat
It's often up to developers and operations teams to run cleanup processes to avoid dangling DNS threats. The
practices below will help ensure your organization avoids suffering from this threat.
Create procedures for prevention:
Educate your application developers to reroute addresses whenever they delete resources.
Put "Remove DNS entry" on the list of required checks when decommissioning a service.
Put delete locks on any resources that have a custom DNS entry. A delete lock serves as an
indicator that the mapping must be removed before the resource is deprovisioned. Measures like
this can only work when combined with internal education programs.
Create procedures for discover y:
Review your DNS records regularly to ensure that your subdomains are all mapped to Azure
resources that:
Exist - Query your DNS zones for resources pointing to Azure subdomains such as
*.azurewebsites.net or *.cloudapp.azure.com (see the Reference list of Azure domains).
You own - Confirm that you own all resources that your DNS subdomains are targeting.
Maintain a service catalog of your Azure fully qualified domain name (FQDN) endpoints and the
application owners. To build your service catalog, run the following Azure Resource Graph query
script. This script projects the FQDN endpoint information of the resources you have access to and
outputs them in a CSV file. If you have access to all the subscriptions for your tenant, the script
considers all those subscriptions as shown in the following sample script. To limit the results to a
specific set of subscriptions, edit the script as shown.
Create procedures for remediation:
When dangling DNS entries are found, your team needs to investigate whether any compromise has
occurred.
Investigate why the address wasn't rerouted when the resource was decommissioned.
Delete the DNS record if it's no longer in use, or point it to the correct Azure resource (FQDN) owned
by your organization.
Next steps
To learn more about related services and Azure features you can use to defend against subdomain takeover, see
the following pages.
Enable Microsoft Defender for App Service - to receive alerts when dangling DNS entries are detected
Prevent dangling DNS records with Azure DNS
Use a domain verification ID when adding custom domains in Azure App Service
Quickstart: Run your first Resource Graph query using Azure PowerShell
Microsoft Antimalware for Azure Cloud Services
and Virtual Machines
12/12/2021 • 10 minutes to read • Edit Online

Microsoft Antimalware for Azure is a free real-time protection that helps identify and remove viruses, spyware,
and other malicious software. It generates alerts when known malicious or unwanted software tries to install
itself or run on your Azure systems.
The solution is built on the same antimalware platform as Microsoft Security Essentials [MSE], Microsoft
Forefront Endpoint Protection, Microsoft System Center Endpoint Protection, Microsoft Intune, and Microsoft
Defender for Cloud. Microsoft Antimalware for Azure is a single-agent solution for applications and tenant
environments, designed to run in the background without human intervention. Protection may be deployed
based on the needs of application workloads, with either basic secure-by-default or advanced custom
configuration, including antimalware monitoring.
When you deploy and enable Microsoft Antimalware for Azure for your applications, the following core features
are available:
Real-time protection - monitors activity in Cloud Services and on Virtual Machines to detect and block
malware execution.
Scheduled scanning - Scans periodically to detect malware, including actively running programs.
Malware remediation - automatically takes action on detected malware, such as deleting or quarantining
malicious files and cleaning up malicious registry entries.
Signature updates - automatically installs the latest protection signatures (virus definitions) to ensure
protection is up-to-date on a pre-determined frequency.
Antimalware Engine updates – automatically updates the Microsoft Antimalware engine.
Antimalware Platform updates – automatically updates the Microsoft Antimalware platform.
Active protection - reports telemetry metadata about detected threats and suspicious resources to
Microsoft Azure to ensure rapid response to the evolving threat landscape, as well as enabling real-time
synchronous signature delivery through the Microsoft Active Protection System (MAPS).
Samples repor ting - provides and reports samples to the Microsoft Antimalware service to help refine the
service and enable troubleshooting.
Exclusions – allows application and service administrators to configure exclusions for files, processes, and
drives.
Antimalware event collection - records the antimalware service health, suspicious activities, and
remediation actions taken in the operating system event log and collects them into the customer's Azure
Storage account.

NOTE
Microsoft Antimalware can also be deployed using Microsoft Defender for Cloud. Read Install Endpoint Protection in
Microsoft Defender for Cloud for more information.

Architecture
Microsoft Antimalware for Azure includes the Microsoft Antimalware Client and Service, Antimalware classic
deployment model, Antimalware PowerShell cmdlets, and Azure Diagnostics Extension. Microsoft Antimalware
is supported on Windows Server 2008 R2, Windows Server 2012, and Windows Server 2012 R2 operating
system families. It is not supported on the Windows Server 2008 operating system, and also is not supported in
Linux.
The Microsoft Antimalware Client and Service is installed by default in a disabled state in all supported Azure
guest operating system families in the Cloud Services platform. The Microsoft Antimalware Client and Service is
not installed by default in the Virtual Machines platform and is available as an optional feature through the
Azure portal and Visual Studio Virtual Machine configuration under Security Extensions.
When using Azure App Service on Windows, the underlying service that hosts the web app has Microsoft
Antimalware enabled on it. This is used to protect Azure App Service infrastructure and does not run on
customer content.

NOTE
Microsoft Defender for Cloud is the built-in Antimalware enabled in Windows Server 2016. The Microsoft Defender for
Cloud Interface is also enabled by default on some Windows Server 2016 SKU's see here for more information. The Azure
VM Antimalware extension can still be added to a Windows Server 2016 Azure VM with Microsoft Defender for Cloud,
but in this scenario the extension will apply any optional configuration policies to be used by Microsoft Defender for
Cloud, the extension will not deploy any additional antimalware services. You can read more about this update here.

Microsoft antimalware workflow


The Azure service administrator can enable Antimalware for Azure with a default or custom configuration for
your Virtual Machines and Cloud Services using the following options:
Virtual Machines – In the Azure portal, under Security Extensions
Virtual Machines – Using the Visual Studio virtual machines configuration in Server Explorer
Virtual Machines and Cloud Services – Using the Antimalware classic deployment model
Virtual Machines and Cloud Services – Using Antimalware PowerShell cmdlets
The Azure portal or PowerShell cmdlets push the Antimalware extension package file to the Azure system at a
pre-determined fixed location. The Azure Guest Agent (or the Fabric Agent) launches the Antimalware Extension,
applying the Antimalware configuration settings supplied as input. This step enables the Antimalware service
with either default or custom configuration settings. If no custom configuration is provided, then the
antimalware service is enabled with the default configuration settings. Refer to the Antimalware configuration
section in the Microsoft Antimalware for Azure – Code Samples for more details.
Once running, the Microsoft Antimalware client downloads the latest protection engine and signature
definitions from the Internet and loads them on the Azure system. The Microsoft Antimalware service writes
service-related events to the system OS events log under the "Microsoft Antimalware" event source. Events
include the Antimalware client health state, protection and remediation status, new and old configuration
settings, engine updates and signature definitions, and others.
You can enable Antimalware monitoring for your Cloud Service or Virtual Machine to have the Antimalware
event log events written as they are produced to your Azure storage account. The Antimalware Service uses the
Azure Diagnostics extension to collect Antimalware events from the Azure system into tables in the customer's
Azure Storage account.
The deployment workflow including configuration steps and options supported for the above scenarios are
documented in Antimalware deployment scenarios section of this document.
NOTE
You can however use Powershell/APIs and Azure Resource Manager templates to deploy Virtual Machine Scale Sets with
the Microsoft Anti-Malware extension. For installing an extension on an already running Virtual Machine, you can use the
sample python script vmssextn.py. This script gets the existing extension config on the Scale Set and adds an extension to
the list of existing extensions on the VM Scale Sets.

Default and Custom Antimalware Configuration


The default configuration settings are applied to enable Antimalware for Azure Cloud Services or Virtual
Machines when you do not provide custom configuration settings. The default configuration settings have been
pre-optimized for running in the Azure environment. Optionally, you can customize these default configuration
settings as required for your Azure application or service deployment and apply them for other deployment
scenarios.
The following table summarizes the configuration settings available for the Antimalware service. The default
configuration settings are marked under the column labeled "Default" below.
Antimalware Deployment Scenarios
The scenarios to enable and configure antimalware, including monitoring for Azure Cloud Services and Virtual
Machines, are discussed in this section.
Virtual machines - enable and configure antimalware
Deployment While creating a VM using the Azure portal
To enable and configure Microsoft Antimalware for Azure Virtual Machines using the Azure portal while
provisioning a Virtual Machine, follow the steps below:
1. Sign in to the Azure portal at https://portal.azure.com.
2. To create a new virtual machine, navigate to Vir tual machines , select Add , and choose Windows Ser ver .
3. Select the version of Windows server that you would like to use.
4. Select Create .

5. Provide a Name , Username , Password , and create a new resource group or choose an existing resource
group.
6. Select Ok .
7. Choose a vm size.
8. In the next section, make the appropriate choices for your needs select the Extensions section.
9. Select Add extension
10. Under New resource , choose Microsoft Antimalware .
11. Select Create
12. In the Install extension section file, locations, and process exclusions can be configured as well as other
scan options. Choose Ok .
13. Choose Ok .
14. Back in the Settings section, choose Ok .
15. In the Create screen, choose Ok .
See this Azure Resource Manager template for deployment of Antimalware VM extension for Windows.
Deployment using the Visual Studio virtual machine configuration
To enable and configure the Microsoft Antimalware service using Visual Studio:
1. Connect to Microsoft Azure in Visual Studio.
2. Choose your Virtual Machine in the Vir tual Machines node in Ser ver Explorer

3. Right-click configure to view the Virtual Machine configuration page


4. Select Microsoft Antimalware extension from the dropdown list under Installed Extensions and click
Add to configure with default antimalware configuration.

5. To customize the default Antimalware configuration, select (highlight) the Antimalware extension in the
installed extensions list and click Configure .
6. Replace the default Antimalware configuration with your custom configuration in supported JSON
format in the public configuration textbox and click OK.
7. Click the Update button to push the configuration updates to your Virtual Machine.

NOTE
The Visual Studio Virtual Machines configuration for Antimalware supports only JSON format configuration. The
Antimalware JSON configuration settings template is included in the Microsoft Antimalware For Azure - Code Samples,
showing the supported Antimalware configuration settings.
Deployment Using PowerShell cmdlets
An Azure application or service can enable and configure Microsoft Antimalware for Azure Virtual Machines
using PowerShell cmdlets.
To enable and configure Microsoft Antimalware using PowerShell cmdlets:
1. Set up your PowerShell environment - Refer to the documentation at https://github.com/Azure/azure-
powershell
2. Use the Set-AzureVMMicrosoftAntimalwareExtension cmdlet to enable and configure Microsoft Antimalware
for your Virtual Machine.

NOTE
The Azure Virtual Machines configuration for Antimalware supports only JSON format configuration. The Antimalware
JSON configuration settings template is included in the Microsoft Antimalware For Azure - Code Samples, showing the
supported Antimalware configuration settings.

Enable and Configure Antimalware Using PowerShell cmdlets


An Azure application or service can enable and configure Microsoft Antimalware for Azure Cloud Services using
PowerShell cmdlets. Note that Microsoft Antimalware is installed in a disabled state in the Cloud Services
platform and requires an action by an Azure application to enable it.
To enable and configure Microsoft Antimalware using PowerShell cmdlets:
1. Set up your PowerShell environment - Refer to the documentation at https://github.com/Azure/azure-
powershell
2. Use the Set-AzureServiceExtension cmdlet to enable and configure Microsoft Antimalware for your Cloud
Service.
The Antimalware XML configuration settings template is included in the Microsoft Antimalware For Azure -
Code Samples, showing the supported Antimalware configuration settings.
Cloud Services and Virtual Machines - Configuration Using PowerShell cmdlets
An Azure application or service can retrieve the Microsoft Antimalware configuration for Cloud Services and
Virtual Machines using PowerShell cmdlets.
To retrieve the Microsoft Antimalware configuration using PowerShell cmdlets:
1. Set up your PowerShell environment - Refer to the documentation at https://github.com/Azure/azure-
powershell
2. For Vir tual Machines : Use the Get-AzureVMMicrosoftAntimalwareExtension cmdlet to get the antimalware
configuration.
3. For Cloud Ser vices : Use the Get-AzureServiceExtension cmdlet to get the Antimalware configuration.
Remove Antimalware Configuration Using PowerShell cmdlets
An Azure application or service can remove the Antimalware configuration and any associated Antimalware
monitoring configuration from the relevant Azure Antimalware and diagnostics service extensions associated
with the Cloud Service or Virtual Machine.
To remove Microsoft Antimalware using PowerShell cmdlets:
1. Set up your PowerShell environment - Refer to the documentation at https://github.com/Azure/azure-
powershell
2. For Vir tual Machines : Use the Remove-AzureVMMicrosoftAntimalwareExtension cmdlet.
3. For Cloud Ser vices: Use the Remove-AzureServiceExtension cmdlet.
To enable antimalware event collection for a virtual machine using the Azure Preview Portal:
1. Click any part of the Monitoring lens in the Virtual Machine blade
2. Click the Diagnostics command on Metric blade
3. Select Status ON and check the option for Windows event system
4. . You can choose to uncheck all other options in the list, or leave them enabled per your application service
needs.
5. The Antimalware event categories "Error", "Warning", "Informational", etc., are captured in your Azure
Storage account.
Antimalware events are collected from the Windows event system logs to your Azure Storage account. You can
configure the Storage Account for your Virtual Machine to collect Antimalware events by selecting the
appropriate storage account.

Enable and configure Antimalware using PowerShell cmdlets for Azure Resource Manager VMs
To enable and configure Microsoft Antimalware for Azure Resource Manager VMs using using PowerShell
cmdlets:
1. Set up your PowerShell environment using this documentation on GitHub.
2. Use the Set-AzureRmVMExtension cmdlet to enable and configure Microsoft Antimalware for your VM.
The following code samples are available:
Deploy Microsoft Antimalware on ARM VMs
Add Microsoft Antimalware to Azure Service Fabric Clusters
Enable and configure Antimalware to Azure Cloud Service Extended Support (CS -ES ) using PowerShell
cmdlets
To enable and configure Microsoft Antimalware using PowerShell cmdlets:
1. Set up your PowerShell environment - Refer to the documentation at https://github.com/Azure/azure-
powershell
2. Use the New-AzCloudServiceExtensionObject cmdlet to enable and configure Microsoft Antimalware for
your Cloud Service VM.
The following code sample is available:
Add Microsoft Antimalware to Azure Cloud Service using Extended Support(CS-ES)
Enable and configure Antimalware using PowerShell cmdlets for Azure Arc-enabled servers
To enable and configure Microsoft Antimalware for Azure Arc-enabled servers using PowerShell cmdlets:
1. Set up your PowerShell environment using this documentation on GitHub.
2. Use the New-AzConnectedMachineExtension cmdlet to enable and configure Microsoft Antimalware for your
Arc-enabled servers.
The following code samples are available:
Add Microsoft Antimalware for Azure Arc-enabled servers

Next steps
See code samples to enable and configure Microsoft Antimalware for Azure Resource Manager (ARM) virtual
machines.
Enable and configure Microsoft Antimalware for
Azure Resource Manager VMs
12/12/2021 • 4 minutes to read • Edit Online

You can enable and configure Microsoft Antimalware for Azure Resource Manager VMs. This article provides
code samples using PowerShell cmdlets.

Deploy Microsoft Antimalware on Azure Resource Manager VMs


NOTE
Before executing this code sample, you must uncomment the variables and provide appropriate values.
# Script to add Microsoft Antimalware extension to Azure Resource Manager VMs
# Specify your subscription ID
$subscriptionId= " SUBSCRIPTION ID HERE "
# specify location, resource group, and VM for the extension
$location = " LOCATION HERE " # eg., “Southeast Asia” or “Central US”
$resourceGroupName = " RESOURCE GROUP NAME HERE "
$vmName = " VM NAME HERE "

# Enable Antimalware with default policies


$settingString = ‘{"AntimalwareEnabled": true}’;
# Enable Antimalware with custom policies
# $settingString = ‘{
# "AntimalwareEnabled": true,
# "RealtimeProtectionEnabled": true,
# "ScheduledScanSettings": {
# "isEnabled": true,
# "day": 0,
# "time": 120,
# "scanType": "Quick"
# },
# "Exclusions": {
# "Extensions": ".ext1,.ext2",
# "Paths":"",
# "Processes":"sampl1e1.exe, sample2.exe"
# },
# "SignatureUpdates": {
# "FileSharesSources": “”,
# "FallbackOrder”: “”,
# "ScheduleDay": 0,
# "UpdateInterval": 0,
# },
# "CloudProtection": true
#
# }’;
# Login to your Azure Resource Manager Account and select the Subscription to use
Login-AzureRmAccount

Select-AzureRmSubscription -SubscriptionId $subscriptionId


# retrieve the most recent version number of the extension
$allVersions= (Get-AzureRmVMExtensionImage -Location $location -PublisherName “Microsoft.Azure.Security” -
Type “IaaSAntimalware”).Version
$versionString = $allVersions[($allVersions.count)-1].Split(“.”)[0] + “.” +
$allVersions[($allVersions.count)-1].Split(“.”)[1]
# set the extension using prepared values
# ****—-Use this script till cmdlets address the -SettingsString format issue we observed ****—-
Set-AzureRmVMExtension -ResourceGroupName $resourceGroupName -Location $location -VMName $vmName -Name
"IaaSAntimalware" -Publisher “Microsoft.Azure.Security” -ExtensionType “IaaSAntimalware” -TypeHandlerVersion
$versionString -SettingString $settingString

Add Microsoft Antimalware to Azure Service Fabric Clusters


Azure Service Fabric uses Azure virtual machine scale sets to create the Service Fabric Clusters. Presently the
virtual machine scale sets template used for creating the Service Fabric Clusters is not enabled with the
Antimalware extension. As such, Antimalware needs to be enabled separately on the scale sets. As you enable it
on scale sets, all the nodes created under the virtual machine scale sets inherit and get the extension
automatically.
The code sample below shows how you can enable IaaS Antimalware extension using the AzureRmVmss
PowerShell cmdlets.
NOTE
Before executing this code sample, you must uncomment the variables and provide appropriate values.

# Script to add Microsoft Antimalware extension to VM Scale Set(VMSS) and Service Fabric Cluster(in turn it
used VMSS)
# Login to your Azure Resource Manager Account and select the Subscription to use
Login-AzureRmAccount
# Specify your subscription ID
$subscriptionId="SUBSCRIPTION ID HERE"
Select-AzureRmSubscription -SubscriptionId $subscriptionId
# Specify location, resource group, and VM Scaleset for the extension
$location = "LOCATION HERE" # eg., “West US or Southeast Asia” or “Central US”
$resourceGroupName = "RESOURCE GROUP NAME HERE"
$vmScaleSetName = "YOUR VM SCALE SET NAME"

# Configuration.JSON configuration file can be customized as per MSDN documentation:


https://msdn.microsoft.com/en-us/library/dn771716.aspx
$settingString = ‘{"AntimalwareEnabled": true}’;
# Enable Antimalware with custom policies
# $settingString = ‘{
# "AntimalwareEnabled": true,
# "RealtimeProtectionEnabled": true,
# "ScheduledScanSettings": {
# "isEnabled": true,
# "day": 0,
# "time": 120,
# "scanType": "Quick"
# },
# "Exclusions": {
# "Extensions": ".ext1,.ext2",
# "Paths":"",
# "Processes":"sampl1e1.exe, sample2.exe"
# } ,
# "SignatureUpdates": {
# "FileSharesSources": “”,
# "FallbackOrder”: “”,
# "ScheduleDay": 0,
# "UpdateInterval": 0,
# },
# "CloudProtection": true

# }’;

# retrieve the most recent version number of the extension


$allVersions= (Get-AzureRmVMExtensionImage -Location $location -PublisherName “Microsoft.Azure.Security” -
Type “IaaSAntimalware”).Version
$versionString = $allVersions[($allVersions.count)-1].Split(“.”)[0] + “.” +
$allVersions[($allVersions.count)-1].Split(“.”)[1]
$VMSS = Get-AzureRmVmss -ResourceGroupName $resourceGroupName -VMScaleSetName $vmScaleSetName
Add-AzureRmVmssExtension -VirtualMachineScaleSet $VMSS -Name “IaaSAntimalware” -Publisher
“Microsoft.Azure.Security” -Type “IaaSAntimalware” -TypeHandlerVersion $versionString
Update-AzureRmVmss -ResourceGroupName $resourceGroupName -Name $vmScaleSetName -VirtualMachineScaleSet $VMSS

Add Microsoft Antimalware to Azure Cloud Service using Extended


Support
The code sample below shows how you can add or configure Microsoft Antimalware to Azure Cloud Service
using extended support(CS-ES) via PowerShell cmdlets.
NOTE
Before executing this code sample, you must uncomment the variables and provide appropriate values.

# Create Antimalware extension object, where file is the AntimalwareSettings


$xmlconfig = [IO.File]::ReadAllText("C:\path\to\file.xml")
$extension = New-AzCloudServiceExtensionObject -Name "AntimalwareExtension" -Type "PaaSAntimalware" -
Publisher "Microsoft.Azure.Security" -Setting $xmlconfig -TypeHandlerVersion "1.5" -AutoUpgradeMinorVersion
$true

# Get existing Cloud Service


$cloudService = Get-AzCloudService -ResourceGroup "ContosOrg" -CloudServiceName "ContosoCS"

# Add Antimalaware extension to existing Cloud Service extension object


$cloudService.ExtensionProfile.Extension = $cloudService.ExtensionProfile.Extension + $extension

# Update Cloud Service


$cloudService | Update-AzCloudService

Here is an example of the private configuration XML file

<?xml version="1.0" encoding="utf-8"?>


<AntimalwareConfig
xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<AntimalwareEnabled>true</AntimalwareEnabled>
<RealtimeProtectionEnabled>true</RealtimeProtectionEnabled>
<ScheduledScanSettings isEnabled="true" day="1" time="120" scanType="Full" />
<Exclusions>
<Extensions>
<Extension>.ext1</Extension>
<Extension>.ext2</Extension>
</Extensions>
<Paths>
<Path>c:\excluded-path-1</Path>
<Path>c:\excluded-path-2</Path>
</Paths>
<Processes>
<Process>excludedproc1.exe</Process>
<Process>excludedproc2.exe</Process>
</Processes>
</Exclusions>
</AntimalwareConfig>

Add Microsoft Antimalware for Azure Arc-enabled servers


The code sample below shows how you can add Microsoft Antimalware for Azure Arc-enabled servers via
PowerShell cmdlets.

NOTE
Before executing this code sample, you must uncomment the variables and provide appropriate values.
#Before using Azure PowerShell to manage VM extensions on your hybrid server managed by Azure Arc-enabled
servers, you need to install the Az.ConnectedMachine module. Run the following command on your Azure Arc-
enabled server:
install-module -Name Az.ConnectedMachine
Import-Module -name Az.ConnectedMachine

# specify location, resource group, and VM for the extension


$subscriptionid =" SUBSCRIPTION ID HERE "
$location = " LOCATION HERE " # eg., “Southeast Asia” or “Central US”
$resourceGroupName = " RESOURCE GROUP NAME HERE "
$machineName = "MACHINE NAME HERE "

# Enable Antimalware with default policies


$settingString = ‘{"AntimalwareEnabled": true}’;
# Enable Antimalware with custom policies
# $settingString = ‘{
# "AntimalwareEnabled": true,
# "RealtimeProtectionEnabled": true,
# "ScheduledScanSettings": {
# "isEnabled": true,
# "day": 0,
# "time": 120,
# "scanType": "Quick"
# },
# "Exclusions": {
# "Extensions": ".ext1,.ext2",
# "Paths":"",
# "Processes":"sampl1e1.exe, sample2.exe"
# },
# "SignatureUpdates": {
# "FileSharesSources": “”,
# "FallbackOrder”: “”,
# "ScheduleDay": 0,
# "UpdateInterval": 0,
# },
# "CloudProtection": true
#
# }’;

# Will be prompted to login


Connect-AzAccount
# Enable Antimalware with the policies
New-AzConnectedMachineExtension -Name "IaaSAntimalware" -ResourceGroupName $resourceGroupName -MachineName
$machineName -Location $location -SubscriptionId $subscriptionid -Publisher “Microsoft.Azure.Security” -
Settings $settingString -ExtensionType “IaaSAntimalware”

Next steps
Learn more about Microsoft Antimalware for Azure.
Azure Virtual Machines security overview
12/12/2021 • 7 minutes to read • Edit Online

This article provides an overview of the core Azure security features that can be used with virtual machines.
You can use Azure Virtual Machines to deploy a wide range of computing solutions in an agile way. The service
supports Microsoft Windows, Linux, Microsoft SQL Server, Oracle, IBM, SAP, and Azure BizTalk Services. So you
can deploy any workload and any language on nearly any operating system.
An Azure virtual machine gives you the flexibility of virtualization without having to buy and maintain the
physical hardware that runs the virtual machine. You can build and deploy your applications with the assurance
that your data is protected and safe in highly secure datacenters.
With Azure, you can build security-enhanced, compliant solutions that:
Protect your virtual machines from viruses and malware.
Encrypt your sensitive data.
Secure network traffic.
Identify and detect threats.
Meet compliance requirements.

Antimalware
With Azure, you can use antimalware software from security vendors such as Microsoft, Symantec, Trend Micro,
and Kaspersky. This software helps protect your virtual machines from malicious files, adware, and other threats.
Microsoft Antimalware for Azure Cloud Services and Virtual Machines is a real-time protection capability that
helps identify and remove viruses, spyware, and other malicious software. Microsoft Antimalware for Azure
provides configurable alerts when known malicious or unwanted software attempts to install itself or run on
your Azure systems.
Microsoft Antimalware for Azure is a single-agent solution for applications and tenant environments. It's
designed to run in the background without human intervention. You can deploy protection based on the needs
of your application workloads, with either basic secure-by-default or advanced custom configuration, including
antimalware monitoring.
Learn more about Microsoft Antimalware for Azure and the core features available.
Learn more about antimalware software to help protect your virtual machines:
Deploying Antimalware Solutions on Azure Virtual Machines
How to install and configure Trend Micro Deep Security as a service on a Windows VM
How to install and configure Symantec Endpoint Protection on a Windows VM
Security solutions in the Azure Marketplace
For even more powerful protection, consider using Windows Defender Advanced Threat Protection. With
Windows Defender ATP, you get:
Attack surface reduction
Next generation protection
Endpoint protection and response
Automated investigation and remediation
Secure score
Advanced hunting
Management and APIs
Microsoft Threat Protection
Learn more:
Get Started with WDATP
Overview of WDATP capabilities

Hardware security module


Improving key security can enhance encryption and authentication protections. You can simplify the
management and security of your critical secrets and keys by storing them in Azure Key Vault.
Key Vault provides the option to store your keys in hardware security modules (HSMs) certified to FIPS 140-2
Level 2 standards. Your SQL Server encryption keys for backup or transparent data encryption can all be stored
in Key Vault with any keys or secrets from your applications. Permissions and access to these protected items
are managed through Azure Active Directory.
Learn more:
What is Azure Key Vault?
Azure Key Vault blog

Virtual machine disk encryption


Azure Disk Encryption is a new capability for encrypting your Windows and Linux virtual machine disks. Azure
Disk Encryption uses the industry-standard BitLocker feature of Windows and the dm-crypt feature of Linux to
provide volume encryption for the OS and the data disks.
The solution is integrated with Azure Key Vault to help you control and manage the disk encryption keys and
secrets in your key vault subscription. It ensures that all data in the virtual machine disks are encrypted at rest in
Azure Storage.
Learn more:
Azure Disk Encryption for IaaS VMs
Quickstart: Encrypt a Windows IaaS VM with Azure PowerShell

Virtual machine backup


Azure Backup is a scalable solution that helps protect your application data with zero capital investment and
minimal operating costs. Application errors can corrupt your data, and human errors can introduce bugs into
your applications. With Azure Backup, your virtual machines running Windows and Linux are protected.
Learn more:
What is Azure Backup?
Azure Backup service FAQ

Azure Site Recovery


An important part of your organization's BCDR strategy is figuring out how to keep corporate workloads and
apps running when planned and unplanned outages occur. Azure Site Recovery helps orchestrate replication,
failover, and recovery of workloads and apps so that they're available from a secondary location if your primary
location goes down.
Site Recovery:
Simplifies your BCDR strategy : Site Recovery makes it easy to handle replication, failover, and recovery
of multiple business workloads and apps from a single location. Site Recovery orchestrates replication and
failover but doesn't intercept your application data or have any information about it.
Provides flexible replication : By using Site Recovery, you can replicate workloads running on Hyper-V
virtual machines, VMware virtual machines, and Windows/Linux physical servers.
Suppor ts failover and recover y : Site Recovery provides test failovers to support disaster recovery drills
without affecting production environments. You can also run planned failovers with a zero-data loss for
expected outages, or unplanned failovers with minimal data loss (depending on replication frequency) for
unexpected disasters. After failover, you can fail back to your primary sites. Site Recovery provides recovery
plans that can include scripts and Azure automation workbooks so that you can customize failover and
recovery of multi-tier applications.
Eliminates secondar y datacenters : You can replicate to a secondary on-premises site, or to Azure. Using
Azure as a destination for disaster recovery eliminates the cost and complexity of maintaining a secondary
site. Replicated data is stored in Azure Storage.
Integrates with existing BCDR technologies : Site Recovery partners with other applications' BCDR
features. For example, you can use Site Recovery to help protect the SQL Server back end of corporate
workloads. This includes native support for SQL Server Always On to manage the failover of availability
groups.
Learn more:
What is Azure Site Recovery?
How does Azure Site Recovery work?
What workloads are protected by Azure Site Recovery?

Virtual networking
Virtual machines need network connectivity. To support that requirement, Azure requires virtual machines to be
connected to an Azure virtual network.
An Azure virtual network is a logical construct built on top of the physical Azure network fabric. Each logical
Azure virtual network is isolated from all other Azure virtual networks. This isolation helps insure that network
traffic in your deployments is not accessible to other Microsoft Azure customers.
Learn more:
Azure network security overview
Virtual Network overview
Networking features and partnerships for enterprise scenarios

Security policy management and reporting


Microsoft Defender for Cloud helps you prevent, detect, and respond to threats. Defender for Cloud gives you
increased visibility into, and control over, the security of your Azure resources. It provides integrated security
monitoring and policy management across your Azure subscriptions. It helps detect threats that might
otherwise go unnoticed, and works with a broad ecosystem of security solutions.
Defender for Cloud helps you optimize and monitor the security of your virtual machines by:
Providing security recommendations for the virtual machines. Example recommendations include: apply
system updates, configure ACLs endpoints, enable antimalware, enable network security groups, and apply
disk encryption.
Monitoring the state of your virtual machines.
Learn more:
Introduction to Microsoft Defender for Cloud
Microsoft Defender for Cloud frequently asked questions
Microsoft Defender for Cloud planning and operations

Compliance
Azure Virtual Machines is certified for FISMA, FedRAMP, HIPAA, PCI DSS Level 1, and other key compliance
programs. This certification makes it easier for your own Azure applications to meet compliance requirements
and for your business to address a wide range of domestic and international regulatory requirements.
Learn more:
Microsoft Trust Center: Compliance
Trusted Cloud: Microsoft Azure Security, Privacy, and Compliance

Confidential Computing
While confidential computing is not technically part of virtual machine security, the topic of virtual machine
security belongs to the higher-level subject of "compute" security. Confidential computing belongs within the
category of "compute" security.
Confidential computing ensures that when data is "in the clear," which is required for efficient processing, the
data is protected inside a Trusted Execution Environment
https://en.wikipedia.org/wiki/Trusted_execution_environment (TEE - also known as an enclave), an example of
which is shown in the figure below.
TEEs ensure there is no way to view data or the operations inside from the outside, even with a debugger. They
even ensure that only authorized code is permitted to access data. If the code is altered or tampered, the
operations are denied and the environment disabled. The TEE enforces these protections throughout the
execution of code within it.
Learn more:
Introducing Azure confidential computing
Azure confidential computing

Next steps
Learn about security best practices for VMs and operating systems.
Security best practices for IaaS workloads in Azure
12/12/2021 • 12 minutes to read • Edit Online

This article describes security best practices for VMs and operating systems.
The best practices are based on a consensus of opinion, and they work with current Azure platform capabilities
and feature sets. Because opinions and technologies can change over time, this article will be updated to reflect
those changes.
In most infrastructure as a service (IaaS) scenarios, Azure virtual machines (VMs) are the main workload for
organizations that use cloud computing. This fact is evident in hybrid scenarios where organizations want to
slowly migrate workloads to the cloud. In such scenarios, follow the general security considerations for IaaS, and
apply security best practices to all your VMs.

Protect VMs by using authentication and access control


The first step in protecting your VMs is to ensure that only authorized users can set up new VMs and access
VMs.

NOTE
To improve the security of Linux VMs on Azure, you can integrate with Azure AD authentication. When you use Azure AD
authentication for Linux VMs, you centrally control and enforce policies that allow or deny access to the VMs.

Best practice : Control VM access.


Detail : Use Azure policies to establish conventions for resources in your organization and create customized
policies. Apply these policies to resources, such as resource groups. VMs that belong to a resource group inherit
its policies.
If your organization has many subscriptions, you might need a way to efficiently manage access, policies, and
compliance for those subscriptions. Azure management groups provide a level of scope above subscriptions.
You organize subscriptions into management groups (containers) and apply your governance conditions to
those groups. All subscriptions within a management group automatically inherit the conditions applied to the
group. Management groups give you enterprise-grade management at a large scale no matter what type of
subscriptions you might have.
Best practice : Reduce variability in your setup and deployment of VMs.
Detail : Use Azure Resource Manager templates to strengthen your deployment choices and make it easier to
understand and inventory the VMs in your environment.
Best practice : Secure privileged access.
Detail : Use a least privilege approach and built-in Azure roles to enable users to access and set up VMs:
Virtual Machine Contributor: Can manage VMs, but not the virtual network or storage account to which they
are connected.
Classic Virtual Machine Contributor: Can manage VMs created by using the classic deployment model, but
not the virtual network or storage account to which the VMs are connected.
Security Admin: In Defender for Cloud only: Can view security policies, view security states, edit security
policies, view alerts and recommendations, dismiss alerts and recommendations.
DevTest Labs User: Can view everything and connect, start, restart, and shut down VMs.
Your subscription admins and coadmins can change this setting, making them administrators of all the VMs in a
subscription. Be sure that you trust all of your subscription admins and coadmins to log in to any of your
machines.

NOTE
We recommend that you consolidate VMs with the same lifecycle into the same resource group. By using resource
groups, you can deploy, monitor, and roll up billing costs for your resources.

Organizations that control VM access and setup improve their overall VM security.

Use multiple VMs for better availability


If your VM runs critical applications that need to have high availability, we strongly recommend that you use
multiple VMs. For better availability, use an availability set or availability zones.
An availability set is a logical grouping that you can use in Azure to ensure that the VM resources you place
within it are isolated from each other when they’re deployed in an Azure datacenter. Azure ensures that the VMs
you place in an availability set run across multiple physical servers, compute racks, storage units, and network
switches. If a hardware or Azure software failure occurs, only a subset of your VMs are affected, and your overall
application continues to be available to your customers. Availability sets are an essential capability when you
want to build reliable cloud solutions.

Protect against malware


You should install antimalware protection to help identify and remove viruses, spyware, and other malicious
software. You can install Microsoft Antimalware or a Microsoft partner’s endpoint protection solution (Trend
Micro, Broadcom, McAfee, Windows Defender, and System Center Endpoint Protection).
Microsoft Antimalware includes features like real-time protection, scheduled scanning, malware remediation,
signature updates, engine updates, samples reporting, and exclusion event collection. For environments that are
hosted separately from your production environment, you can use an antimalware extension to help protect
your VMs and cloud services.
You can integrate Microsoft Antimalware and partner solutions with Microsoft Defender for Cloud for ease of
deployment and built-in detections (alerts and incidents).
Best practice : Install an antimalware solution to protect against malware.
Detail : Install a Microsoft partner solution or Microsoft Antimalware
Best practice : Integrate your antimalware solution with Defender for Cloud to monitor the status of your
protection.
Detail : Manage endpoint protection issues with Defender for Cloud

Manage your VM updates


Azure VMs, like all on-premises VMs, are meant to be user managed. Azure doesn't push Windows updates to
them. You need to manage your VM updates.
Best practice : Keep your VMs current.
Detail : Use the Update Management solution in Azure Automation to manage operating system updates for
your Windows and Linux computers that are deployed in Azure, in on-premises environments, or in other cloud
providers. You can quickly assess the status of available updates on all agent computers and manage the
process of installing required updates for servers.
Computers that are managed by Update Management use the following configurations to perform assessment
and update deployments:
Microsoft Monitoring Agent (MMA) for Windows or Linux
PowerShell Desired State Configuration (DSC) for Linux
Automation Hybrid Runbook Worker
Microsoft Update or Windows Server Update Services (WSUS) for Windows computers
If you use Windows Update, leave the automatic Windows Update setting enabled.
Best practice : Ensure at deployment that images you built include the most recent round of Windows updates.
Detail : Check for and install all Windows updates as a first step of every deployment. This measure is especially
important to apply when you deploy images that come from either you or your own library. Although images
from the Azure Marketplace are updated automatically by default, there can be a lag time (up to a few weeks)
after a public release.
Best practice : Periodically redeploy your VMs to force a fresh version of the OS.
Detail : Define your VM with an Azure Resource Manager template so you can easily redeploy it. Using a
template gives you a patched and secure VM when you need it.
Best practice : Rapidly apply security updates to VMs.
Detail : Enable Microsoft Defender for Cloud (Free tier or Standard tier) to identify missing security updates and
apply them.
Best practice : Install the latest security updates.
Detail : Some of the first workloads that customers move to Azure are labs and external-facing systems. If your
Azure VMs host applications or services that need to be accessible to the internet, be vigilant about patching.
Patch beyond the operating system. Unpatched vulnerabilities on partner applications can also lead to problems
that can be avoided if good patch management is in place.
Best practice : Deploy and test a backup solution.
Detail : A backup needs to be handled the same way that you handle any other operation. This is true of systems
that are part of your production environment extending to the cloud.
Test and dev systems must follow backup strategies that provide restore capabilities that are similar to what
users have grown accustomed to, based on their experience with on-premises environments. Production
workloads moved to Azure should integrate with existing backup solutions when possible. Or, you can use Azure
Backup to help address your backup requirements.
Organizations that don't enforce software-update policies are more exposed to threats that exploit known,
previously fixed vulnerabilities. To comply with industry regulations, companies must prove that they are
diligent and using correct security controls to help ensure the security of their workloads located in the cloud.
Software-update best practices for a traditional datacenter and Azure IaaS have many similarities. We
recommend that you evaluate your current software update policies to include VMs located in Azure.

Manage your VM security posture


Cyberthreats are evolving. Safeguarding your VMs requires a monitoring capability that can quickly detect
threats, prevent unauthorized access to your resources, trigger alerts, and reduce false positives.
To monitor the security posture of your Windows and Linux VMs, use Microsoft Defender for Cloud. In Defender
for Cloud, safeguard your VMs by taking advantage of the following capabilities:
Apply OS security settings with recommended configuration rules.
Identify and download system security and critical updates that might be missing.
Deploy recommendations for endpoint antimalware protection.
Validate disk encryption.
Assess and remediate vulnerabilities.
Detect threats.
Defender for Cloud can actively monitor for threats, and potential threats are exposed in security alerts.
Correlated threats are aggregated in a single view called a security incident.
Defender for Cloud stores data in Azure Monitor logs. Azure Monitor logs provides a query language and
analytics engine that gives you insights into the operation of your applications and resources. Data is also
collected from Azure Monitor, management solutions, and agents installed on virtual machines in the cloud or
on-premises. This shared functionality helps you form a complete picture of your environment.
Organizations that don't enforce strong security for their VMs remain unaware of potential attempts by
unauthorized users to circumvent security controls.

Monitor VM performance
Resource abuse can be a problem when VM processes consume more resources than they should. Performance
issues with a VM can lead to service disruption, which violates the security principle of availability. This is
particularly important for VMs that are hosting IIS or other web servers, because high CPU or memory usage
might indicate a denial of service (DoS) attack. It’s imperative to monitor VM access not only reactively while an
issue is occurring, but also proactively against baseline performance as measured during normal operation.
We recommend that you use Azure Monitor to gain visibility into your resource’s health. Azure Monitor features:
Resource diagnostic log files: Monitors your VM resources and identifies potential issues that might
compromise performance and availability.
Azure Diagnostics extension: Provides monitoring and diagnostics capabilities on Windows VMs. You can
enable these capabilities by including the extension as part of the Azure Resource Manager template.
Organizations that don't monitor VM performance can’t determine whether certain changes in performance
patterns are normal or abnormal. A VM that’s consuming more resources than normal might indicate an attack
from an external resource or a compromised process running in the VM.

Encrypt your virtual hard disk files


We recommend that you encrypt your virtual hard disks (VHDs) to help protect your boot volume and data
volumes at rest in storage, along with your encryption keys and secrets.
Azure Disk Encryption helps you encrypt your Windows and Linux IaaS virtual machine disks. Azure Disk
Encryption uses the industry-standard BitLocker feature of Windows and the DM-Crypt feature of Linux to
provide volume encryption for the OS and the data disks. The solution is integrated with Azure Key Vault to help
you control and manage the disk-encryption keys and secrets in your key vault subscription. The solution also
ensures that all data on the virtual machine disks are encrypted at rest in Azure Storage.
Following are best practices for using Azure Disk Encryption:
Best practice : Enable encryption on VMs.
Detail : Azure Disk Encryption generates and writes the encryption keys to your key vault. Managing encryption
keys in your key vault requires Azure AD authentication. Create an Azure AD application for this purpose. For
authentication purposes, you can use either client secret-based authentication or client certificate-based Azure
AD authentication.
Best practice : Use a key encryption key (KEK) for an additional layer of security for encryption keys. Add a KEK
to your key vault.
Detail : Use the Add-AzKeyVaultKey cmdlet to create a key encryption key in the key vault. You can also import a
KEK from your on-premises hardware security module (HSM) for key management. For more information, see
the Key Vault documentation. When a key encryption key is specified, Azure Disk Encryption uses that key to
wrap the encryption secrets before writing to Key Vault. Keeping an escrow copy of this key in an on-premises
key management HSM offers additional protection against accidental deletion of keys.
Best practice : Take a snapshot and/or backup before disks are encrypted. Backups provide a recovery option if
an unexpected failure happens during encryption.
Detail : VMs with managed disks require a backup before encryption occurs. After a backup is made, you can
use the Set-AzVMDiskEncr yptionExtension cmdlet to encrypt managed disks by specifying the -
skipVmBackup parameter. For more information about how to back up and restore encrypted VMs, see the
Azure Backup article.
Best practice : To make sure the encryption secrets don’t cross regional boundaries, Azure Disk Encryption
needs the key vault and the VMs to be located in the same region.
Detail : Create and use a key vault that is in the same region as the VM to be encrypted.
When you apply Azure Disk Encryption, you can satisfy the following business needs:
IaaS VMs are secured at rest through industry-standard encryption technology to address organizational
security and compliance requirements.
IaaS VMs start under customer-controlled keys and policies, and you can audit their usage in your key vault.

Restrict direct internet connectivity


Monitor and restrict VM direct internet connectivity. Attackers constantly scan public cloud IP ranges for open
management ports and attempt “easy” attacks like common passwords and known unpatched vulnerabilities.
The following table lists best practices to help protect against these attacks:
Best practice : Prevent inadvertent exposure to network routing and security.
Detail : Use Azure RBAC to ensure that only the central networking group has permission to networking
resources.
Best practice : Identify and remediate exposed VMs that allow access from “any” source IP address.
Detail : Use Microsoft Defender for Cloud. Defender for Cloud will recommend that you restrict access through
internet-facing endpoints if any of your network security groups has one or more inbound rules that allow
access from “any” source IP address. Defender for Cloud will recommend that you edit these inbound rules to
restrict access to source IP addresses that actually need access.
Best practice : Restrict management ports (RDP, SSH).
Detail : Just-in-time (JIT) VM access can be used to lock down inbound traffic to your Azure VMs, reducing
exposure to attacks while providing easy access to connect to VMs when needed. When JIT is enabled, Defender
for Cloud locks down inbound traffic to your Azure VMs by creating a network security group rule. You select
the ports on the VM to which inbound traffic will be locked down. These ports are controlled by the JIT solution.

Next steps
See Azure security best practices and patterns for more security best practices to use when you’re designing,
deploying, and managing your cloud solutions by using Azure.
The following resources are available to provide more general information about Azure security and related
Microsoft services:
Azure Security Team Blog - for up to date information on the latest in Azure Security
Microsoft Security Response Center - where Microsoft security vulnerabilities, including issues with Azure,
can be reported or via email to secure@microsoft.com
Security Recommendations for Azure Marketplace
Images
12/12/2021 • 3 minutes to read • Edit Online

Your image must meet these security configuration recommendations. This helps maintain a high level of
security for partner solution images in the Azure Marketplace.
Always run a security vulnerability detection on your image prior to submitting. If you detect a security
vulnerability in your own published image, you must inform your customers in a timely manner of both the
vulnerability and how to correct it.

Open Source-based Images


C AT EGO RY C H EC K

Security Install all the latest security patches for the Linux
distribution.

Security Follow industry guidelines to secure the VM image for the


specific Linux distribution.

Security Limit the attack surface by keeping minimal footprint with


only necessary Windows Server roles, features, services, and
networking ports.

Security Scan source code and resulting VM image for malware.

Security The VHD image only includes necessary locked accounts


that do not have default passwords that would allow
interactive login; no back doors.

Security Disable firewall rules unless application functionally relies on


them, such as a firewall appliance.

Security Remove all sensitive information from the VHD image, such
as test SSH keys, known hosts file, log files, and unnecessary
certificates.

Security Avoid using LVM.

Security Include the latest versions of required libraries:


- OpenSSL v1.0 or greater
- Python 2.5 or above (Python 2.6+ is highly recommended)
- Python pyasn1 package if not already installed
- d.OpenSSL v 1.0 or greater

Security Clear Bash/Shell history entries.

Networking Include the SSH server by default. Set SSH keep alive to sshd
config with the following option: ClientAliveInterval 180.
C AT EGO RY C H EC K

Networking Remove any custom network configuration from the image.


Delete the resolv.conf: rm /etc/resolv.conf .

Deployment Install the latest Azure Linux Agent.


- Install using the RPM or Deb package.
- You may also use the manual install process, but the
installer packages are recommended and preferred.
- If installing the agent manually from the GitHub repository,
first copy the waagent file to /usr/sbin and run (as root):
# chmod 755 /usr/sbin/waagent
# /usr/sbin/waagent -install
The agent configuration file is placed at
/etc/waagent.conf .

Deployment Ensure Azure Support can provide our partners with serial
console output when needed and provide adequate timeout
for OS disk mounting from cloud storage. Add the following
parameters to the image Kernel Boot Line:
console=ttyS0 earlyprintk=ttyS0 rootdelay=300 .

Deployment No swap partition on the OS disk. Swap can be requested


for creation on the local resource disk by the Linux Agent.

Deployment Create a single root partition for the OS disk.

Deployment 64-bit operating system only.

Windows Server-based Images


C AT EGO RY C H EC K

Security Use a secure OS base image. The VHD used for the source of
any image based on Windows Server must be from the
Windows Server OS images provided through Microsoft
Azure.

Security Install all latest security updates.

Security Applications should not depend on restricted user names


like administrator, root, or admin.

Security Enable BitLocker Drive Encryption for both OS hard drives


and data hard drives.

Security Limit the attack surface by keeping minimal footprint with


only necessary Windows Server roles, features, services, and
networking ports enabled.

Security Scan source code and resulting VM image for malware.

Security Set Windows Server images security update to auto-update.


C AT EGO RY C H EC K

Security The VHD image only includes necessary locked accounts


that do not have default passwords that would allow
interactive login; no back doors.

Security Disable firewall rules unless application functionally relies on


them, such as a firewall appliance.

Security Remove all sensitive information from the VHD image,


including HOSTS files, log files, and unnecessary certificates.

Deployment 64-bit operating system only.

Even if your organization does not have images in the Azure marketplace, consider checking your Windows and
Linux image configurations against these recommendations.
Azure encryption overview
12/12/2021 • 12 minutes to read • Edit Online

This article provides an overview of how encryption is used in Microsoft Azure. It covers the major areas of
encryption, including encryption at rest, encryption in flight, and key management with Azure Key Vault. Each
section includes links to more detailed information.

Encryption of data at rest


Data at rest includes information that resides in persistent storage on physical media, in any digital format. The
media can include files on magnetic or optical media, archived data, and data backups. Microsoft Azure offers a
variety of data storage solutions to meet different needs, including file, disk, blob, and table storage. Microsoft
also provides encryption to protect Azure SQL Database, Azure Cosmos DB, and Azure Data Lake.
Data encryption at rest is available for services across the software as a service (SaaS), platform as a service
(PaaS), and infrastructure as a service (IaaS) cloud models. This article summarizes and provides resources to
help you use the Azure encryption options.
For a more detailed discussion of how data at rest is encrypted in Azure, see Azure Data Encryption-at-Rest.

Azure encryption models


Azure supports various encryption models, including server-side encryption that uses service-managed keys,
customer-managed keys in Key Vault, or customer-managed keys on customer-controlled hardware. With client-
side encryption, you can manage and store keys on-premises or in another secure location.
Client-side encryption
Client-side encryption is performed outside of Azure. It includes:
Data encrypted by an application that’s running in the customer’s datacenter or by a service application.
Data that is already encrypted when it is received by Azure.
With client-side encryption, cloud service providers don’t have access to the encryption keys and cannot decrypt
this data. You maintain complete control of the keys.
Server-side encryption
The three server-side encryption models offer different key management characteristics, which you can choose
according to your requirements:
Ser vice-managed keys : Provides a combination of control and convenience with low overhead.
Customer-managed keys : Gives you control over the keys, including Bring Your Own Keys (BYOK)
support, or allows you to generate new ones.
Ser vice-managed keys in customer-controlled hardware : Enables you to manage keys in your
proprietary repository, outside of Microsoft control. This characteristic is called Host Your Own Key
(HYOK). However, configuration is complex, and most Azure services don’t support this model.
Azure disk encryption
You can protect Windows and Linux virtual machines by using Azure disk encryption, which uses Windows
BitLocker technology and Linux DM-Crypt to protect both operating system disks and data disks with full
volume encryption.
Encryption keys and secrets are safeguarded in your Azure Key Vault subscription. By using the Azure Backup
service, you can back up and restore encrypted virtual machines (VMs) that use Key Encryption Key (KEK)
configuration.
Azure Storage Service Encryption
Data at rest in Azure Blob storage and Azure file shares can be encrypted in both server-side and client-side
scenarios.
Azure Storage Service Encryption (SSE) can automatically encrypt data before it is stored, and it automatically
decrypts the data when you retrieve it. The process is completely transparent to users. Storage Service
Encryption uses 256-bit Advanced Encryption Standard (AES) encryption, which is one of the strongest block
ciphers available. AES handles encryption, decryption, and key management transparently.
Client-side encryption of Azure blobs
You can perform client-side encryption of Azure blobs in various ways.
You can use the Azure Storage Client Library for .NET NuGet package to encrypt data within your client
applications prior to uploading it to your Azure storage.
To learn more about and download the Azure Storage Client Library for .NET NuGet package, see Windows
Azure Storage 8.3.0.
When you use client-side encryption with Key Vault, your data is encrypted using a one-time symmetric Content
Encryption Key (CEK) that is generated by the Azure Storage client SDK. The CEK is encrypted using a Key
Encryption Key (KEK), which can be either a symmetric key or an asymmetric key pair. You can manage it locally
or store it in Key Vault. The encrypted data is then uploaded to Azure Storage.
To learn more about client-side encryption with Key Vault and get started with how-to instructions, see Tutorial:
Encrypt and decrypt blobs in Azure Storage by using Key Vault.
Finally, you can also use the Azure Storage Client Library for Java to perform client-side encryption before you
upload data to Azure Storage, and to decrypt the data when you download it to the client. This library also
supports integration with Key Vault for storage account key management.
Encryption of data at rest with Azure SQL Database
Azure SQL Database is a general-purpose relational database service in Azure that supports structures such as
relational data, JSON, spatial, and XML. SQL Database supports both server-side encryption via the Transparent
Data Encryption (TDE) feature and client-side encryption via the Always Encrypted feature.
Transparent Data Encryption
TDE is used to encrypt SQL Server, Azure SQL Database, and Azure Synapse Analytics data files in real time,
using a Database Encryption Key (DEK), which is stored in the database boot record for availability during
recovery.
TDE protects data and log files, using AES and Triple Data Encryption Standard (3DES) encryption algorithms.
Encryption of the database file is performed at the page level. The pages in an encrypted database are encrypted
before they are written to disk and are decrypted when they’re read into memory. TDE is now enabled by
default on newly created Azure SQL databases.
Always Encrypted feature
With the Always Encrypted feature in Azure SQL you can encrypt data within client applications prior to storing
it in Azure SQL Database. You can also enable delegation of on-premises database administration to third
parties and maintain separation between those who own and can view the data and those who manage it but
should not have access to it.
Cell-level or column-level encryption
With Azure SQL Database, you can apply symmetric encryption to a column of data by using Transact-SQL. This
approach is called cell-level encryption or column-level encryption (CLE), because you can use it to encrypt
specific columns or even specific cells of data with different encryption keys. Doing so gives you more granular
encryption capability than TDE, which encrypts data in pages.
CLE has built-in functions that you can use to encrypt data by using either symmetric or asymmetric keys, the
public key of a certificate, or a passphrase using 3DES.
Cosmos DB database encryption
Azure Cosmos DB is Microsoft's globally distributed, multi-model database. User data that's stored in Cosmos
DB in non-volatile storage (solid-state drives) is encrypted by default. There are no controls to turn it on or off.
Encryption at rest is implemented by using a number of security technologies, including secure key storage
systems, encrypted networks, and cryptographic APIs. Encryption keys are managed by Microsoft and are
rotated per Microsoft internal guidelines. Optionally, you can choose to add a second layer of encryption with
keys you manage using the customer-managed keys or CMK feature.
At-rest encryption in Data Lake
Azure Data Lake is an enterprise-wide repository of every type of data collected in a single place prior to any
formal definition of requirements or schema. Data Lake Store supports "on by default," transparent encryption
of data at rest, which is set up during the creation of your account. By default, Azure Data Lake Store manages
the keys for you, but you have the option to manage them yourself.
Three types of keys are used in encrypting and decrypting data: the Master Encryption Key (MEK), Data
Encryption Key (DEK), and Block Encryption Key (BEK). The MEK is used to encrypt the DEK, which is stored on
persistent media, and the BEK is derived from the DEK and the data block. If you are managing your own keys,
you can rotate the MEK.

Encryption of data in transit


Azure offers many mechanisms for keeping data private as it moves from one location to another.
Data-link Layer encryption in Azure
Whenever Azure Customer traffic moves between datacenters-- outside physical boundaries not controlled by
Microsoft (or on behalf of Microsoft)-- a data-link layer encryption method using the IEEE 802.1AE MAC Security
Standards (also known as MACsec) is applied from point-to-point across the underlying network hardware. The
packets are encrypted and decrypted on the devices before being sent, preventing physical “man-in-the-middle”
or snooping/wiretapping attacks. Because this technology is integrated on the network hardware itself, it
provides line rate encryption on the network hardware with no measurable link latency increase. This MACsec
encryption is on by default for all Azure traffic traveling within a region or between regions, and no action is
required on customers’ part to enable.
TLS encryption in Azure
Microsoft gives customers the ability to use Transport Layer Security (TLS) protocol to protect data when it’s
traveling between the cloud services and customers. Microsoft datacenters negotiate a TLS connection with
client systems that connect to Azure services. TLS provides strong authentication, message privacy, and integrity
(enabling detection of message tampering, interception, and forgery), interoperability, algorithm flexibility, and
ease of deployment and use.
Perfect Forward Secrecy (PFS) protects connections between customers’ client systems and Microsoft cloud
services by unique keys. Connections also use RSA-based 2,048-bit encryption key lengths. This combination
makes it difficult for someone to intercept and access data that is in transit.
Azure Storage transactions
When you interact with Azure Storage through the Azure portal, all transactions take place over HTTPS. You can
also use the Storage REST API over HTTPS to interact with Azure Storage. You can enforce the use of HTTPS
when you call the REST APIs to access objects in storage accounts by enabling the secure transfer that's required
for the storage account.
Shared Access Signatures (SAS), which can be used to delegate access to Azure Storage objects, include an
option to specify that only the HTTPS protocol can be used when you use Shared Access Signatures. This
approach ensures that anybody who sends links with SAS tokens uses the proper protocol.
SMB 3.0, which used to access Azure Files shares, supports encryption, and it's available in Windows Server
2012 R2, Windows 8, Windows 8.1, and Windows 10. It allows cross-region access and even access on the
desktop.
Client-side encryption encrypts the data before it’s sent to your Azure Storage instance, so that it’s encrypted as
it travels across the network.
SMB encryption over Azure virtual networks
By using SMB 3.0 in VMs that are running Windows Server 2012 or later, you can make data transfers secure by
encrypting data in transit over Azure Virtual Networks. By encrypting data, you help protect against tampering
and eavesdropping attacks. Administrators can enable SMB encryption for the entire server, or just specific
shares.
By default, after SMB encryption is turned on for a share or server, only SMB 3.0 clients are allowed to access the
encrypted shares.

In-transit encryption in VMs


Data in transit to, from, and between VMs that are running Windows can be encrypted in a number of ways,
depending on the nature of the connection.
RDP sessions
You can connect and sign in to a VM by using the Remote Desktop Protocol (RDP) from a Windows client
computer, or from a Mac with an RDP client installed. Data in transit over the network in RDP sessions can be
protected by TLS.
You can also use Remote Desktop to connect to a Linux VM in Azure.
Secure access to Linux VMs with SSH
For remote management, you can use Secure Shell (SSH) to connect to Linux VMs running in Azure. SSH is an
encrypted connection protocol that allows secure sign-ins over unsecured connections. It is the default
connection protocol for Linux VMs hosted in Azure. By using SSH keys for authentication, you eliminate the
need for passwords to sign in. SSH uses a public/private key pair (asymmetric encryption) for authentication.

Azure VPN encryption


You can connect to Azure through a virtual private network that creates a secure tunnel to protect the privacy of
the data being sent across the network.
Azure VPN gateways
You can use an Azure VPN gateway to send encrypted traffic between your virtual network and your on-
premises location across a public connection, or to send traffic between virtual networks.
Site-to-site VPNs use IPsec for transport encryption. Azure VPN gateways use a set of default proposals. You can
configure Azure VPN gateways to use a custom IPsec/IKE policy with specific cryptographic algorithms and key
strengths, rather than the Azure default policy sets.
Point-to -site VPNs
Point-to-site VPNs allow individual client computers access to an Azure virtual network. The Secure Socket
Tunneling Protocol (SSTP) is used to create the VPN tunnel. It can traverse firewalls (the tunnel appears as an
HTTPS connection). You can use your own internal public key infrastructure (PKI) root certificate authority (CA)
for point-to-site connectivity.
You can configure a point-to-site VPN connection to a virtual network by using the Azure portal with certificate
authentication or PowerShell.
To learn more about point-to-site VPN connections to Azure virtual networks, see:
Configure a point-to-site connection to a virtual network by using certification authentication: Azure portal
Configure a point-to-site connection to a virtual network by using certificate authentication: PowerShell
Site -to -site VPNs
You can use a site-to-site VPN gateway connection to connect your on-premises network to an Azure virtual
network over an IPsec/IKE (IKEv1 or IKEv2) VPN tunnel. This type of connection requires an on-premises VPN
device that has an external-facing public IP address assigned to it.
You can configure a site-to-site VPN connection to a virtual network by using the Azure portal, PowerShell, or
Azure CLI.
For more information, see:
Create a site-to-site connection in the Azure portal
Create a site-to-site connection in PowerShell
Create a virtual network with a site-to-site VPN connection by using CLI

In-transit encryption in Data Lake


Data in transit (also known as data in motion) is also always encrypted in Data Lake Store. In addition to
encrypting data prior to storing it in persistent media, the data is also always secured in transit by using HTTPS.
HTTPS is the only protocol that is supported for the Data Lake Store REST interfaces.
To learn more about encryption of data in transit in Data Lake, see Encryption of data in Data Lake Store.

Key management with Key Vault


Without proper protection and management of the keys, encryption is rendered useless. Key Vault is the
Microsoft-recommended solution for managing and controlling access to encryption keys used by cloud
services. Permissions to access keys can be assigned to services or to users through Azure Active Directory
accounts.
Key Vault relieves organizations of the need to configure, patch, and maintain hardware security modules
(HSMs) and key management software. When you use Key Vault, you maintain control. Microsoft never sees
your keys, and applications don’t have direct access to them. You can also import or generate keys in HSMs.

Next steps
Azure security overview
Azure network security overview
Azure database security overview
Azure virtual machines security overview
Data encryption at rest
Data security and encryption best practices
Double encryption
12/12/2021 • 2 minutes to read • Edit Online

Double encryption is where two or more independent layers of encryption are enabled to protect against
compromises of any one layer of encryption. Using two layers of encryption mitigates threats that come with
encrypting data. For example:
Configuration errors in the data encryption
Implementation errors in the encryption algorithm
Compromise of a single encryption key
Azure provides double encryption for data at rest and data in transit.

Data at rest
Microsoft’s approach to enabling two layers of encryption for data at rest is:
Disk encr yption using customer-managed keys . You provide your own key for disk encryption. You can
bring your own keys to your Key Vault (BYOK – Bring Your Own Key), or generate new keys in Azure Key
Vault to encrypt the desired resources.
Infrastructure encr yption using platform-managed keys . By default, disks are automatically encrypted
at rest using platform-managed encryption keys.

Data in transit
Microsoft’s approach to enabling two layers of encryption for data in transit is:
Transit encr yption using Transpor t Layer Security (TLS) 1.2 to protect data when it’s traveling
between the cloud ser vices and you . All traffic leaving a datacenter is encrypted in transit, even if the
traffic destination is another domain controller in the same region. TLS 1.2 is the default security protocol
used. TLS provides strong authentication, message privacy, and integrity (enabling detection of message
tampering, interception, and forgery), interoperability, algorithm flexibility, and ease of deployment and use.
Additional layer of encr yption provided at the infrastructure layer . A data-link layer encryption
method using the IEEE 802.1AE MAC Security Standards (also known as MACsec) is applied from point-to-
point across the underlying network hardware. Whenever Azure Customer traffic moves between
datacenters-- outside physical boundaries not controlled by Microsoft (or on behalf of Microsoft)-- The
packets are encrypted and decrypted on the devices before being sent, preventing physical “man-in-the-
middle” or snooping/wiretapping attacks. Because this technology is integrated on the network hardware
itself, it provides line rate encryption on the network hardware with no measurable link latency increase. This
MACsec encryption is on by default for all Azure traffic traveling within a region or between regions, and no
action is required on customers’ part to enable.

Next steps
Learn how encryption is used in Azure.
Azure TLS certificate changes
12/12/2021 • 3 minutes to read • Edit Online

Microsoft is updating Azure services to use TLS certificates from a different set of Root Certificate Authorities
(CAs). This change is being made because the current CA certificates do not comply with one of the CA/Browser
Forum Baseline requirements and will be revoked on February 15, 2021.

When will this change happen?


Existing Azure endpoints have been transitioning in a phased manner since August 13, 2020. All newly created
Azure TLS/SSL endpoints contain updated certificates chaining up to the new Root CAs.
All Azure services are impacted by this change. Here are some more details for specific services:
Azure Active Directory (Azure AD) services began this transition on July 7, 2020.
Azure IoT Hub and DPS will remain on Baltimore CyberTrust Root CA but their intermediate CAs will change.
Click here for details.
For Azure Storage, click here for details.
Azure Cache for Redis will remain on Baltimore CyberTrust Root CA but their intermediate CAs will change.
Click here for details.
For Azure Instance Metadata Service, see Azure Instance Metadata Service-Attested data TLS: Critical changes
are almost here! for details.

IMPORTANT
Customers may need to update their application(s) after this change to prevent connectivity failures when attempting to
connect to Azure Storage. https://techcommunity.microsoft.com/t5/azure-storage/azure-storage-tls-critical-changes-are-
almost-here-and-why-you/ba-p/2741581

What is changing?
Today, most of the TLS certificates used by Azure services chain up to the following Root CA:

C OMMON NAME OF T H E C A T H UM B P RIN T ( SH A 1)

Baltimore CyberTrust Root d4de20d05e66fc53fe1a50882c78db2852cae474

TLS certificates used by Azure services will chain up to one of the following Root CAs:

C OMMON NAME OF T H E C A T H UM B P RIN T ( SH A 1)

DigiCert Global Root G2 df3c24f9bfd666761b268073fe06d1cc8d4f82a4

DigiCert Global Root CA a8985d3a65e5e5c4b2d7d66d40c6dd2fb19c5436

Baltimore CyberTrust Root d4de20d05e66fc53fe1a50882c78db2852cae474

D-TRUST Root Class 3 CA 2 2009 58e8abb0361533fb80f79b1b6d29d3ff8d5f00f0


C OMMON NAME OF T H E C A T H UM B P RIN T ( SH A 1)

Microsoft RSA Root Certificate Authority 2017 73a5e64a3bff8316ff0edccc618a906e4eae4d74

Microsoft ECC Root Certificate Authority 2017 999a64c37ff47d9fab95f14769891460eec4c3c5

When can I retire the old intermediate thumbprint?


The current CA certificates will not be revoked until February 15, 2021. After that date you can remove the old
thumbprints from your code.
If this date changes, you will be notified of the new revocation date.

Will this change affect me?


We expect that most Azure customers will not be impacted. However, your application may be impacted if it
explicitly specifies a list of acceptable CAs. This practice is known as certificate pinning.
Here are some ways to detect if your application is impacted:
Search your source code for the thumbprint, Common Name, and other cert properties of any of the
Microsoft IT TLS CAs found here. If there is a match, then your application will be impacted. To resolve this
problem, update the source code include the new CAs. As a best practice, ensure that CAs can be added
or edited on short notice. Industry regulations require CA certificates to be replaced within seven days
and hence customers relying on pinning need to react swiftly.
If you have an application that integrates with Azure APIs or other Azure services and you are unsure if it
uses certificate pinning, check with the application vendor.
Different operating systems and language runtimes that communicate with Azure services may require
more steps to correctly build the certificate chain with these new roots:
Linux : Many distributions require you to add CAs to /etc/ssl/certs. For specific instructions, refer to
the distribution’s documentation.
Java : Ensure that the Java key store contains the CAs listed above.
Windows running in disconnected environments : Systems running in disconnected
environments will need to have the new roots added to the Trusted Root Certification Authorities
store, and the intermediates added to the Intermediate Certification Authorities store.
Android : Check the documentation for your device and version of Android.
Other hardware devices, especially IoT : Contact the device manufacturer.
If you have an environment where firewall rules are set to allow outbound calls to only specific Certificate
Revocation List (CRL) download and/or Online Certificate Status Protocol (OCSP) verification locations.
You will need to allow the following CRL and OCSP URLs:
http://crl3.digicert.com
http://crl4.digicert.com
http://ocsp.digicert.com
http://www.d-trust.net
http://root-c3-ca2-2009.ocsp.d-trust.net
http://crl.microsoft.com
http://oneocsp.microsoft.com
http://ocsp.msocsp.com
http://www.microsoft.com/pkiops
Next steps
If you have additional questions, contact us through support.
Azure data security and encryption best practices
12/12/2021 • 9 minutes to read • Edit Online

This article describes best practices for data security and encryption.
The best practices are based on a consensus of opinion, and they work with current Azure platform capabilities
and feature sets. Opinions and technologies change over time and this article is updated on a regular basis to
reflect those changes.

Protect data
To help protect data in the cloud, you need to account for the possible states in which your data can occur, and
what controls are available for that state. Best practices for Azure data security and encryption relate to the
following data states:
At rest: This includes all information storage objects, containers, and types that exist statically on physical
media, whether magnetic or optical disk.
In transit: When data is being transferred between components, locations, or programs, it’s in transit.
Examples are transfer over the network, across a service bus (from on-premises to cloud and vice-versa,
including hybrid connections such as ExpressRoute), or during an input/output process.

Choose a key management solution


Protecting your keys is essential to protecting your data in the cloud.
Azure Key Vault helps safeguard cryptographic keys and secrets that cloud applications and services use. Key
Vault streamlines the key management process and enables you to maintain control of keys that access and
encrypt your data. Developers can create keys for development and testing in minutes, and then migrate them
to production keys. Security administrators can grant (and revoke) permission to keys, as needed.
You can use Key Vault to create multiple secure containers, called vaults. These vaults are backed by HSMs.
Vaults help reduce the chances of accidental loss of security information by centralizing the storage of
application secrets. Key vaults also control and log the access to anything stored in them. Azure Key Vault can
handle requesting and renewing Transport Layer Security (TLS) certificates. It provides features for a robust
solution for certificate lifecycle management.
Azure Key Vault is designed to support application keys and secrets. Key Vault is not intended to be a store for
user passwords.
Following are security best practices for using Key Vault.
Best practice : Grant access to users, groups, and applications at a specific scope.
Detail : Use Azure RBAC predefined roles. For example, to grant access to a user to manage key vaults, you
would assign the predefined role Key Vault Contributor to this user at a specific scope. The scope in this case
would be a subscription, a resource group, or just a specific key vault. If the predefined roles don’t fit your needs,
you can define your own roles.
Best practice : Control what users have access to.
Detail : Access to a key vault is controlled through two separate interfaces: management plane and data plane.
The management plane and data plane access controls work independently.
Use Azure RBAC to control what users have access to. For example, if you want to grant an application access to
use keys in a key vault, you only need to grant data plane access permissions by using key vault access policies,
and no management plane access is needed for this application. Conversely, if you want a user to be able to read
vault properties and tags but not have any access to keys, secrets, or certificates, you can grant this user read
access by using Azure RBAC, and no access to the data plane is required.
Best practice : Store certificates in your key vault. Your certificates are of high value. In the wrong hands, your
application's security or the security of your data can be compromised.
Detail : Azure Resource Manager can securely deploy certificates stored in Azure Key Vault to Azure VMs when
the VMs are deployed. By setting appropriate access policies for the key vault, you also control who gets access
to your certificate. Another benefit is that you manage all your certificates in one place in Azure Key Vault. See
Deploy Certificates to VMs from customer-managed Key Vault for more information.
Best practice : Ensure that you can recover a deletion of key vaults or key vault objects.
Detail : Deletion of key vaults or key vault objects can be inadvertent or malicious. Enable the soft delete and
purge protection features of Key Vault, particularly for keys that are used to encrypt data at rest. Deletion of
these keys is equivalent to data loss, so you can recover deleted vaults and vault objects if needed. Practice Key
Vault recovery operations on a regular basis.

NOTE
If a user has contributor permissions (Azure RBAC) to a key vault management plane, they can grant themselves access to
the data plane by setting a key vault access policy. We recommend that you tightly control who has contributor access to
your key vaults, to ensure that only authorized persons can access and manage your key vaults, keys, secrets, and
certificates.

Manage with secure workstations


NOTE
The subscription administrator or owner should use a secure access workstation or a privileged access workstation.

Because the vast majority of attacks target the end user, the endpoint becomes one of the primary points of
attack. An attacker who compromises the endpoint can use the user’s credentials to gain access to the
organization’s data. Most endpoint attacks take advantage of the fact that users are administrators in their local
workstations.
Best practice : Use a secure management workstation to protect sensitive accounts, tasks, and data.
Detail : Use a privileged access workstation to reduce the attack surface in workstations. These secure
management workstations can help you mitigate some of these attacks and ensure that your data is safer.
Best practice : Ensure endpoint protection.
Detail : Enforce security policies across all devices that are used to consume data, regardless of the data location
(cloud or on-premises).

Protect data at rest


Data encryption at rest is a mandatory step toward data privacy, compliance, and data sovereignty.
Best practice : Apply disk encryption to help safeguard your data.
Detail : Use Azure Disk Encryption. It enables IT administrators to encrypt Windows and Linux IaaS VM disks.
Disk Encryption combines the industry-standard Windows BitLocker feature and the Linux dm-crypt feature to
provide volume encryption for the OS and the data disks.
Azure Storage and Azure SQL Database encrypt data at rest by default, and many services offer encryption as an
option. You can use Azure Key Vault to maintain control of keys that access and encrypt your data. See Azure
resource providers encryption model support to learn more.
Best practices : Use encryption to help mitigate risks related to unauthorized data access.
Detail : Encrypt your drives before you write sensitive data to them.
Organizations that don’t enforce data encryption are more exposed to data-confidentiality issues. For example,
unauthorized or rogue users might steal data in compromised accounts or gain unauthorized access to data
coded in Clear Format. Companies also must prove that they are diligent and using correct security controls to
enhance their data security in order to comply with industry regulations.

Protect data in transit


Protecting data in transit should be an essential part of your data protection strategy. Because data is moving
back and forth from many locations, we generally recommend that you always use SSL/TLS protocols to
exchange data across different locations. In some circumstances, you might want to isolate the entire
communication channel between your on-premises and cloud infrastructures by using a VPN.
For data moving between your on-premises infrastructure and Azure, consider appropriate safeguards such as
HTTPS or VPN. When sending encrypted traffic between an Azure virtual network and an on-premises location
over the public internet, use Azure VPN Gateway.
Following are best practices specific to using Azure VPN Gateway, SSL/TLS, and HTTPS.
Best practice : Secure access from multiple workstations located on-premises to an Azure virtual network.
Detail : Use site-to-site VPN.
Best practice : Secure access from an individual workstation located on-premises to an Azure virtual network.
Detail : Use point-to-site VPN.
Best practice : Move larger data sets over a dedicated high-speed WAN link.
Detail : Use ExpressRoute. If you choose to use ExpressRoute, you can also encrypt the data at the application
level by using SSL/TLS or other protocols for added protection.
Best practice : Interact with Azure Storage through the Azure portal.
Detail : All transactions occur via HTTPS. You can also use Storage REST API over HTTPS to interact with Azure
Storage.
Organizations that fail to protect data in transit are more susceptible to man-in-the-middle attacks,
eavesdropping, and session hijacking. These attacks can be the first step in gaining access to confidential data.

Secure email, documents, and sensitive data


You want to control and secure email, documents, and sensitive data that you share outside your company.
Azure Information Protection is a cloud-based solution that helps an organization to classify, label, and protect
its documents and emails. This can be done automatically by administrators who define rules and conditions,
manually by users, or a combination where users get recommendations.
Classification is identifiable at all times, regardless of where the data is stored or with whom it’s shared. The
labels include visual markings such as a header, footer, or watermark. Metadata is added to files and email
headers in clear text. The clear text ensures that other services, such as solutions to prevent data loss, can
identify the classification and take appropriate action.
The protection technology uses Azure Rights Management (Azure RMS). This technology is integrated with
other Microsoft cloud services and applications, such as Microsoft 365 and Azure Active Directory. This
protection technology uses encryption, identity, and authorization policies. Protection that is applied through
Azure RMS stays with the documents and emails, independently of the location—inside or outside your
organization, networks, file servers, and applications.
This information protection solution keeps you in control of your data, even when it’s shared with other people.
You can also use Azure RMS with your own line-of-business applications and information protection solutions
from software vendors, whether these applications and solutions are on-premises or in the cloud.
We recommend that you:
Deploy Azure Information Protection for your organization.
Apply labels that reflect your business requirements. For example: Apply a label named “highly confidential”
to all documents and emails that contain top-secret data, to classify and protect this data. Then, only
authorized users can access this data, with any restrictions that you specify.
Configure usage logging for Azure RMS so that you can monitor how your organization is using the
protection service.
Organizations that are weak on data classification and file protection might be more susceptible to data leakage
or data misuse. With proper file protection, you can analyze data flows to gain insight into your business, detect
risky behaviors and take corrective measures, track access to documents, and so on.

Next steps
See Azure security best practices and patterns for more security best practices to use when you’re designing,
deploying, and managing your cloud solutions by using Azure.
The following resources are available to provide more general information about Azure security and related
Microsoft services:
Azure Security Team Blog - for up to date information on the latest in Azure Security
Microsoft Security Response Center - where Microsoft security vulnerabilities, including issues with Azure,
can be reported or via email to secure@microsoft.com
Azure Data Encryption at rest
12/12/2021 • 11 minutes to read • Edit Online

Microsoft Azure includes tools to safeguard data according to your company's security and compliance needs.
This paper focuses on:
How data is protected at rest across Microsoft Azure
Discusses the various components taking part in the data protection implementation,
Reviews pros and cons of the different key management protection approaches.
Encryption at Rest is a common security requirement. In Azure, organizations can encrypt data at rest without
the risk or cost of a custom key management solution. Organizations have the option of letting Azure
completely manage Encryption at Rest. Additionally, organizations have various options to closely manage
encryption or encryption keys.

What is encryption at rest?


Encryption is the secure encoding of data used to protect confidentiality of data. The Encryption at Rest designs
in Azure use symmetric encryption to encrypt and decrypt large amounts of data quickly according to a simple
conceptual model:
A symmetric encryption key is used to encrypt data as it is written to storage.
The same encryption key is used to decrypt that data as it is readied for use in memory.
Data may be partitioned, and different keys may be used for each partition.
Keys must be stored in a secure location with identity-based access control and audit policies. Data
encryption keys which are stored outside of secure locations are encrypted with a key encryption key kept in
a secure location.
In practice, key management and control scenarios, as well as scale and availability assurances, require
additional constructs. Microsoft Azure Encryption at Rest concepts and components are described below.

The purpose of encryption at rest


Encryption at rest provides data protection for stored data (at rest). Attacks against data at-rest include attempts
to obtain physical access to the hardware on which the data is stored, and then compromise the contained data.
In such an attack, a server's hard drive may have been mishandled during maintenance allowing an attacker to
remove the hard drive. Later the attacker would put the hard drive into a computer under their control to
attempt to access the data.
Encryption at rest is designed to prevent the attacker from accessing the unencrypted data by ensuring the data
is encrypted when on disk. If an attacker obtains a hard drive with encrypted data but not the encryption keys,
the attacker must defeat the encryption to read the data. This attack is much more complex and resource
consuming than accessing unencrypted data on a hard drive. For this reason, encryption at rest is highly
recommended and is a high priority requirement for many organizations.
Encryption at rest may also be required by an organization's need for data governance and compliance efforts.
Industry and government regulations such as HIPAA, PCI and FedRAMP, lay out specific safeguards regarding
data protection and encryption requirements. Encryption at rest is a mandatory measure required for
compliance with some of those regulations. For more information on Microsoft's approach to FIPS 140-2
validation, see Federal Information Processing Standard (FIPS) Publication 140-2.
In addition to satisfying compliance and regulatory requirements, encryption at rest provides defense-in-depth
protection. Microsoft Azure provides a compliant platform for services, applications, and data. It also provides
comprehensive facility and physical security, data access control, and auditing. However, it's important to
provide additional "overlapping" security measures in case one of the other security measures fails and
encryption at rest provides such a security measure.
Microsoft is committed to encryption at rest options across cloud services and giving customers control of
encryption keys and logs of key use. Additionally, Microsoft is working towards encrypting all customer data at
rest by default.

Azure Encryption at Rest Components


As described previously, the goal of encryption at rest is that data that is persisted on disk is encrypted with a
secret encryption key. To achieve that goal secure key creation, storage, access control, and management of the
encryption keys must be provided. Though details may vary, Azure services Encryption at Rest implementations
can be described in terms illustrated in the following diagram.

Azure Key Vault


The storage location of the encryption keys and access control to those keys is central to an encryption at rest
model. The keys need to be highly secured but manageable by specified users and available to specific services.
For Azure services, Azure Key Vault is the recommended key storage solution and provides a common
management experience across services. Keys are stored and managed in key vaults, and access to a key vault
can be given to users or services. Azure Key Vault supports customer creation of keys or import of customer
keys for use in customer-managed encryption key scenarios.
Azure Active Directory
Permissions to use the keys stored in Azure Key Vault, either to manage or to access them for Encryption at Rest
encryption and decryption, can be given to Azure Active Directory accounts.
Envelope Encryption with a Key Hierarchy
More than one encryption key is used in an encryption at rest implementation. Storing an encryption key in
Azure Key Vault ensures secure key access and central management of keys. However, service local access to
encryption keys is more efficient for bulk encryption and decryption than interacting with Key Vault for every
data operation, allowing for stronger encryption and better performance. Limiting the use of a single encryption
key decreases the risk that the key will be compromised and the cost of re-encryption when a key must be
replaced. Azure encryption at rest models use envelope encryption, where a key encryption key encrypts a data
encryption key. This model forms a key hierarchy which is better able to address performance and security
requirements:
Data Encr yption Key (DEK) – A symmetric AES256 key used to encrypt a partition or block of data,
sometimes also referred to as simply a Data Key. A single resource may have many partitions and many Data
Encryption Keys. Encrypting each block of data with a different key makes crypto analysis attacks more
difficult. And keeping DEKs local to the service encrypting and decrypting data maximizes performance.
Key Encr yption Key (KEK) – An encryption key used to encrypt the Data Encryption Keys using envelope
encryption, also referred to as wrapping. Use of a Key Encryption Key that never leaves Key Vault allows the
data encryption keys themselves to be encrypted and controlled. The entity that has access to the KEK may
be different than the entity that requires the DEK. An entity may broker access to the DEK to limit the access
of each DEK to a specific partition. Since the KEK is required to decrypt the DEKs, customers can
cryptographically erase DEKs and data by disabling of the KEK.
Resource providers and application instances store the encrypted Data Encryption Keys as metadata. Only an
entity with access to the Key Encryption Key can decrypt these Data Encryption Keys. Different models of key
storage are supported. For more information, see data encryption models.

Encryption at rest in Microsoft cloud services


Microsoft Cloud services are used in all three cloud models: IaaS, PaaS, SaaS. Below you have examples of how
they fit on each model:
Software services, referred to as Software as a Server or SaaS, which have applications provided by the cloud
such as Microsoft 365.
Platform services in which customers use the cloud for things like storage, analytics, and service bus
functionality in their applications.
Infrastructure services, or Infrastructure as a Service (IaaS) in which customer deploys operating systems and
applications that are hosted in the cloud and possibly leveraging other cloud services.
Encryption at rest for SaaS customers
Software as a Service (SaaS) customers typically have encryption at rest enabled or available in each service.
Microsoft 365 has several options for customers to verify or enable encryption at rest. For information about
Microsoft 365 services, see Encryption in Microsoft 365.
Encryption at rest for PaaS customers
Platform as a Service (PaaS) customer's data typically resides in a storage service such as Blob Storage but may
also be cached or stored in the application execution environment, such as a virtual machine. To see the
encryption at rest options available to you, examine the Data encryption models: supporting services table for
the storage and application platforms that you use.
Encryption at rest for IaaS customers
Infrastructure as a Service (IaaS) customers can have a variety of services and applications in use. IaaS services
can enable encryption at rest in their Azure hosted virtual machines and VHDs using Azure Disk Encryption.
Encrypted storage
Like PaaS, IaaS solutions can leverage other Azure services that store data encrypted at rest. In these cases, you
can enable the Encryption at Rest support as provided by each consumed Azure service. The Data encryption
models: supporting services table enumerates the major storage, services, and application platforms and the
model of Encryption at Rest supported.
Encrypted compute
All Managed Disks, Snapshots, and Images are encrypted using Storage Service Encryption using a service-
managed key. A more complete Encryption at Rest solution ensures that the data is never persisted in
unencrypted form. While processing the data on a virtual machine, data can be persisted to the Windows page
file or Linux swap file, a crash dump, or to an application log. To ensure this data is encrypted at rest, IaaS
applications can use Azure Disk Encryption on an Azure IaaS virtual machine (Windows or Linux) and virtual
disk.
Custom encryption at rest
It is recommended that whenever possible, IaaS applications leverage Azure Disk Encryption and Encryption at
Rest options provided by any consumed Azure services. In some cases, such as irregular encryption
requirements or non-Azure based storage, a developer of an IaaS application may need to implement
encryption at rest themselves. Developers of IaaS solutions can better integrate with Azure management and
customer expectations by leveraging certain Azure components. Specifically, developers should use the Azure
Key Vault service to provide secure key storage as well as provide their customers with consistent key
management options with that of most Azure platform services. Additionally, custom solutions should use
Azure-Managed Service Identities to enable service accounts to access encryption keys. For developer
information on Azure Key Vault and Managed Service Identities, see their respective SDKs.

Azure resource providers encryption model support


Microsoft Azure Services each support one or more of the encryption at rest models. For some services,
however, one or more of the encryption models may not be applicable. For services that support customer-
managed key scenarios, they may support only a subset of the key types that Azure Key Vault supports for key
encryption keys. Additionally, services may release support for these scenarios and key types at different
schedules. This section describes the encryption at rest support at the time of this writing for each of the major
Azure data storage services.
Azure disk encryption
Any customer using Azure Infrastructure as a Service (IaaS) features can achieve encryption at rest for their IaaS
VMs and disks through Azure Disk Encryption. For more information on Azure Disk encryption, see the Azure
Disk Encryption documentation.
Azure storage
All Azure Storage services (Blob storage, Queue storage, Table storage, and Azure Files) support server-side
encryption at rest; some services additionally support customer-managed keys and client-side encryption.
Server-side: All Azure Storage Services enable server-side encryption by default using service-managed
keys, which is transparent to the application. For more information, see Azure Storage Service Encryption for
Data at Rest. Azure Blob storage and Azure Files also support RSA 2048-bit customer-managed keys in Azure
Key Vault. For more information, see Storage Service Encryption using customer-managed keys in Azure Key
Vault.
Client-side: Azure Blobs, Tables, and Queues support client-side encryption. When using client-side
encryption, customers encrypt the data and upload the data as an encrypted blob. Key management is done
by the customer. For more information, see Client-Side Encryption and Azure Key Vault for Microsoft Azure
Storage.
Azure SQL Database
Azure SQL Database currently supports encryption at rest for Microsoft-managed service side and client-side
encryption scenarios.
Support for server encryption is currently provided through the SQL feature called Transparent Data Encryption.
Once an Azure SQL Database customer enables TDE key are automatically created and managed for them.
Encryption at rest can be enabled at the database and server levels. As of June 2017, Transparent Data
Encryption (TDE) is enabled by default on newly created databases. Azure SQL Database supports RSA 2048-bit
customer-managed keys in Azure Key Vault. For more information, see Transparent Data Encryption with Bring
Your Own Key support for Azure SQL Database and Data Warehouse.
Client-side encryption of Azure SQL Database data is supported through the Always Encrypted feature. Always
Encrypted uses a key that created and stored by the client. Customers can store the master key in a Windows
certificate store, Azure Key Vault, or a local Hardware Security Module. Using SQL Server Management Studio,
SQL users choose what key they'd like to use to encrypt which column.
Conclusion
Protection of customer data stored within Azure Services is of paramount importance to Microsoft. All Azure
hosted services are committed to providing Encryption at Rest options. Azure services support either service-
managed keys, customer-managed keys, or client-side encryption. Azure services are broadly enhancing
Encryption at Rest availability and new options are planned for preview and general availability in the upcoming
months.

Next steps
See data encryption models to learn more about service-managed keys and customer-managed keys.
Learn how Azure uses double encryption to mitigate threats that come with encrypting data.
Learn what Microsoft does to ensure platform integrity and security of hosts traversing the hardware and
firmware build-out, integration, operationalization, and repair pipelines.
Data encryption models
12/12/2021 • 10 minutes to read • Edit Online

An understanding of the various encryption models and their pros and cons is essential for understanding how
the various resource providers in Azure implement encryption at Rest. These definitions are shared across all
resource providers in Azure to ensure common language and taxonomy.
There are three scenarios for server-side encryption:
Server-side encryption using Service-Managed keys
Azure Resource Providers perform the encryption and decryption operations
Microsoft manages the keys
Full cloud functionality
Server-side encryption using customer-managed keys in Azure Key Vault
Azure Resource Providers perform the encryption and decryption operations
Customer controls keys via Azure Key Vault
Full cloud functionality
Server-side encryption using customer-managed keys on customer-controlled hardware
Azure Resource Providers perform the encryption and decryption operations
Customer controls keys on customer-controlled hardware
Full cloud functionality
Server-side Encryption models refer to encryption that is performed by the Azure service. In that model, the
Resource Provider performs the encrypt and decrypt operations. For example, Azure Storage may receive data
in plain text operations and will perform the encryption and decryption internally. The Resource Provider might
use encryption keys that are managed by Microsoft or by the customer depending on the provided
configuration.

Each of the server-side encryption at rest models implies distinctive characteristics of key management. This
includes where and how encryption keys are created, and stored as well as the access models and the key
rotation procedures.
For client-side encryption, consider the following:
Azure services cannot see decrypted data
Customers manage and store keys on-premises (or in other secure stores). Keys are not available to Azure
services
Reduced cloud functionality
The supported encryption models in Azure split into two main groups: "Client Encryption" and "Server-side
Encryption" as mentioned previously. Independent of the encryption at rest model used, Azure services always
recommend the use of a secure transport such as TLS or HTTPS. Therefore, encryption in transport should be
addressed by the transport protocol and should not be a major factor in determining which encryption at rest
model to use.

Client encryption model


Client Encryption model refers to encryption that is performed outside of the Resource Provider or Azure by the
service or calling application. The encryption can be performed by the service application in Azure, or by an
application running in the customer data center. In either case, when leveraging this encryption model, the Azure
Resource Provider receives an encrypted blob of data without the ability to decrypt the data in any way or have
access to the encryption keys. In this model, the key management is done by the calling service/application and
is opaque to the Azure service.

Server-side encryption using service-managed keys


For many customers, the essential requirement is to ensure that the data is encrypted whenever it is at rest.
Server-side encryption using service-managed Keys enables this model by allowing customers to mark the
specific resource (Storage Account, SQL DB, etc.) for encryption and leaving all key management aspects such as
key issuance, rotation, and backup to Microsoft. Most Azure services that support encryption at rest typically
support this model of offloading the management of the encryption keys to Azure. The Azure resource provider
creates the keys, places them in secure storage, and retrieves them when needed. This means that the service
has full access to the keys and the service has full control over the credential lifecycle management.
Server-side encryption using service-managed keys therefore quickly addresses the need to have encryption at
rest with low overhead to the customer. When available a customer typically opens the Azure portal for the
target subscription and resource provider and checks a box indicating, they would like the data to be encrypted.
In some Resource Managers server-side encryption with service-managed keys is on by default.
Server-side encryption with Microsoft-managed keys does imply the service has full access to store and manage
the keys. While some customers may want to manage the keys because they feel they gain greater security, the
cost and risk associated with a custom key storage solution should be considered when evaluating this model. In
many cases, an organization may determine that resource constraints or risks of an on-premises solution may
be greater than the risk of cloud management of the encryption at rest keys. However, this model might not be
sufficient for organizations that have requirements to control the creation or lifecycle of the encryption keys or
to have different personnel manage a service's encryption keys than those managing the service (that is,
segregation of key management from the overall management model for the service).
Key access
When Server-side encryption with service-managed keys is used, the key creation, storage, and service access
are all managed by the service. Typically, the foundational Azure resource providers will store the Data
Encryption Keys in a store that is close to the data and quickly available and accessible while the Key Encryption
Keys are stored in a secure internal store.
Advantages
Simple setup
Microsoft manages key rotation, backup, and redundancy
Customer does not have the cost associated with implementation or the risk of a custom key management
scheme.
Disadvantages
No customer control over the encryption keys (key specification, lifecycle, revocation, etc.)
No ability to segregate key management from overall management model for the service
Server-side encryption using customer-managed keys in Azure Key
Vault
For scenarios where the requirement is to encrypt the data at rest and control the encryption keys customers
can use server-side encryption using customer-managed Keys in Key Vault. Some services may store only the
root Key Encryption Key in Azure Key Vault and store the encrypted Data Encryption Key in an internal location
closer to the data. In that scenario customers can bring their own keys to Key Vault (BYOK – Bring Your Own
Key), or generate new ones, and use them to encrypt the desired resources. While the Resource Provider
performs the encryption and decryption operations, it uses the configured key encryption key as the root key
for all encryption operations.
Loss of key encryption keys means loss of data. For this reason, keys should not be deleted. Keys should be
backed up whenever created or rotated. Soft-Delete and purge protection must be enabled on any vault storing
key encryption keys to protect against accidental or malicious cryptographic erasure. Instead of deleting a key, it
is recommended to set enabled to false on the key encryption key.
Key Access
The server-side encryption model with customer-managed keys in Azure Key Vault involves the service
accessing the keys to encrypt and decrypt as needed. Encryption at rest keys are made accessible to a service
through an access control policy. This policy grants the service identity access to receive the key. An Azure
service running on behalf of an associated subscription can be configured with an identity in that subscription.
The service can perform Azure Active Directory authentication and receive an authentication token identifying
itself as that service acting on behalf of the subscription. That token can then be presented to Key Vault to obtain
a key it has been given access to.
For operations using encryption keys, a service identity can be granted access to any of the following
operations: decrypt, encrypt, unwrapKey, wrapKey, verify, sign, get, list, update, create, import, delete, backup,
and restore.
To obtain a key for use in encrypting or decrypting data at rest the service identity that the Resource Manager
service instance will run as must have UnwrapKey (to get the key for decryption) and WrapKey (to insert a key
into key vault when creating a new key).

NOTE
For more detail on Key Vault authorization see the secure your key vault page in the Azure Key Vault documentation.

Advantages
Full control over the keys used – encryption keys are managed in the customer's Key Vault under the
customer's control.
Ability to encrypt multiple services to one master
Can segregate key management from overall management model for the service
Can define service and key location across regions
Disadvantages
Customer has full responsibility for key access management
Customer has full responsibility for key lifecycle management
Additional Setup & configuration overhead

Server-side encryption using customer-managed keys in customer-


controlled hardware
Some Azure services enable the Host Your Own Key (HYOK) key management model. This management mode is
useful in scenarios where there is a need to encrypt the data at rest and manage the keys in a proprietary
repository outside of Microsoft's control. In this model, the service must retrieve the key from an external site.
Performance and availability guarantees are impacted, and configuration is more complex. Additionally, since
the service does have access to the DEK during the encryption and decryption operations the overall security
guarantees of this model are similar to when the keys are customer-managed in Azure Key Vault. As a result, this
model is not appropriate for most organizations unless they have specific key management requirements. Due
to these limitations, most Azure services do not support server-side encryption using server-managed keys in
customer-controlled hardware.
Key Access
When server-side encryption using service-managed keys in customer-controlled hardware is used, the keys are
maintained on a system configured by the customer. Azure services that support this model provide a means of
establishing a secure connection to a customer supplied key store.
Advantages
Full control over the root key used – encryption keys are managed by a customer provided store
Ability to encrypt multiple services to one master
Can segregate key management from overall management model for the service
Can define service and key location across regions
Disadvantages
Full responsibility for key storage, security, performance, and availability
Full responsibility for key access management
Full responsibility for key lifecycle management
Significant setup, configuration, and ongoing maintenance costs
Increased dependency on network availability between the customer datacenter and Azure datacenters.

Supporting services
The Azure services that support each encryption model:

P RO DUC T, F EAT URE, O R SERVER- SIDE USIN G SERVER- SIDE USIN G C L IEN T - SIDE USIN G
SERVIC E SERVIC E- M A N A GED K EY C USTO M ER- M A N A GED K EY C L IEN T - M A N A GED K EY

AI and Machine
Learning

Azure Cognitive Search Yes Yes -

Azure Cognitive Services Yes Yes -

Azure Machine Learning Yes Yes -

Content Moderator Yes Yes -

Face Yes Yes -

Language Understanding Yes Yes -

Personalizer Yes Yes -


P RO DUC T, F EAT URE, O R SERVER- SIDE USIN G SERVER- SIDE USIN G C L IEN T - SIDE USIN G
SERVIC E SERVIC E- M A N A GED K EY C USTO M ER- M A N A GED K EY C L IEN T - M A N A GED K EY

QnA Maker Yes Yes -

Speech Services Yes Yes -

Translator Text Yes Yes -

Power BI Yes Yes, RSA 4096-bit -

Analytics

Azure Stream Analytics Yes Yes** -

Event Hubs Yes Yes -

Functions Yes Yes -

Azure Analysis Services Yes - -

Azure Data Catalog Yes - -

Azure HDInsight Yes All -

Azure Monitor Application Yes Yes -


Insights

Azure Monitor Log Yes Yes -


Analytics

Azure Data Explorer Yes Yes -

Azure Data Factory Yes Yes -

Azure Data Lake Store Yes Yes, RSA 2048-bit -

Containers

Azure Kubernetes Service Yes Yes -

Container Instances Yes Yes -

Container Registry Yes Yes -

Compute

Virtual Machines Yes Yes -

Virtual Machine Scale Set Yes Yes -

SAP HANA Yes Yes -


P RO DUC T, F EAT URE, O R SERVER- SIDE USIN G SERVER- SIDE USIN G C L IEN T - SIDE USIN G
SERVIC E SERVIC E- M A N A GED K EY C USTO M ER- M A N A GED K EY C L IEN T - M A N A GED K EY

App Service Yes Yes** -

Automation Yes Yes** -

Azure Functions Yes Yes** -

Azure portal Yes Yes** -

Logic Apps Yes Yes -

Azure-managed Yes Yes** -


applications

Service Bus Yes Yes -

Site Recovery Yes Yes -

Databases

SQL Server on Virtual Yes Yes Yes


Machines

Azure SQL Database Yes Yes, RSA 3072-bit Yes

Azure SQL Database for Yes - -


MariaDB

Azure SQL Database for Yes Yes -


MySQL

Azure SQL Database for Yes Yes -


PostgreSQL

Azure Synapse Analytics Yes Yes, RSA 3072-bit -

SQL Server Stretch Yes Yes, RSA 3072-bit Yes


Database

Table Storage Yes Yes Yes

Azure Cosmos DB Yes (learn more) Yes (learn more) -

Azure Databricks Yes Yes -

Azure Database Migration Yes N/A* -


Service

Identity

Azure Active Directory Yes - -


P RO DUC T, F EAT URE, O R SERVER- SIDE USIN G SERVER- SIDE USIN G C L IEN T - SIDE USIN G
SERVIC E SERVIC E- M A N A GED K EY C USTO M ER- M A N A GED K EY C L IEN T - M A N A GED K EY

Azure Active Directory Yes Yes -


Domain Services

Integration

Service Bus Yes Yes Yes

Event Grid Yes - -

API Management Yes - -

IoT Ser vices

IoT Hub Yes Yes Yes

IoT Hub Device Provisioning Yes Yes -

Management and
Governance

Azure Site Recovery Yes - -

Azure Migrate Yes Yes -

Media

Media Services Yes Yes Yes

Security

Microsoft Defender for IoT Yes Yes -

Microsoft Sentinel Yes Yes -

Storage

Blob Storage Yes Yes Yes

Premium Blob Storage Yes Yes Yes

Disk Storage Yes Yes -

Ultra Disk Storage Yes Yes -

Managed Disk Storage Yes Yes -

File Storage Yes Yes -

File Premium Storage Yes Yes -


P RO DUC T, F EAT URE, O R SERVER- SIDE USIN G SERVER- SIDE USIN G C L IEN T - SIDE USIN G
SERVIC E SERVIC E- M A N A GED K EY C USTO M ER- M A N A GED K EY C L IEN T - M A N A GED K EY

File Sync Yes Yes -

Queue Storage Yes Yes Yes

Avere vFXT Yes - -

Azure Cache for Redis Yes N/A* -

Azure NetApp Files Yes Yes -

Archive Storage Yes Yes -

StorSimple Yes Yes Yes

Azure Backup Yes Yes Yes

Data Box Yes - Yes

Data Box Edge Yes Yes -

* This service doesn't persist data. Transient caches, if any, are encrypted with a Microsoft key.
** This service supports storing data in your own Key Vault, Storage Account, or other data persisting service
that already supports Server-Side Encryption with Customer-Managed Key.

Next steps
Learn how encryption is used in Azure.
Learn how Azure uses double encryption to mitigate threats that come with encrypting data.
Azure Disk Encryption for virtual machines and
virtual machine scale sets
12/12/2021 • 2 minutes to read • Edit Online

Azure Disk encryption can be applied to both Linux and Windows virtual machines, as well as to virtual machine
scale sets.

Linux virtual machines


The following articles provide guidance for encrypting Linux virtual machines.
Current version of Azure Disk Encryption
Overview of Azure Disk Encryption for Linux virtual machines
Azure Disk Encryption scenarios on Linux VMs
Create and encrypt a Linux VM with Azure CLI
Create and encrypt a Linux VM with Azure PowerShell
Create and encrypt a Linux VM with the Azure portal
Azure Disk Encryption Extension Schema for Linux
Creating and configuring a key vault for Azure Disk Encryption
Azure Disk Encryption sample scripts
Azure Disk Encryption troubleshooting
Azure Disk Encryption frequently asked questions
Azure disk encryption with Azure AD (previous version)
Overview of Azure Disk Encryption with Azure AD for Linux virtual machines
Azure Disk Encryption with Azure AD scenarios on Linux VMs
Creating and configuring a key vault for Azure Disk Encryption with Azure AD (previous release)

Windows virtual machines


The following articles provide guidance for encrypting Windows virtual machines.
Current version of Azure Disk Encryption
Overview of Azure Disk Encryption for Windows virtual machines
Azure Disk Encryption scenarios on Windows VMs
Create and encrypt a Windows VM with Azure CLI
Create and encrypt a Windows VM with Azure PowerShell
Create and encrypt a Windows VM with the Azure portal
Azure Disk Encryption Extension Schema for Windows
Creating and configuring a key vault for Azure Disk Encryption
Azure Disk Encryption sample scripts
Azure Disk Encryption troubleshooting
Azure Disk Encryption frequently asked questions
Azure disk encryption with Azure AD (previous version)
Overview of Azure Disk Encryption with Azure AD for Windows virtual machines
Azure Disk Encryption with Azure AD scenarios on Windows VMs
Creating and configuring a key vault for Azure Disk Encryption with Azure AD (previous release)

Virtual machine scale sets


The following articles provide guidance for encrypting virtual machine scale sets.
Overview of Azure Disk Encryption for virtual machine scale sets
Encrypt a virtual machine scale sets using the Azure CLI
Encrypt a virtual machine scale sets using Azure Powershell.
Encrypt a virtual machine scale sets using the Azure Resource Manager
Create and configure a key vault for Azure Disk Encryption
Use Azure Disk Encryption with virtual machine scale set extension sequencing

Next steps
Azure encryption overview
Data encryption at rest
Data security and encryption best practices
An overview of Azure SQL Database and SQL
Managed Instance security capabilities
12/12/2021 • 9 minutes to read • Edit Online

APPLIES TO: Azure SQL Database Azure SQL Managed Instance Azure Synapse Analytics
This article outlines the basics of securing the data tier of an application using Azure SQL Database, Azure SQL
Managed Instance, and Azure Synapse Analytics. The security strategy described follows the layered defense-in-
depth approach as shown in the picture below, and moves from the outside in:

Network security
Microsoft Azure SQL Database, SQL Managed Instance, and Azure Synapse Analytics provide a relational
database service for cloud and enterprise applications. To help protect customer data, firewalls prevent network
access to the server until access is explicitly granted based on IP address or Azure Virtual network traffic origin.
IP firewall rules
IP firewall rules grant access to databases based on the originating IP address of each request. For more
information, see Overview of Azure SQL Database and Azure Synapse Analytics firewall rules.
Virtual network firewall rules
Virtual network service endpoints extend your virtual network connectivity over the Azure backbone and enable
Azure SQL Database to identify the virtual network subnet that traffic originates from. To allow traffic to reach
Azure SQL Database, use the SQL service tags to allow outbound traffic through Network Security Groups.
Virtual network rules enable Azure SQL Database to only accept communications that are sent from selected
subnets inside a virtual network.
NOTE
Controlling access with firewall rules does not apply to SQL Managed Instance . For more information about the
networking configuration needed, see Connecting to a managed instance

Access management
IMPORTANT
Managing databases and servers within Azure is controlled by your portal user account's role assignments. For more
information on this article, see Azure role-based access control in the Azure portal.

Authentication
Authentication is the process of proving the user is who they claim to be. Azure SQL Database and SQL
Managed Instance support two types of authentication:
SQL authentication :
SQL authentication refers to the authentication of a user when connecting to Azure SQL Database or
Azure SQL Managed Instance using username and password. A ser ver admin login with a username
and password must be specified when the server is being created. Using these credentials, a ser ver
admin can authenticate to any database on that server or instance as the database owner. After that,
additional SQL logins and users can be created by the server admin, which enable users to connect using
username and password.
Azure Active Director y authentication :
Azure Active Directory authentication is a mechanism of connecting to Azure SQL Database, Azure SQL
Managed Instance and Azure Synapse Analytics by using identities in Azure Active Directory (Azure AD).
Azure AD authentication allows administrators to centrally manage the identities and permissions of
database users along with other Azure services in one central location. This includes the minimization of
password storage and enables centralized password rotation policies.
A server admin called the Active Director y administrator must be created to use Azure AD
authentication with SQL Database. For more information, see Connecting to SQL Database By Using
Azure Active Directory Authentication. Azure AD authentication supports both managed and federated
accounts. The federated accounts support Windows users and groups for a customer domain federated
with Azure AD.
Additional Azure AD authentication options available are Active Directory Universal Authentication for
SQL Server Management Studio connections including Multi-Factor Authentication and Conditional
Access.

IMPORTANT
Managing databases and servers within Azure is controlled by your portal user account's role assignments. For more
information on this article, see Azure role-based access control in Azure portal. Controlling access with firewall rules does
not apply to SQL Managed Instance. Please see the following article on connecting to a managed instance for more
information about the networking configuration needed.

Authorization
Authorization refers to controlling access on resources and commands within a database. This is done by
assigning permissions to a user within a database in Azure SQL Database or Azure SQL Managed Instance.
Permissions are ideally managed by adding user accounts to database roles and assigning database-level
permissions to those roles. Alternatively an individual user can also be granted certain object-level permissions.
For more information, see Logins and users
As a best practice, create custom roles when needed. Add users to the role with the least privileges required to
do their job function. Do not assign permissions directly to users. The server admin account is a member of the
built-in db_owner role, which has extensive permissions and should only be granted to few users with
administrative duties. To further limit the scope of what a user can do, the EXECUTE AS can be used to specify
the execution context of the called module. Following these best practices is also a fundamental step towards
Separation of Duties.
Row-level security
Row-Level Security enables customers to control access to rows in a database table based on the characteristics
of the user executing a query (for example, group membership or execution context). Row-Level Security can
also be used to implement custom Label-based security concepts. For more information, see Row-Level security.

Threat protection
SQL Database and SQL Managed Instance secure customer data by providing auditing and threat detection
capabilities.
SQL auditing in Azure Monitor logs and Event Hubs
SQL Database and SQL Managed Instance auditing tracks database activities and helps maintain compliance
with security standards by recording database events to an audit log in a customer-owned Azure storage
account. Auditing allows users to monitor ongoing database activities, as well as analyze and investigate
historical activity to identify potential threats or suspected abuse and security violations. For more information,
see Get started with SQL Database Auditing.
Advanced Threat Protection
Advanced Threat Protection is analyzing your logs to detect unusual behavior and potentially harmful attempts
to access or exploit databases. Alerts are created for suspicious activities such as SQL injection, potential data
infiltration, and brute force attacks or for anomalies in access patterns to catch privilege escalations and
breached credentials use. Alerts are viewed from the Microsoft Defender for Cloud, where the details of the
suspicious activities are provided and recommendations for further investigation given along with actions to
mitigate the threat. Advanced Threat Protection can be enabled per server for an additional fee. For more
information, see Get started with SQL Database Advanced Threat Protection.
Information protection and encryption
Transport Layer Security (Encryption-in-transit)
SQL Database, SQL Managed Instance, and Azure Synapse Analytics secure customer data by encrypting data in
motion with Transport Layer Security (TLS).
SQL Database, SQL Managed Instance, and Azure Synapse Analytics enforce encryption (SSL/TLS) at all times
for all connections. This ensures all data is encrypted "in transit" between the client and server irrespective of
the setting of Encr ypt or TrustSer verCer tificate in the connection string.
As a best practice, recommend that in the connection string used by the application, you specify an encrypted
connection and not trust the server certificate. This forces your application to verify the server certificate and
thus prevents your application from being vulnerable to man in the middle type attacks.
For example when using the ADO.NET driver this is accomplished via Encr ypt=True and
TrustSer verCer tificate=False . If you obtain your connection string from the Azure portal, it will have the
correct settings.

IMPORTANT
Note that some non-Microsoft drivers may not use TLS by default or rely on an older version of TLS (<1.2) in order to
function. In this case the server still allows you to connect to your database. However, we recommend that you evaluate
the security risks of allowing such drivers and application to connect to SQL Database, especially if you store sensitive
data.
For further information about TLS and connectivity, see TLS considerations

Transparent Data Encryption (Encryption-at-rest)


Transparent data encryption (TDE) for SQL Database, SQL Managed Instance, and Azure Synapse Analytics adds
a layer of security to help protect data at rest from unauthorized or offline access to raw files or backups.
Common scenarios include data center theft or unsecured disposal of hardware or media such as disk drives
and backup tapes.TDE encrypts the entire database using an AES encryption algorithm, which doesn't require
application developers to make any changes to existing applications.
In Azure, all newly created databases are encrypted by default and the database encryption key is protected by a
built-in server certificate. Certificate maintenance and rotation are managed by the service and require no input
from the user. Customers who prefer to take control of the encryption keys can manage the keys in Azure Key
Vault.
Key management with Azure Key Vault
Bring Your Own Key (BYOK) support forTransparent Data Encryption (TDE)allows customers to take ownership
of key management and rotation usingAzure Key Vault, Azure's cloud-based external key management system. If
the database's access to the key vault is revoked, a database cannot be decrypted and read into memory. Azure
Key Vault provides a central key management platform, leverages tightly monitored hardware security modules
(HSMs), and enables separation of duties between management of keys and data to help meet security
compliance requirements.
Always Encrypted (Encryption-in-use )

Always Encrypted is a feature designed to protect sensitive data stored in specific database columns from access
(for example, credit card numbers, national identification numbers, or data on a need to know basis). This
includes database administrators or other privileged users who are authorized to access the database to
perform management tasks, but have no business need to access the particular data in the encrypted columns.
The data is always encrypted, which means the encrypted data is decrypted only for processing by client
applications with access to the encryption key. The encryption key is never exposed to SQL Database or SQL
Managed Instance and can be stored either in the Windows Certificate Store or in Azure Key Vault.
Dynamic data masking

Dynamic data masking limits sensitive data exposure by masking it to non-privileged users. Dynamic data
masking automatically discovers potentially sensitive data in Azure SQL Database and SQL Managed Instance
and provides actionable recommendations to mask these fields, with minimal impact to the application layer. It
works by obfuscating the sensitive data in the result set of a query over designated database fields, while the
data in the database is not changed. For more information, see Get started with SQL Database and SQL
Managed Instance dynamic data masking.

Security management
Vulnerability assessment
Vulnerability assessment is an easy to configure service that can discover, track, and help remediate potential
database vulnerabilities with the goal to proactively improve overall database security. Vulnerability assessment
(VA) is part of the Microsoft Defender for SQL offering, which is a unified package for advanced SQL security
capabilities. Vulnerability assessment can be accessed and managed via the central Microsoft Defender for SQL
portal.
Data discovery and classification
Data discovery and classification (currently in preview) provides basic capabilities built into Azure SQL Database
and SQL Managed Instance for discovering, classifying and labeling the sensitive data in your databases.
Discovering and classifying your utmost sensitive data (business/financial, healthcare, personal data, etc.) can
play a pivotal role in your organizational Information protection stature. It can serve as infrastructure for:
Various security scenarios, such as monitoring (auditing) and alerting on anomalous access to sensitive data.
Controlling access to, and hardening the security of, databases containing highly sensitive data.
Helping meet data privacy standards and regulatory compliance requirements.
For more information, see Get started with data discovery and classification.
Compliance
In addition to the above features and functionality that can help your application meet various security
requirements, Azure SQL Database also participates in regular audits, and has been certified against a number
of compliance standards. For more information, see the Microsoft Azure Trust Center where you can find the
most current list of SQL Database compliance certifications.

Next steps
For a discussion of the use of logins, user accounts, database roles, and permissions in SQL Database and
SQL Managed Instance, see Manage logins and user accounts.
For a discussion of database auditing, see auditing.
For a discussion of threat detection, see threat detection.
Playbook for addressing common security
requirements with Azure SQL Database and Azure
SQL Managed Instance
12/12/2021 • 39 minutes to read • Edit Online

APPLIES TO: Azure SQL Database Azure SQL Managed Instance


This article provides best practices on how to solve common security requirements. Not all requirements are
applicable to all environments, and you should consult your database and security team on which features to
implement.

Solving common security requirements


This document provides guidance on how to solve common security requirements for new or existing
applications using Azure SQL Database and Azure SQL Managed Instance. It's organized by high-level security
areas. For addressing specific threats, refer to the Common security threats and potential mitigations section.
Although some of the presented recommendations are applicable when migrating applications from on-
premises to Azure, migration scenarios are not the focus of this document.
Azure SQL Database deployment offers covered in this guide
Azure SQL Database: single databases and elastic pools in servers
Azure SQL Managed Instance
Deployment offers not covered in this guide
Azure Synapse Analytics
Azure SQL VMs (IaaS)
SQL Server
Audience
The intended audiences for this guide are customers facing questions on how to secure Azure SQL Database.
The roles interested in this best practice article include, but not limited to:
Security Architects
Security Managers
Compliance Officers
Privacy Officers
Security Engineers
Using this guide
This document is intended as a companion to our existing Azure SQL Database security documentation.
Unless otherwise stated, we recommend you follow all best practices listed in each section to achieve the
respective goal or requirement. To meet specific security compliance standards or best practices, important
regulatory compliance controls are listed under the Requirements or Goals section wherever applicable. These
are the security standards and regulations that are referenced in this paper:
FedRAMP: AC-04, AC-06
SOC: CM-3, SDL-3
ISO/IEC 27001: Access Control, Cryptography
Microsoft Operational Security Assurance (OSA) practices: Practice #1-6 and #9
NIST Special Publication 800-53 Security Controls: AC-5, AC-6
PCI DSS: 6.3.2, 6.4.2
We plan on continuing to update the recommendations and best practices listed here. Provide input or any
corrections for this document using the Feedback link at the bottom of this article.

Authentication
Authentication is the process of proving the user is who they claim to be. Azure SQL Database and SQL
Managed Instance support two types of authentication:
SQL authentication
Azure Active Directory authentication

NOTE
Azure Active Directory authentication may not be supported for all tools and 3rd party applications.

Central management for identities


Central identity management offers the following benefits:
Manage group accounts and control user permissions without duplicating logins across servers, databases
and managed instances.
Simplified and flexible permission management.
Management of applications at scale.
How to implement :
Use Azure Active Directory (Azure AD) authentication for centralized identity management.
Best practices :
Create an Azure AD tenant and create users to represent human users and create service principals to
represent apps, services, and automation tools. Service principals are equivalent to service accounts in
Windows and Linux.
Assign access rights to resources to Azure AD principals via group assignment: Create Azure AD groups,
grant access to groups, and add individual members to the groups. In your database, create contained
database users that map your Azure AD groups. To assign permissions inside the database, put the users
that are associated with your Azure AD groups in database roles with the appropriate permissions.
See the articles, Configure and manage Azure Active Directory authentication with SQL and Use Azure
AD for authentication with SQL.

NOTE
In SQL Managed Instance, you can also create logins that map to Azure AD principals in the master database. See
CREATE LOGIN (Transact-SQL).

Using Azure AD groups simplifies permission management and both the group owner, and the resource
owner can add/remove members to/from the group.
Create a separate group for Azure AD administrators for each server or managed instance.
See the article, Provision an Azure Active Directory administrator for your server.
Monitor Azure AD group membership changes using Azure AD audit activity reports.
For a managed instance, a separate step is required to create an Azure AD admin.
See the article, Provision an Azure Active Directory administrator for your managed instance.

NOTE
Azure AD authentication is recorded in Azure SQL audit logs, but not in Azure AD sign-in logs.
Azure RBAC permissions granted in Azure do not apply to Azure SQL Database or SQL Managed Instance permissions.
Such permissions must be created/mapped manually using existing SQL permissions.
On the client-side, Azure AD authentication needs access to the internet or via User Defined Route (UDR) to a virtual
network.
The Azure AD access token is cached on the client side and its lifetime depends on token configuration. See the article,
Configurable token lifetimes in Azure Active Directory
For guidance on troubleshooting Azure AD Authentication issues, see the following blog: Troubleshooting Azure AD.

Azure AD Multi-Factor Authentication


Mentioned in: OSA Practice #2, ISO Access Control (AC)

Azure AD Multi-Factor Authentication helps provides additional security by requiring more than one form of
authentication.
How to implement :
Enable Multi-Factor Authentication in Azure AD using Conditional Access and use interactive
authentication.
The alternative is to enable Multi-Factor Authentication for the entire Azure AD or AD domain.
Best practices :
Activate Conditional Access in Azure AD (requires Premium subscription).
See the article, Conditional Access in Azure AD.
Create Azure AD group(s) and enable Multi-Factor Authentication policy for selected groups using Azure
AD Conditional Access.
See the article, Plan Conditional Access Deployment.
Multi-Factor Authentication can be enabled for the entire Azure AD or for the whole Active Directory
federated with Azure AD.
Use Azure AD Interactive authentication mode for Azure SQL Database and Azure SQL Managed Instance
where a password is requested interactively, followed by Multi-Factor Authentication:
Use Universal Authentication in SSMS. See the article, Using Multi-factor Azure AD authentication with
Azure SQL Database, SQL Managed Instance, Azure Synapse (SSMS support for Multi-Factor
Authentication).
Use Interactive Authentication supported in SQL Server Data Tools (SSDT). See the article, Azure Active
Directory support in SQL Server Data Tools (SSDT).
Use other SQL tools supporting Multi-Factor Authentication.
SSMS Wizard support for export/extract/deploy database
sqlpackage.exe: option '/ua'
sqlcmd Utility: option -G (interactive)
bcp Utility: option -G (interactive)
Implement your applications to connect to Azure SQL Database or Azure SQL Managed Instance using
interactive authentication with Multi-Factor Authentication support.
See the article, Connect to Azure SQL Database with Azure AD Multi-Factor Authentication.

NOTE
This authentication mode requires user-based identities. In cases where a trusted identity model is used that is
bypassing individual Azure AD user authentication (e.g. using managed identity for Azure resources), Multi-Factor
Authentication does not apply.

Minimize the use of password-based authentication for users


Mentioned in: OSA Practice #4, ISO Access Control (AC)

Password-based authentication methods are a weaker form of authentication. Credentials can be compromised
or mistakenly given away.
How to implement :
Use an Azure AD integrated authentication that eliminates the use of passwords.
Best practices :
Use single sign-on authentication using Windows credentials. Federate the on-premises AD domain with
Azure AD and use integrated Windows authentication (for domain-joined machines with Azure AD).
See the article, SSMS support for Azure AD Integrated authentication.
Minimize the use of password-based authentication for applications
Mentioned in: OSA Practice #4, ISO Access Control (AC)

How to implement :
Enable Azure Managed Identity. You can also use integrated or certificate-based authentication.
Best practices :
Use managed identities for Azure resources.
System-assigned managed identity
User-assigned managed identity
Use Azure SQL Database from Azure App Service with managed identity (without code changes)
Use cert-based authentication for an application.
See this code sample.
Use Azure AD authentication for integrated federated domain and domain-joined machine (see section
above).
See the sample application for integrated authentication.
Protect passwords and secrets
For cases when passwords aren't avoidable, make sure they're secured.
How to implement :
Use Azure Key Vault to store passwords and secrets. Whenever applicable, use Multi-Factor Authentication
for Azure SQL Database with Azure AD users.
Best practices :
If avoiding passwords or secrets aren't possible, store user passwords and application secrets in Azure
Key Vault and manage access through Key Vault access policies.
Various app development frameworks may also offer framework-specific mechanisms for protecting
secrets in the app. For example: ASP.NET core app.
Use SQL authentication for legacy applications
SQL authentication refers to the authentication of a user when connecting to Azure SQL Database or SQL
Managed Instance using username and password. A login will need to be created in each server or managed
instance, and a user created in each database.
How to implement :
Use SQL authentication.
Best practices :
As a server or instance admin, create logins and users. Unless using contained database users with
passwords, all passwords are stored in master database.
See the article, Controlling and granting database access to SQL Database, SQL Managed Instance and
Azure Synapse Analytics.

Access management
Access management (also called Authorization) is the process of controlling and managing authorized users'
access and privileges to Azure SQL Database or SQL Managed Instance.
Implement principle of least privilege
Mentioned in: FedRamp controls AC-06, NIST: AC-6, OSA Practice #3

The principle of least privilege states that users shouldn't have more privileges than needed to complete their
tasks. For more information, see the article Just enough administration.
How to implement :
Assign only the necessary permissions to complete the required tasks:
In SQL Databases:
Use granular permissions and user-defined database roles (or server-roles in Managed Instance):
1. Create the required roles
CREATE ROLE
CREATE SERVER ROLE
2. Create required users
CREATE USER
3. Add users as members to roles
ALTER ROLE
ALTER SERVER ROLE
4. Then assign permissions to roles.
GRANT
Make sure to not assign users to unnecessary roles.
In Azure Resource Manager:
Use built-in roles if available or Azure custom roles and assign the necessary permissions.
Azure built-in roles
Azure custom roles
Best practices :
The following best practices are optional but will result in better manageability and supportability of your
security strategy:
If possible, start with the least possible set of permissions and start adding permissions one by one if
there's a real necessity (and justification) – as opposed to the opposite approach: taking permissions away
step by step.
Refrain from assigning permissions to individual users. Use roles (database or server roles) consistently
instead. Roles helps greatly with reporting and troubleshooting permissions. (Azure RBAC only supports
permission assignment via roles.)
Create and use custom roles with the exact permissions needed. Typical roles that are used in practice:
Security deployment
Administrator
Developer
Support personnel
Auditor
Automated processes
End user
Use built-in roles only when the permissions of the roles match exactly the needed permissions for the
user. You can assign users to multiple roles.
Remember that permissions in the database engine can be applied within the following scopes (the
smaller the scope, the smaller the impact of the granted permissions):
Server (special roles in master database) in Azure
Database
Schema
It is a best practice to use schemas to grant permissions inside a database. (also see: Schema-
design: Recommendations for Schema design with security in mind)
Object (table, view, procedure, etc.)

NOTE
It is not recommended to apply permissions on the object level because this level adds unnecessary complexity to
the overall implementation. If you decide to use object-level permissions, those should be clearly documented. The
same applies to column-level-permissions, which are even less recommendable for the same reasons. Also be
aware that by default a table-level DENY does not override a column-level GRANT. This would require the
common criteria compliance Server Configuration to be activated.

Perform regular checks using Vulnerability Assessment (VA) to test for too many permissions.
Implement Separation of Duties
Mentioned in: FedRamp: AC-04, NIST: AC-5, ISO: A.6.1.2, PCI 6.4.2, SOC: CM-3, SDL-3

Separation of Duties, also called Segregation of Duties describes the requirement to split sensitive tasks into
multiple tasks that are assigned to different users. Separation of Duties helps prevent data breaches.
How to implement :
Identify the required level of Separation of Duties. Examples:
Between Development/Test and Production environments
Security-wise sensitive tasks vs Database Administrator (DBA) management level tasks vs developer
tasks.
Examples: Auditor, creation of security policy for Role-level Security (RLS), Implementing SQL
Database objects with DDL-permissions.
Identify a comprehensive hierarchy of users (and automated processes) that access the system.
Create roles according to the needed user-groups and assign permissions to roles.
For management-level tasks in Azure portal or via PowerShell-automation use Azure roles. Either find
a built-in role matching the requirement, or create an Azure custom role using the available
permissions
Create Server roles for server-wide tasks (creating new logins, databases) in a managed instance.
Create Database Roles for database-level tasks.
For certain sensitive tasks, consider creating special stored procedures signed by a certificate to execute
the tasks on behalf of the users. One important advantage of digitally signed stored procedures is that if
the procedure is changed, the permissions that were granted to the previous version of the procedure are
immediately removed.
Example: Tutorial: Signing Stored Procedures with a Certificate
Implement Transparent Data Encryption (TDE) with customer-managed keys in Azure Key Vault to enable
Separation of Duties between data owner and security owner.
See the article, Configure customer-managed keys for Azure Storage encryption from the Azure
portal.
To ensure that a DBA can't see data that is considered highly sensitive and can still do DBA tasks, you can
use Always Encrypted with role separation.
See the articles, Overview of Key Management for Always Encrypted, Key Provisioning with Role
Separation, and Column Master Key Rotation with Role Separation.
In cases where the use of Always Encrypted isn't feasible, or at least not without major costs and efforts
that may even render the system near unusable, compromises can be made and mitigated through the
use of compensating controls such as:
Human intervention in processes.
Audit trails – for more information on Auditing, see, Audit critical security events.
Best practices :
Make sure that different accounts are used for Development/Test and Production environments. Different
accounts help to comply with separation of Test and Production systems.
Refrain from assigning permissions to individual users. Use roles (database or server roles) consistently
instead. Having roles helps greatly with reporting and troubleshooting permissions.
Use built-in roles when the permissions match exactly the needed permissions – if the union of all
permissions from multiple built-in roles leads to a 100% match, you can assign multiple roles
concurrently as well.
Create and use user-defined roles when built-in roles grant too many permissions or insufficient
permissions.
Role assignments can also be done temporarily, also known as Dynamic Separation of Duties (DSD),
either within SQL Agent Job steps in T-SQL or using Azure PIM for Azure roles.
Make sure that DBAs don't have access to the encryption keys or key stores, and that Security
Administrators with access to the keys have no access to the database in turn. The use of Extensible Key
Management (EKM) can make this separation easier to achieve. Azure Key Vault can be used to
implement EKM.
Always make sure to have an Audit trail for security-related actions.
You can retrieve the definition of the Azure built-in roles to see the permissions used and create a custom
role based on excerpts and cumulations of these via PowerShell.
Because any member of the db_owner database role can change security settings like Transparent Data
Encryption (TDE), or change the SLO, this membership should be granted with care. However, there are
many tasks that require db_owner privileges. Task like changing any database setting such as changing
DB options. Auditing plays a key role in any solution.
It is not possible to restrict permissions of a db_owner, and therefore prevent an administrative account
from viewing user data. If there's highly sensitive data in a database, Always Encrypted can be used to
safely prevent db_owners or any other DBA from viewing it.

NOTE
Achieving Separation of Duties (SoD) is challenging for security-related or troubleshooting tasks. Other areas like
development and end-user roles are easier to segregate. Most compliance related controls allow the use of alternate
control functions such as Auditing when other solutions aren't practical.

For the readers that want to dive deeper into SoD, we recommend the following resources:
For Azure SQL Database and SQL Managed Instance:
Controlling and granting database access
Engine Separation of Duties for the Application Developer
Separation of Duties
Signing Stored Procedures
For Azure Resource Management:
Azure built-in roles
Azure custom roles
Using Azure AD Privileged Identity Management for elevated access
Perform regular code reviews
Mentioned in: PCI: 6.3.2, SOC: SDL-3

Separation of Duties is not limited to the data in a database, but includes application code. Malicious code can
potentially circumvent security controls. Before deploying custom code to production, it is essential to review
what's being deployed.
How to implement :
Use a database tool like Azure Data Studio that supports source control.
Implement a segregated code deployment process.
Before committing to main branch, a person (other than the author of the code itself) has to inspect the
code for potential elevation of privileges risks as well as malicious data modifications to protect against
fraud and rogue access. This can be done using source control mechanisms.
Best practices :
Standardization: It helps to implement a standard procedure that is to be followed for any code updates.
Vulnerability Assessment contains rules that check for excessive permissions, the use of old encryption
algorithms, and other security problems within a database schema.
Further checks can be done in a QA or test environment using Advanced Threat Protection that scans for
code that is vulnerable to SQL-injection.
Examples of what to look out for:
Creation of a user or changing security settings from within an automated SQL-code-update
deployment.
A stored procedure, which, depending on the parameters provided, updates a monetary value in a cell
in a non-conforming way.
Make sure the person conducting the review is an individual other than the originating code author and
knowledgeable in code-reviews and secure coding.
Be sure to know all sources of code-changes. Code can be in T-SQL Scripts. It can be ad-hoc commands
to be executed or be deployed in forms of Views, Functions, Triggers, and Stored Procedures. It can be
part of SQL Agent Job definitions (Steps). It can also be executed from within SSIS packages, Azure Data
Factory, and other services.

Data protection
Data protection is a set of capabilities for safeguarding important information from compromise by encryption
or obfuscation.

NOTE
Microsoft attests to Azure SQL Database and SQL Managed Instance as being FIPS 140-2 Level 1 compliant. This is done
after verifying the strict use of FIPS 140-2 Level 1 acceptable algorithms and FIPS 140-2 Level 1 validated instances of
those algorithms including consistency with required key lengths, key management, key generation, and key storage. This
attestation is meant to allow our customers to respond to the need or requirement for the use of FIPS 140-2 Level 1
validated instances in the processing of data or delivery of systems or applications. We define the terms "FIPS 140-2 Level
1 compliant" and "FIPS 140-2 Level 1 compliance" used in the above statement to demonstrate their intended
applicability to U.S. and Canadian government use of the different term "FIPS 140-2 Level 1 validated."

Encrypt data in transit


Mentioned in: OSA Practice #6, ISO Control Family: Cryptography

Protects your data while data moves between your client and server. Refer to Network Security.
Encrypt data at rest
Mentioned in: OSA Practice #6, ISO Control Family: Cryptography

Encryption at rest is the cryptographic protection of data when it is persisted in database, log, and backup files.
How to implement :
Transparent Database Encryption (TDE) with service managed keys are enabled by default for any databases
created after 2017 in Azure SQL Database and SQL Managed Instance.
In a managed instance, if the database is created from a restore operation using an on-premises server, the
TDE setting of the original database will be honored. If the original database doesn't have TDE enabled, we
recommend that TDE be manually turned on for the managed instance.
Best practices :
Don't store data that requires encryption-at-rest in the master database. The master database can't be
encrypted with TDE.
Use customer-managed keys in Azure Key Vault if you need increased transparency and granular control
over the TDE protection. Azure Key Vault allows the ability to revoke permissions at any time to render
the database inaccessible. You can centrally manage TDE protectors along with other keys, or rotate the
TDE protector at your own schedule using Azure Key Vault.
If you're using customer-managed keys in Azure Key Vault, follow the articles, Guidelines for configuring
TDE with Azure Key Vault and How to configure Geo-DR with Azure Key Vault.
Protect sensitive data in use from high-privileged, unauthorized users
Data in use is the data stored in memory of the database system during the execution of SQL queries. If your
database stores sensitive data, your organization may be required to ensure that high-privileged users are
prevented from viewing sensitive data in your database. High-privilege users, such as Microsoft operators or
DBAs in your organization should be able to manage the database, but prevented from viewing and potentially
exfiltrating sensitive data from the memory of the SQL process or by querying the database.
The policies that determine which data is sensitive and whether the sensitive data must be encrypted in memory
and not accessible to administrators in plaintext, are specific to your organization and compliance regulations
you need to adhere to. Please see the related requirement: Identify and tag sensitive data.
How to implement :
Use Always Encrypted to ensure sensitive data isn't exposed in plaintext in Azure SQL Database or SQL
Managed Instance, even in memory/in use. Always Encrypted protects the data from Database
Administrators (DBAs) and cloud admins (or bad actors who can impersonate high-privileged but
unauthorized users) and gives you more control over who can access your data.
Best practices :
Always Encrypted isn't a substitute to encrypt data at rest (TDE) or in transit (SSL/TLS). Always Encrypted
shouldn't be used for non-sensitive data to minimize performance and functionality impact. Using Always
Encrypted in conjunction with TDE and Transport Layer Security (TLS) is recommended for
comprehensive protection of data at-rest, in-transit, and in-use.
Assess the impact of encrypting the identified sensitive data columns before you deploy Always
Encrypted in a production database. In general, Always Encrypted reduces the functionality of queries on
encrypted columns and has other limitations, listed in Always Encrypted - Feature Details. Therefore, you
may need to rearchitect your application to re-implement the functionality, a query does not support, on
the client side or/and refactor your database schema, including the definitions of stored procedures,
functions, views and triggers. Existing applications may not work with encrypted columns if they do not
adhere to the restrictions and limitations of Always Encrypted. While the ecosystem of Microsoft tools,
products and services supporting Always Encrypted is growing, a number of them do not work with
encrypted columns. Encrypting a column may also impact query performance, depending on the
characteristics of your workload.
Manage Always Encrypted keys with role separation if you're using Always Encrypted to protect data
from malicious DBAs. With role separation, a security admin creates the physical keys. The DBA creates
the column master key and column encryption key metadata objects describing the physical keys in the
database. During this process, the security admin doesn't need access to the database, and the DBA
doesn't need access to the physical keys in plaintext.
See the article, Managing Keys with Role Separation for details.
Store your column master keys in Azure Key Vault for ease of management. Avoid using Windows
Certificate Store (and in general, distributed key store solutions, as opposed central key management
solutions) that make key management hard.
Think carefully through the tradeoffs of using multiple keys (column master key or column encryption
keys). Keep the number of keys small to reduce key management cost. One column master key and one
column encryption key per database is typically sufficient in steady-state environments (not in the middle
of a key rotation). You may need additional keys if you have different user groups, each using different
keys and accessing different data.
Rotate column master keys per your compliance requirements. If you also need to rotate column
encryption keys, consider using online encryption to minimize application downtime.
See the article, Performance and Availability Considerations.
Use deterministic encryption if computations (equality) on data need to be supported. Otherwise, use
randomized encryption. Avoid using deterministic encryption for low-entropy data sets, or data sets with
publicly known distribution.
If you're concerned about third parties accessing your data legally without your consent, ensure that all
application and tools that have access to the keys and data in plaintext run outside of Microsoft Azure
Cloud. Without access to the keys, the third party will have no way of decrypting the data unless they
bypass the encryption.
Always Encrypted doesn't easily support granting temporary access to the keys (and the protected data).
For example, if you need to share the keys with a DBA to allow the DBA to do some cleansing operations
on sensitive and encrypted data. The only way to reliability revoke the access to the data from the DBA
will be to rotate both the column encryption keys and the column master keys protecting the data, which
is an expensive operation.
To access the plaintext values in encrypted columns, a user needs to have access to the Column Master
Key (CMK) that protects columns, which is configured in the key store holding the CMK. The user also
needs to have the VIEW ANY COLUMN MASTER KEY DEFINITION and VIEW ANY COLUMN
ENCRYPTION KEY DEFINITION database permissions.
Control access of application users to sensitive data through encryption
Encryption can be used as a way to ensure that only specific application users who have access to cryptographic
keys can view or update the data.
How to implement :
Use Cell-level Encryption (CLE). See the article, Encrypt a Column of Data for details.
Use Always Encrypted, but be aware of its limitation. The limitations are listed below.
Best practices
When using CLE:
Control access to keys through SQL permissions and roles.
Use AES (AES 256 recommended) for data encryption. Algorithms, such RC4, DES and TripleDES, are
deprecated and shouldn't be used because of known vulnerabilities.
Protect symmetric keys with asymmetric keys/certificates (not passwords) to avoid using 3DES.
Be careful when migrating a database using Cell-Level Encryption via export/import (bacpac files).
See the article, Recommendations for using Cell Level Encryption in Azure SQL Database on how to
prevent losing keys when migrating data, and for other best practice guidance.
Keep in mind that Always Encrypted is primarily designed to protect sensitive data in use from high-privilege
users of Azure SQL Database (cloud operators, DBAs) - see Protect sensitive data in use from high-privileged,
unauthorized users. Be aware of the following challenges when using Always Encrypted to protect data from
application users:
By default, all Microsoft client drivers supporting Always Encrypted maintain a global (one per application)
cache of column encryption keys. Once a client driver acquires a plaintext column encryption key by
contacting a key store holding a column master key, the plaintext column encryption key is cached. This
makes isolating data from users of a multi-user application challenging. If your application impersonates end
users when interacting with a key store (such as Azure Key Vault), after a user's query populates the cache
with a column encryption key, a subsequent query that requires the same key but is triggered by another
user will use the cached key. The driver won't call the key store and it won't check if the second user has a
permission to access the column encryption key. As a result, the user can see the encrypted data even if the
user doesn't have access to the keys. To achieve the isolation of users within a multi-user application, you can
disable column encryption key caching. Disabling caching will cause additional performance overheads, as
the driver will need to contact the key store for each data encryption or decryption operation.
Protect data against unauthorized viewing by application users while preserving data format
Another technique for preventing unauthorized users from viewing data is to obfuscate or mask the data while
preserving data types and formats to ensure that user applications can continue handle and display the data.
How to implement :
Use Dynamic Data Masking to obfuscate table columns.

NOTE
Always Encrypted does not work with Dynamic Data Masking. It is not possible to encrypt and mask the same column,
which implies that you need to prioritize protecting data in use vs. masking the data for your app users via Dynamic Data
Masking.

Best practices :

NOTE
Dynamic Data Masking cannot be used to protect data from high-privilege users. Masking policies do not apply to users
with administrative access like db_owner.

Don't permit app users to run ad-hoc queries (as they may be able to work around Dynamic Data
Masking).
See the article, Bypassing masking using inference or brute-force techniques for details.
Use a proper access control policy (via SQL permissions, roles, RLS) to limit user permissions to make
updates in the masked columns. Creating a mask on a column doesn't prevent updates to that column.
Users that receive masked data when querying the masked column, can update the data if they have
write-permissions.
Dynamic Data Masking doesn't preserve the statistical properties of the masked values. This may impact
query results (for example, queries containing filtering predicates or joins on the masked data).

Network security
Network security refers to access controls and best practices to secure your data in transit to Azure SQL
Database.
Configure my client to connect securely to SQL Database/SQL Managed Instance
Best practices on how to prevent client machines and applications with well-known vulnerabilities (for example,
using older TLS protocols and cipher suites) from connecting to Azure SQL Database and SQL Managed
Instance.
How to implement :
Ensure that client machines connecting to Azure SQL Database and SQL Managed Instance are using the
latest Transport Layer Security (TLS) version.
Best practices :
Enforce a minimal TLS version at the SQL Database server or SQL Managed Instance level using the
minimal TLS version setting. We recommend setting the minimal TLS version to 1.2, after testing to
confirm your applications supports it. TLS 1.2 includes fixes for vulnerabilities found in previous versions.
Configure all your apps and tools to connect to SQL Database with encryption enabled
Encrypt = On, TrustServerCertificate = Off (or equivalent with non-Microsoft drivers).
If your app uses a driver that doesn't support TLS or supports an older version of TLS, replace the driver,
if possible. If not possible, carefully evaluate the security risks.
Reduce attack vectors via vulnerabilities in SSL 2.0, SSL 3.0, TLS 1.0, and TLS 1.1 by disabling them on
client machines connecting to Azure SQL Database per Transport Layer Security (TLS) registry
settings.
Check cipher suites available on the client: Cipher Suites in TLS/SSL (Schannel SSP). Specifically,
disable 3DES per Configuring TLS Cipher Suite Order.
Minimize attack surface
Minimize the number of features that can be attacked by a malicious user. Implement network access controls
for Azure SQL Database.

Mentioned in: OSA Practice #5

How to implement :
In SQL Database:
Set Allow Access to Azure services to OFF at the server-level
Use VNet Service endpoints and VNet Firewall Rules.
Use Private Link.
In SQL Managed Instance:
Follow the guidelines in Network requirements.
Best practices :
Restricting access to Azure SQL Database and SQL Managed Instance by connecting on a private
endpoint (for example, using a private data path):
A managed instance can be isolated inside a virtual network to prevent external access. Applications
and tools that are in the same or peered virtual network in the same region could access it directly.
Applications and tools that are in different region could use virtual-network-to-virtual-network
connection or ExpressRoute circuit peering to establish connection. Customer should use Network
Security Groups (NSG) to restrict access over port 1433 only to resources that require access to a
managed instance.
For a SQL Database, use the Private Link feature that provides a dedicated private IP for the server
inside your virtual network. You can also use Virtual network service endpoints with virtual network
firewall rules to restrict access to your servers.
Mobile users should use point-to-site VPN connections to connect over the data path.
Users connected to their on-premises network should use site-to-site VPN connection or
ExpressRoute to connect over the data path.
You can access Azure SQL Database and SQL Managed Instance by connecting to a public endpoint (for
example, using a public data path). The following best practices should be considered:
For a server in SQL Database, use IP firewall rules to restrict access to only authorized IP addresses.
For SQL Managed Instance, use Network Security Groups (NSG) to restrict access over port 3342 only
to required resources. For more information, see Use a managed instance securely with public
endpoints.

NOTE
The SQL Managed Instance public endpoint is not enabled by default and it and must be explicitly enabled. If company
policy disallows the use of public endpoints, use Azure Policy to prevent enabling public endpoints in the first place.

Set up Azure Networking components:


Follow Azure best practices for network security.
Plan Virtual Network configuration per best practices outlined in Azure Virtual Network frequently
asked questions (FAQ) and plan.
Segment a virtual network into multiple subnets and assign resources for similar role to the same
subnet (for example, front-end vs back-end resources).
Use Network Security Groups (NSGs) to control traffic between subnets inside the Azure virtual
network boundary.
Enable Azure Network Watcher for your subscription to monitor inbound and outbound network
traffic.
Configure Power BI for secure connections to SQL Database/SQL Managed Instance
Best practices :
For Power BI Desktop, use private data path whenever possible.
Ensure that Power BI Desktop is connecting using TLS1.2 by setting the registry key on the client machine
as per Transport Layer Security (TLS) registry settings.
Restrict data access for specific users via Row-level security (RLS) with Power BI.
For Power BI Service, use the on-premises data gateway, keeping in mind Limitations and Considerations.
Configure App Service for secure connections to SQL Database/SQL Managed Instance
Best practices :
For a simple Web App, connecting over public endpoint requires setting Allow Azure Ser vices to ON.
Integrate your app with an Azure Virtual Network for private data path connectivity to a managed
instance. Optionally, you can also deploy a Web App with App Service Environments (ASE).
For Web App withASEorvirtual network Integrated Web Appconnecting to a database in SQL Database,
you can use virtual network service endpoints and virtual network firewall rules to limit access from a
specific virtual network and subnet. Then set Allow Azure Ser vices to OFF. You can also connect ASE to
a managed instance in SQL Managed Instance over a private data path.
Ensure that your Web App is configured per the article, Best practices for securing platform as a service
(PaaS) web and mobile applications using Azure App Service.
Install Web Application Firewall (WAF) to protect your web app from common exploits and vulnerabilities.
Configure Azure virtual machine hosting for secure connections to SQL Database/SQL Managed Instance
Best practices :
Use a combination of Allow and Deny rules on the NSGs of Azure virtual machines to control which
regions can be accessed from the VM.
Ensure that your VM is configured per the article, Security best practices for IaaS workloads in Azure.
Ensure that all VMs are associated with a specific virtual network and subnet.
Evaluate if you need the default route 0.0.0.0/Internet per the guidance at about forced tunneling.
If yes – for example, front-end subnet - then keep the default route.
If no – for example, middle tier or back-end subnet – then enable force tunneling so no traffic goes
over Internet to reach on-premises (a.k.a cross-premises).
Implement optional default routes if you're using peering or connecting to on-premises.
Implement User Defined Routes if you need to send all traffic in the virtual network to a Network Virtual
Appliance for packet inspection.
Use virtual network service endpoints for secure access to PaaS services like Azure Storage via the Azure
backbone network.
Protect against Distributed Denial of Service (DDoS ) attacks
Distributed Denial of Service (DDoS) attacks are attempts by a malicious user to send a flood of network traffic
to Azure SQL Database with the aim of overwhelming the Azure infrastructure and causing it to reject valid
logins and workload.

Mentioned in: OSA Practice #9

How to implement :
DDoS protection is automatically enabled as part of the Azure Platform. It includes always-on traffic monitoring
and real-time mitigation of network-level attacks on public endpoints.
Use Azure DDoS Protection to monitor public IP addresses associated to resources deployed in virtual
networks.
Use Advanced Threat Protection for Azure SQL Database to detect Denial of Service (DoS) attacks against
databases.
Best practices :
Follow the practices described in Minimize Attack Surface helps minimize DDoS attack threats.
The Advanced Threat Protection Brute force SQL credentials alert helps to detect brute force attacks.
In some cases, the alert can even distinguish penetration testing workloads.
For Azure VM hosting applications connecting to SQL Database:
Follow recommendation to Restrict access through Internet-facing endpoints in Microsoft Defender
for Cloud.
Use virtual machine scale sets to run multiple instances of your application on Azure VMs.
Disable RDP and SSH from Internet to prevent brute force attack.

Monitoring, Logging, and Auditing


This section refers to capabilities to help you detect anomalous activities indicating unusual and potentially
harmful attempts to access or exploit databases. It also describes best practices to configure database auditing
to track and capture database events.
Protect databases against attacks
Advanced threat protection enables you to detect and respond to potential threats as they occur by providing
security alerts on anomalous activities.
How to implement :
Use Advanced Threat Protection for SQL to detect unusual and potentially harmful attempts to access or
exploit databases, including:
SQL injection attack.
Credentials theft/leak.
Privilege abuse.
Data exfiltration.
Best practices :
Configure Microsoft Defender for SQLfor a specific server or a managed instance. You can also configure
Microsoft Defender for SQL for all servers and managed instances in a subscription by enabling
Microsoft Defender for Cloud.
For a full investigation experience, it's recommended to enableSQL Database Auditing. With auditing, you
can track database events and write them to an audit log in an Azure Storage account or Azure Log
Analytics workspace.
Audit critical security events
Tracking of database events helps you understand database activity. You can gain insight into discrepancies and
anomalies that could indicate business concerns or suspected security violations. It also enables and facilitates
adherence to compliance standards.
How to implement :
EnableSQL Database Auditing or Managed Instance Auditing to track database events and write them to
an audit log in your Azure Storage account, Log Analytics workspace (preview), or Event Hubs (preview).
Audit logs can be written to an Azure Storage account, to a Log Analytics workspace for consumption by
Azure Monitor logs, or to event hub for consumption using event hub. You can configure any
combination of these options, and audit logs will be written to each.
Best practices :
By configuring SQL Database Auditing on your server or Managed Instance Auditing to audit events, all
existing and newly created databases on that server will be audited.
By default auditing policy includes all actions (queries, stored procedures and successful and failed logins)
against the databases, which may result in high volume of audit logs. It's recommended for customers to
configure auditing for different types of actions and action groups using PowerShell. Configuring this will
help control the number of audited actions, and minimize the risk of event loss. Custom audit configurations
allow customers to capture only the audit data that is needed.
Audit logs can be consumed directly in the Azure portal, or from the storage location that was configured.
NOTE
Enabling auditing to Log Analytics will incur cost based on ingestion rates. Please be aware of the associated cost with
using this option, or consider storing the audit logs in an Azure storage account.

Fur ther resources :


SQL Database Auditing
SQL Server Auditing
Secure audit logs
Restrict access to the storage account to support Separation of Duties and to separate DBA from Auditors.
How to implement :
When saving Audit logs to Azure Storage, make sure that access to the Storage Account is restricted to the
minimal security principles. Control who has access to the storage account.
For more information, see Authorizing access to Azure Storage.
Best practices :
Controlling Access to the Audit Target is a key concept in separating DBA from Auditors.
When auditing access to sensitive data, consider securing the data with data encryption to avoid
information leakage to the Auditor. For more information, see the section Protect sensitive data in use
from high-privileged, unauthorized users.

Security Management
This section describes the different aspects and best practices for managing your databases security posture. It
includes best practices for ensuring your databases are configured to meet security standards, for discovering
and for classifying and tracking access to potentially sensitive data in your databases.
Ensure that the databases are configured to meet security best practices
Proactively improve your database security by discovering and remediating potential database vulnerabilities.
How to implement :
Enable SQL Vulnerability Assessment (VA) to scan your database for security issues, and to automatically run
periodically on your databases.
Best practices :
Initially, run VA on your databases and iterate by remediating failing checks that oppose security best
practices. Set up baselines for acceptable configurations until the scan comes out clean, or all checks has
passed.
Configure periodic recurring scans to run once a week and configure the relevant person to receive
summary emails.
Review the VA summary following each weekly scan. For any vulnerabilities found, evaluate the drift from
the previous scan result and determine if the check should be resolved. Review if there's a legitimate
reason for the change in configuration.
Resolve checks and update baselines where relevant. Create ticket items for resolving actions and track
these until they're resolved.
Fur ther resources :
SQL Vulnerability Assessment
SQL Vulnerability Assessment service helps you identify database vulnerabilities
Identify and tag sensitive data
Discover columns that potentially contain sensitive data. What is considered sensitive data heavily depends on
the customer, compliance regulation, etc., and needs to be evaluated by the users in charge of that data. Classify
the columns to use advanced sensitivity-based auditing and protection scenarios.
How to implement :
Use SQL Data Discovery and Classification to discover, classify, label, and protect the sensitive data in your
databases.
View the classification recommendations that are created by the automated discovery in the SQL Data
Discovery and Classification dashboard. Accept the relevant classifications, such that your sensitive
data is persistently tagged with classification labels.
Manually add classifications for any additional sensitive data fields that were not discovered by the
automated mechanism.
For more information, see SQL Data Discovery and Classification.
Best practices :
Monitor the classification dashboard on a regular basis for an accurate assessment of the database's
classification state. A report on the database classification state can be exported or printed to share for
compliance and auditing purposes.
Continuously monitor the status of recommended sensitive data in SQL Vulnerability Assessment. Track
the sensitive data discovery rule and identify any drift in the recommended columns for classification.
Use classification in a way that is tailored to the specific needs of your organization. Customize your
Information Protection policy (sensitivity labels, information types, discovery logic) in the SQL
Information Protection policy in Microsoft Defender for Cloud.
Track access to sensitive data
Monitor who accesses sensitive data and capture queries on sensitive data in audit logs.
How to implement :
Use SQL Audit and Data Classification in combination.
In your SQL Database Audit log, you can track access specifically to sensitive data. You can also view
information such as the data that was accessed, as well as its sensitivity label. For more information,
see Data Discovery and Classification and Auditing access to sensitive data.
Best practices :
See best practices for the Auditing and Data Classification sections:
Audit critical security events
Identify and tag sensitive data
Visualize security and compliance status
Use a unified infrastructure security management system that strengthens the security posture of your data
centers (including databases in SQL Database). View a list of recommendations concerning the security of your
databases and compliance status.
How to implement :
Monitor SQL-related security recommendations and active threats in Microsoft Defender for Cloud.
Common security threats and potential mitigations
This section helps you find security measures to protect against certain attack vectors. It's expected that most
mitigations can be achieved by following one or more of the security guidelines above.
Security threat: Data exfiltration
Data exfiltration is the unauthorized copying, transfer, or retrieval of data from a computer or server. See a
definition for data exfiltration on Wikipedia.
Connecting to server over a public endpoint presents a data exfiltration risk as it requires customers open their
firewalls to public IPs.
Scenario 1 : An application on an Azure VM connects to a database in Azure SQL Database. A rogue actor gets
access to the VM and compromises it. In this scenario, data exfiltration means that an external entity using the
rogue VM connects to the database, copies personal data, and stores it in a blob storage or a different SQL
Database in a different subscription.
Scenario 2 : A Rouge DBA. This scenario is often raised by security sensitive customers from regulated
industries. In this scenario, a high privilege user might copy data from Azure SQL Database to another
subscription not controlled by the data owner.
Potential mitigations :
Today, Azure SQL Database and SQL Managed Instance offers the following techniques for mitigating data
exfiltration threats:
Use a combination of Allow and Deny rules on the NSGs of Azure VMs to control which regions can be
accessed from the VM.
If using a server in SQL Database, set the following options:
Allow Azure Services to OFF.
Only allow traffic from the subnet containing your Azure VM by setting up a VNet Firewall rule.
Use Private Link
For SQL Managed Instance, using private IP access by default addresses the first data exfiltration concern of a
rogue VM. Turn on the subnet delegation feature on a subnet to automatically set the most restrictive policy
on a SQL Managed Instance subnet.
The Rogue DBA concern is more exposed with SQL Managed Instance as it has a larger surface area and
networking requirements are visible to customers. The best mitigation for this is applying all of the practices
in this security guide to prevent the Rogue DBA scenario in the first place (not only for data exfiltration).
Always Encrypted is one method to protect sensitive data by encrypting it and keeping the key inaccessible
for the DBA.

Security aspects of business continuity and availability


Most security standards address data availability in terms of operational continuity, achieved by implementing
redundancy and fail-over capabilities to avoid single points of failure. For disaster scenarios, it's a common
practice to keep backups of Data and Log files.The following section provides a high-level overview of the
capabilities that are built-into Azure. It also provides additional options that can be configured to meet specific
needs:
Azure offers built-in high-availability: High-availability with SQL Database and SQL Managed Instance
The Business Critical tier includes failover groups, full and differential log backups, and point-in-time-
restore backups enabled by default:
Automated backups
Recover a database using automated database backups - Point-in-time restore
Additional business continuity features such as the zone redundant configuration and auto-failover
groups across different Azure geos can be configured:
High-availability - Zone redundant configuration for Premium & Business Critical service tiers
High-availability - Zone redundant configuration for General Purpose service tier
Overview of business continuity

Next steps
See An overview of Azure SQL Database security capabilities
Azure database security checklist
12/12/2021 • 2 minutes to read • Edit Online

To help improve security, Azure Database includes a number of built-in security controls that you can use to limit
and control access.
These include:
A firewall that enables you to create firewall rules limiting connectivity by IP address,
Server-level firewall accessible from the Azure portal
Database-level firewall rules accessible from SSMS
Secure connectivity to your database using secure connection strings
Use access management
Data encryption
SQL Database auditing
SQL Database threat detection

Introduction
Cloud computing requires new security paradigms that are unfamiliar to many application users, database
administrators, and programmers. As a result, some organizations are hesitant to implement a cloud
infrastructure for data management due to perceived security risks. However, much of this concern can be
alleviated through a better understanding of the security features built into Microsoft Azure and Microsoft Azure
SQL Database.

Checklist
We recommend that you read the Azure Database Security Best Practices article prior to reviewing this checklist.
You will be able to get the most out of this checklist after you understand the best practices. You can then use
this checklist to make sure that you've addressed the important issues in Azure database security.

C H EC K L IST C AT EGO RY DESC RIP T IO N

Protect Data

Transport Layer Security, for data encryption when


Encryption in Motion/Transit data is moving to the networks.
Database requires secure communication from clients
based on the TDS(Tabular Data Stream) protocol over
TLS (Transport Layer Security).

Transparent Data Encryption, when inactive data is


Encryption at rest stored physically in any digital form.

Control Access
C H EC K L IST C AT EGO RY DESC RIP T IO N

Authentication (Azure Active Directory


Database Access Authentication) AD authentication uses identities
managed by Azure Active Directory.
Authorization grant users the least privileges
necessary.

Row level Security (Using Security Policy, at the same


Application Access time restricting row-level access based on a user's
identity,role, or execution context).
Dynamic Data Masking (Using Permission & Policy,
limits sensitive data exposure by masking it to non-
privileged users)

Proactive Monitoring

Auditing tracks database events and writes them to


Tracking & Detecting an Audit log/ Activity log in your Azure Storage
account.
Track Azure Database health using Azure Monitor
Activity Logs.
Threat Detection detects anomalous database
activities indicating potential security threats to the
database.

Data Monitoring Use Microsoft Defender for Cloud


Microsoft Defender for Cloud as a centralized security monitoring solution for SQL
and other Azure services.

Conclusion
Azure Database is a robust database platform, with a full range of security features that meet many
organizational and regulatory compliance requirements. You can easily protect data by controlling the physical
access to your data, and using a variety of options for data security at the file-, column-, or row-level with
Transparent Data Encryption, Cell-Level Encryption, or Row-Level Security. Always Encrypted also enables
operations against encrypted data, simplifying the process of application updates. In turn, access to auditing
logs of SQL Database activity provides you with the information you need, allowing you to know how and when
data is accessed.

Next steps
You can improve the protection of your database against malicious users or unauthorized access with just a few
simple steps. In this tutorial you learn to:
Set up firewall rules for your server and or database.
Protect your data with encryption.
Enable SQL Database auditing.
Security recommendations for Blob storage
12/12/2021 • 9 minutes to read • Edit Online

This article contains security recommendations for Blob storage. Implementing these recommendations will
help you fulfill your security obligations as described in our shared responsibility model. For more information
on how Microsoft fulfills service provider responsibilities, see Shared responsibility in the cloud.
Some of the recommendations included in this article can be automatically monitored by Microsoft Defender
for Cloud, which is the first line of defense in protecting your resources in Azure. For information on Microsoft
Defender for Cloud, see What is Microsoft Defender for Cloud?
Microsoft Defender for Cloud periodically analyzes the security state of your Azure resources to identify
potential security vulnerabilities. It then provides you with recommendations on how to address them. For more
information on Microsoft Defender for Cloud recommendations, see Security recommendations in Microsoft
Defender for Cloud.

Data protection
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Use the Azure Resource Manager Create new storage accounts using the -
deployment model Azure Resource Manager deployment
model for important security
enhancements, including superior
Azure role-based access control (Azure
RBAC) and auditing, Resource
Manager-based deployment and
governance, access to managed
identities, access to Azure Key Vault for
secrets, and Azure AD-based
authentication and authorization for
access to Azure Storage data and
resources. If possible, migrate existing
storage accounts that use the classic
deployment model to use Azure
Resource Manager. For more
information about Azure Resource
Manager, see Azure Resource Manager
overview.

Enable Microsoft Defender for all of Microsoft Defender for Storage Yes
your storage accounts provides an additional layer of security
intelligence that detects unusual and
potentially harmful attempts to access
or exploit storage accounts. Security
alerts are triggered in Microsoft
Defender for Cloud when anomalies in
activity occur and are also sent via
email to subscription administrators,
with details of suspicious activity and
recommendations on how to
investigate and remediate threats. For
more information, see Configure
Microsoft Defender for Storage.
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Turn on soft delete for blobs Soft delete for blobs enables you to -
recover blob data after it has been
deleted. For more information on soft
delete for blobs, see Soft delete for
Azure Storage blobs.

Turn on soft delete for containers Soft delete for containers enables you -
to recover a container after it has been
deleted. For more information on soft
delete for containers, see Soft delete
for containers.

Lock storage account to prevent Apply an Azure Resource Manager lock


accidental or malicious deletion or to your storage account to protect the
configuration changes account from accidental or malicious
deletion or configuration change.
Locking a storage account does not
prevent data within that account from
being deleted. It only prevents the
account itself from being deleted. For
more information, see Apply an Azure
Resource Manager lock to a storage
account.

Store business-critical data in Configure legal holds and time-based -


immutable blobs retention policies to store blob data in
a WORM (Write Once, Read Many)
state. Blobs stored immutably can be
read, but cannot be modified or
deleted for the duration of the
retention interval. For more
information, see Store business-critical
blob data with immutable storage.

Require secure transfer (HTTPS) to the When you require secure transfer for a -
storage account storage account, all requests to the
storage account must be made over
HTTPS. Any requests made over HTTP
are rejected. Microsoft recommends
that you always require secure transfer
for all of your storage accounts. For
more information, see Require secure
transfer to ensure secure connections.

Limit shared access signature (SAS) Requiring HTTPS when a client uses a -
tokens to HTTPS connections only SAS token to access blob data helps to
minimize the risk of eavesdropping.
For more information, see Grant
limited access to Azure Storage
resources using shared access
signatures (SAS).

Identity and access management


REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Use Azure Active Directory (Azure AD) Azure AD provides superior security -
to authorize access to blob data and ease of use over Shared Key for
authorizing requests to Blob storage.
For more information, see Authorize
access to data in Azure Storage.

Keep in mind the principal of least When assigning a role to a user, group, -
privilege when assigning permissions or application, grant that security
to an Azure AD security principal via principal only those permissions that
Azure RBAC are necessary for them to perform
their tasks. Limiting access to
resources helps prevent both
unintentional and malicious misuse of
your data.

Use a user delegation SAS to grant A user delegation SAS is secured with -
limited access to blob data to clients Azure Active Directory (Azure AD)
credentials and also by the permissions
specified for the SAS. A user delegation
SAS is analogous to a service SAS in
terms of its scope and function, but
offers security benefits over the service
SAS. For more information, see Grant
limited access to Azure Storage
resources using shared access
signatures (SAS).

Secure your account access keys with Microsoft recommends using Azure -
Azure Key Vault AD to authorize requests to Azure
Storage. However, if you must use
Shared Key authorization, then secure
your account keys with Azure Key
Vault. You can retrieve the keys from
the key vault at runtime, instead of
saving them with your application. For
more information about Azure Key
Vault, see Azure Key Vault overview.

Regenerate your account keys Rotating the account keys periodically -


periodically reduces the risk of exposing your data
to malicious actors.

Disallow Shared Key authorization When you disallow Shared Key -


authorization for a storage account,
Azure Storage rejects all subsequent
requests to that account that are
authorized with the account access
keys. Only secured requests that are
authorized with Azure AD will succeed.
For more information, see Prevent
Shared Key authorization for an Azure
Storage account.

Keep in mind the principal of least When creating a SAS, specify only -
privilege when assigning permissions those permissions that are required by
to a SAS the client to perform its function.
Limiting access to resources helps
prevent both unintentional and
malicious misuse of your data.
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Have a revocation plan in place for any If a SAS is compromised, you will want -
SAS that you issue to clients to revoke that SAS as soon as possible.
To revoke a user delegation SAS,
revoke the user delegation key to
quickly invalidate all signatures
associated with that key. To revoke a
service SAS that is associated with a
stored access policy, you can delete the
stored access policy, rename the policy,
or change its expiry time to a time that
is in the past. For more information,
see Grant limited access to Azure
Storage resources using shared access
signatures (SAS).

If a service SAS is not associated with a A service SAS that is not associated -
stored access policy, then set the with a stored access policy cannot be
expiry time to one hour or less revoked. For this reason, limiting the
expiry time so that the SAS is valid for
one hour or less is recommended.

Disable anonymous public read access Anonymous public read access to a -


to containers and blobs container and its blobs grants read-
only access to those resources to any
client. Avoid enabling public read
access unless your scenario requires it.
To learn how to disable anonymous
public access for a storage account, see
Configure anonymous public read
access for containers and blobs.

Networking
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Configure the minimum required Require that clients use a more secure -
version of Transport Layer Security version of TLS to make requests
(TLS) for a storage account. against an Azure Storage account by
configuring the minimum version of
TLS for that account. For more
information, see Configure minimum
required version of Transport Layer
Security (TLS) for a storage account

Enable the Secure transfer required When you enable the Secure Yes
option on all of your storage accounts transfer required option, all requests
made against the storage account
must take place over secure
connections. Any requests made over
HTTP will fail. For more information,
see Require secure transfer in Azure
Storage.
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Enable firewall rules Configure firewall rules to limit access -


to your storage account to requests
that originate from specified IP
addresses or ranges, or from a list of
subnets in an Azure Virtual Network
(VNet). For more information about
configuring firewall rules, see Configure
Azure Storage firewalls and virtual
networks.

Allow trusted Microsoft services to Turning on firewall rules for your -


access the storage account storage account blocks incoming
requests for data by default, unless the
requests originate from a service
operating within an Azure Virtual
Network (VNet) or from allowed public
IP addresses. Requests that are
blocked include those from other
Azure services, from the Azure portal,
from logging and metrics services, and
so on. You can permit requests from
other Azure services by adding an
exception to allow trusted Microsoft
services to access the storage account.
For more information about adding an
exception for trusted Microsoft
services, see Configure Azure Storage
firewalls and virtual networks.

Use private endpoints A private endpoint assigns a private IP -


address from your Azure Virtual
Network (VNet) to the storage
account. It secures all traffic between
your VNet and the storage account
over a private link. For more
information about private endpoints,
see Connect privately to a storage
account using Azure Private Endpoint.

Use VNet service tags A service tag represents a group of IP -


address prefixes from a given Azure
service. Microsoft manages the
address prefixes encompassed by the
service tag and automatically updates
the service tag as addresses change.
For more information about service
tags supported by Azure Storage, see
Azure service tags overview. For a
tutorial that shows how to use service
tags to create outbound network rules,
see Restrict access to PaaS resources.

Limit network access to specific Limiting network access to networks Yes


networks hosting clients requiring access
reduces the exposure of your
resources to network attacks.
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Configure network routing preference You can configure network routing -


preference for your Azure storage
account to specify how network traffic
is routed to your account from clients
over the Internet using the Microsoft
global network or Internet routing. For
more information, see Configure
network routing preference for Azure
Storage.

Logging/Monitoring
REC O M M EN DAT IO N C O M M EN T S DEF EN DER F O R C LO UD

Track how requests are authorized Enable Azure Storage logging to track -
how each request made against Azure
Storage was authorized. The logs
indicate whether a request was made
anonymously, by using an OAuth 2.0
token, by using Shared Key, or by
using a shared access signature (SAS).
For more information, see Monitoring
Azure Blob Storage with Azure Monitor
or Azure Storage analytics logging with
Classic Monitoring.

Set up alerts in Azure Monitor Configure log alerts to evaluate -


resources logs at a set frequency and
fire an alert based on the results. For
more information, see Log alerts in
Azure Monitor.

Next steps
Azure security documentation
Secure development documentation.
Customer Lockbox for Microsoft Azure
12/12/2021 • 5 minutes to read • Edit Online

NOTE
To use this feature, your organization must have an Azure support plan with a minimal level of Developer .

Most operations, support, and troubleshooting performed by Microsoft personnel and sub-processors do not
require access to customer data. In those rare circumstances where such access is required, Customer Lockbox
for Microsoft Azure provides an interface for customers to review and approve or reject customer data access
requests. It is used in cases where a Microsoft engineer needs to access customer data, whether in response to a
customer-initiated support ticket or a problem identified by Microsoft.
This article covers how to enable Customer Lockbox and how Lockbox requests are initiated, tracked, and stored
for later reviews and audits.

Supported services and scenarios


General Availability
The following services are generally available for Customer Lockbox:
Azure API Management
Azure App Service
Azure Cognitive Search
Azure Cognitive Services
Azure Container Registry
Azure Database for MySQL
Azure Databricks
Azure Data Box
Azure Data Explorer
Azure Data Factory
Azure Database for PostgreSQL
Azure Functions
Azure HDInsight
Azure Kubernetes Service
Azure Monitor
Azure Storage
Azure SQL Database
Azure subscription transfers
Azure Synapse Analytics
Virtual machines in Azure (covering remote desktop access, access to memory dumps, and managed disks)
Public Preview
The following services are currently in preview for Customer Lockbox:
Azure Machine Learning
Azure Batch

Enable Customer Lockbox


You can now enable Customer Lockbox from the Administration module in the Customer Lockbox blade.

NOTE
To enable Customer Lockbox, the user account needs to have the Global Administrator role assigned.

Workflow
The following steps outline a typical workflow for a Customer Lockbox request.
1. Someone at an organization has an issue with their Azure workload.
2. After this person troubleshoots the issue, but can't fix it, they open a support ticket from the Azure portal.
The ticket is assigned to an Azure Customer Support Engineer.
3. An Azure Support Engineer reviews the service request and determines the next steps to resolve the
issue.
4. If the support engineer can't troubleshoot the issue by using standard tools and service generated data,
the next step is to request elevated permissions by using a Just-In-Time (JIT) access service. This request
can be from the original support engineer or from a different engineer because the problem is escalated
to the Azure DevOps team.
5. After the access request is submitted by the Azure Engineer, Just-In-Time service evaluates the request
taking into account factors such as:
The scope of the resource
Whether the requester is an isolated identity or using multi-factor authentication
Permissions levels
Based on the JIT rule, this request may also include an approval from Internal Microsoft Approvers. For
example, the approver might be the Customer support lead or the DevOps Manager.
6. When the request requires direct access to customer data, a Customer Lockbox request is initiated. For
example, remote desktop access to a customer's virtual machine.
The request is now in a Customer Notified state, waiting for the customer's approval before granting
access.
7. At the customer organization, the user who has the Owner role for the Azure subscription receives an
email from Microsoft, to notify them about the pending access request. For Customer Lockbox requests,
this person is the designated approver.
Example email:
8. The email notification provides a link to the Customer Lockbox blade in the Administration module.
Using this link, the designated approver signs in to the Azure portal to view any pending requests that
their organization has for Customer Lockbox:
The request remains in the customer queue for four days. After this time, the access request automatically
expires and no access is granted to Microsoft engineers.
9. To get the details of the pending request, the designated approver can select the lockbox request from
Pending Requests :

10. The designated approver can also select the SERVICE REQUEST ID to view the support ticket request
that was created by the original user. This information provides context for why Microsoft Support is
engaged, and the history of the reported problem. For example:

11. After reviewing the request, the designated approver selects Approve or Deny :
As a result of the selection:
Approve : Access is granted to the Microsoft engineer. The access is granted for a default period of
eight hours.
Deny : The elevated access request by the Microsoft engineer is rejected and no further action is taken.
For auditing purposes, the actions taken in this workflow are logged in Customer Lockbox request logs.

Auditing logs
Customer Lockbox logs are stored in activity logs. In the Azure portal, select Activity Logs to view auditing
information related to Customer Lockbox requests. You can filter for specific actions, such as:
Deny Lockbox Request
Create Lockbox Request
Approve Lockbox Request
Lockbox Request Expir y
As an example:

Customer Lockbox integration with Azure Security Benchmark


We've introduced a new baseline control (3.13) in Azure Security Benchmark that covers Customer Lockbox
applicability. Customers can now leverage the benchmark to review Customer Lockbox applicability for a
service.
Exclusions
Customer Lockbox requests are not triggered in the following engineering support scenarios:
Emergency scenarios that fall outside of standard operating procedures. For example, a major service outage
requires immediate attention to recover or restore services in an unexpected or unpredictable scenario.
These “break glass” events are rare and, in most instances, do not require any access to customer data to
resolve.
A Microsoft engineer accesses the Azure platform as part of troubleshooting and is inadvertently exposed to
customer data. For example, the Azure Network Team performs troubleshooting that results in a packet
capture on a network device. It is rare that such scenarios would result in access to meaningful quantities of
customer data. Customers can further protect their data through use of in transit and at rest encryption.
Customer Lockbox requests are also not triggered by external legal demands for data. For details, see the
discussion of government requests for data on the Microsoft Trust Center.

Next steps
Customer Lockbox is available for all customers who have an Azure support plan with a minimal level of
Developer . You can enable Customer Lockbox from the Administration module in the Customer Lockbox blade.
Customer Lockbox requests are initiated by a Microsoft engineer if this action is needed to progress a support
case.
Securing PaaS deployments
12/12/2021 • 12 minutes to read • Edit Online

This article provides information that helps you:


Understand the security advantages of hosting applications in the cloud
Evaluate the security advantages of platform as a service (PaaS) versus other cloud service models
Change your security focus from a network-centric to an identity-centric perimeter security approach
Implement general PaaS security best practices recommendations
Developing secure applications on Azure is a general guide to the security questions and controls you should
consider at each phase of the software development lifecycle when developing applications for the cloud.

Cloud security advantages


It’s important to understand the division of responsibility between you and Microsoft. On-premises, you own
the whole stack but as you move to the cloud some responsibilities transfer to Microsoft.
There are security advantages to being in the cloud. In an on-premises environment, organizations likely have
unmet responsibilities and limited resources available to invest in security, which creates an environment where
attackers are able to exploit vulnerabilities at all layers.
Organizations are able to improve their threat detection and response times by using a provider’s cloud-based
security capabilities and cloud intelligence. By shifting responsibilities to the cloud provider, organizations can
get more security coverage, which enables them to reallocate security resources and budget to other business
priorities.

Security advantages of a PaaS cloud service model


Let’s look at the security advantages of an Azure PaaS deployment versus on-premises.

Starting at the bottom of the stack, the physical infrastructure, Microsoft mitigates common risks and
responsibilities. Because the Microsoft cloud is continually monitored by Microsoft, it is hard to attack. It doesn’t
make sense for an attacker to pursue the Microsoft cloud as a target. Unless the attacker has lots of money and
resources, the attacker is likely to move on to another target.
In the middle of the stack, there is no difference between a PaaS deployment and on-premises. At the
application layer and the account and access management layer, you have similar risks. In the next steps section
of this article, we will guide you to best practices for eliminating or minimizing these risks.
At the top of the stack, data governance and rights management, you take on one risk that can be mitigated by
key management. (Key management is covered in best practices.) While key management is an additional
responsibility, you have areas in a PaaS deployment that you no longer have to manage so you can shift
resources to key management.
The Azure platform also provides you strong DDoS protection by using various network-based technologies.
However, all types of network-based DDoS protection methods have their limits on a per-link and per-datacenter
basis. To help avoid the impact of large DDoS attacks, you can take advantage of Azure’s core cloud capability of
enabling you to quickly and automatically scale out to defend against DDoS attacks. We'll go into more detail on
how you can do this in the recommended practices articles.

Modernizing the Defender for Cloud’s mindset


With PaaS deployments come a shift in your overall approach to security. You shift from needing to control
everything yourself to sharing responsibility with Microsoft.
Another significant difference between PaaS and traditional on-premises deployments, is a new view of what
defines the primary security perimeter. Historically, the primary on-premises security perimeter was your
network and most on-premises security designs use the network as its primary security pivot. For PaaS
deployments, you are better served by considering identity to be the primary security perimeter.

Adopt a policy of identity as the primary security perimeter


One of the five essential characteristics of cloud computing is broad network access, which makes network-
centric thinking less relevant. The goal of much of cloud computing is to allow users to access resources
regardless of location. For most users, their location is going to be somewhere on the Internet.
The following figure shows how the security perimeter has evolved from a network perimeter to an identity
perimeter. Security becomes less about defending your network and more about defending your data, as well as
managing the security of your apps and users. The key difference is that you want to push security closer to
what’s important to your company.
Initially, Azure PaaS services (for example, web roles and Azure SQL) provided little or no traditional network
perimeter defenses. It was understood that the element’s purpose was to be exposed to the Internet (web role)
and that authentication provides the new perimeter (for example, BLOB or Azure SQL).
Modern security practices assume that the adversary has breached the network perimeter. Therefore, modern
defense practices have moved to identity. Organizations must establish an identity-based security perimeter
with strong authentication and authorization hygiene (best practices).
Principles and patterns for the network perimeter have been available for decades. In contrast, the industry has
relatively less experience with using identity as the primary security perimeter. With that said, we have
accumulated enough experience to provide some general recommendations that are proven in the field and
apply to almost all PaaS services.
The following are best practices for managing the identity perimeter.
Best practice : Secure your keys and credentials to secure your PaaS deployment.
Detail : Losing keys and credentials is a common problem. You can use a centralized solution where keys and
secrets can be stored in hardware security modules (HSMs). Azure Key Vault safeguards your keys and secrets
by encrypting authentication keys, storage account keys, data encryption keys, .pfx files, and passwords using
keys that are protected by HSMs.
Best practice : Don’t put credentials and other secrets in source code or GitHub.
Detail : The only thing worse than losing your keys and credentials is having an unauthorized party gain access
to them. Attackers can take advantage of bot technologies to find keys and secrets stored in code repositories
such as GitHub. Do not put key and secrets in these public code repositories.
Best practice : Protect your VM management interfaces on hybrid PaaS and IaaS services by using a
management interface that enables you to remote manage these VMs directly.
Detail : Remote management protocols such as SSH, RDP, and PowerShell remoting can be used. In general, we
recommend that you do not enable direct remote access to VMs from the internet.
If possible, use alternate approaches like using virtual private networks in an Azure virtual network. If alternative
approaches are not available, ensure that you use complex passphrases and two-factor authentication (such as
Azure AD Multi-Factor Authentication).
Best practice : Use strong authentication and authorization platforms.
Detail : Use federated identities in Azure AD instead of custom user stores. When you use federated identities,
you take advantage of a platform-based approach and you delegate the management of authorized identities to
your partners. A federated identity approach is especially important when employees are terminated and that
information needs to be reflected through multiple identity and authorization systems.
Use platform-supplied authentication and authorization mechanisms instead of custom code. The reason is that
developing custom authentication code can be error prone. Most of your developers are not security experts
and are unlikely to be aware of the subtleties and the latest developments in authentication and authorization.
Commercial code (for example, from Microsoft) is often extensively security reviewed.
Use two-factor authentication. Two-factor authentication is the current standard for authentication and
authorization because it avoids the security weaknesses inherent in username and password types of
authentication. Access to both the Azure management (portal/remote PowerShell) interfaces and customer-
facing services should be designed and configured to use Azure AD Multi-Factor Authentication.
Use standard authentication protocols, such as OAuth2 and Kerberos. These protocols have been extensively
peer reviewed and are likely implemented as part of your platform libraries for authentication and
authorization.

Use threat modeling during application design


The Microsoft Security Development Lifecycle specifies that teams should engage in a process called threat
modeling during the design phase. To help facilitate this process, Microsoft has created the SDL Threat Modeling
Tool. Modeling the application design and enumerating STRIDE threats across all trust boundaries can catch
design errors early on.
The following table lists the STRIDE threats and gives some example mitigations that use Azure features. These
mitigations won’t work in every situation.

P OT EN T IA L A Z URE P L AT F O RM
T H REAT SEC URIT Y P RO P ERT Y M IT IGAT IO N S

Spoofing Authentication Require HTTPS connections.

Tampering Integrity Validate TLS/SSL certificates.

Repudiation Non-repudiation Enable Azure monitoring and


diagnostics.

Information disclosure Confidentiality Encrypt sensitive data at rest by using


service certificates.

Denial of service Availability Monitor performance metrics for


potential denial-of-service conditions.
Implement connection filters.

Elevation of privilege Authorization Use Privileged Identity Management.

Develop on Azure App Service


Azure App Service is a PaaS offering that lets you create web and mobile apps for any platform or device and
connect to data anywhere, in the cloud or on-premises. App Service includes the web and mobile capabilities
that were previously delivered separately as Azure Websites and Azure Mobile Services. It also includes new
capabilities for automating business processes and hosting cloud APIs. As a single integrated service, App
Service brings a rich set of capabilities to web, mobile, and integration scenarios.
Following are best practices for using App Service.
Best practice : Authenticate through Azure Active Directory.
Detail : App Service provides an OAuth 2.0 service for your identity provider. OAuth 2.0 focuses on client
developer simplicity while providing specific authorization flows for web applications, desktop applications, and
mobile phones. Azure AD uses OAuth 2.0 to enable you to authorize access to mobile and web applications.
Best practice : Restrict access based on the need to know and least privilege security principles.
Detail : Restricting access is imperative for organizations that want to enforce security policies for data access.
You can use Azure RBAC to assign permissions to users, groups, and applications at a certain scope. To learn
more about granting users access to applications, see Get started with access management.
Best practice : Protect your keys.
Detail : Azure Key Vault helps safeguard cryptographic keys and secrets that cloud applications and services use.
With Key Vault, you can encrypt keys and secrets (such as authentication keys, storage account keys, data
encryption keys, .PFX files, and passwords) by using keys that are protected by hardware security modules
(HSMs). For added assurance, you can import or generate keys in HSMs. See Azure Key Vault to learn more. You
can also use Key Vault to manage your TLS certificates with auto-renewal.
Best practice : Restrict incoming source IP addresses.
Detail : App Service Environment has a virtual network integration feature that helps you restrict incoming
source IP addresses through network security groups. Virtual networks enable you to place Azure resources in a
non-internet, routable network that you control access to. To learn more, see Integrate your app with an Azure
virtual network.
Best practice : Monitor the security state of your App Service environments.
Detail : Use Microsoft Defender for Cloud to monitor your App Service environments. When Defender for Cloud
identifies potential security vulnerabilities, it creates recommendations that guide you through the process of
configuring the needed controls.

Azure Cloud Services


Azure Cloud Services is an example of a PaaS. Like Azure App Service, this technology is designed to support
applications that are scalable, reliable, and inexpensive to operate. In the same way that App Service is hosted on
virtual machines (VMs), so too is Azure Cloud Services. However, you have more control over the VMs. You can
install your own software on VMs that use Azure Cloud Services, and you can access them remotely.

Install a web application firewall


Web applications are increasingly targets of malicious attacks that exploit common known vulnerabilities.
Common among these exploits are SQL injection attacks, cross site scripting attacks to name a few. Preventing
such attacks in application code can be challenging and may require rigorous maintenance, patching and
monitoring at many layers of the application topology. A centralized web application firewall helps make
security management much simpler and gives better assurance to application administrators against threats or
intrusions. A WAF solution can also react to a security threat faster by patching a known vulnerability at a central
location versus securing each of individual web applications. Existing application gateways can be converted to a
web application firewall enabled application gateway easily.
Web application firewall (WAF) is a feature of Application Gateway that provides centralized protection of your
web applications from common exploits and vulnerabilities. WAF is based on rules from the Open Web
Application Security Project (OWASP) core rule sets 3.0 or 2.2.9.

Monitor the performance of your applications


Monitoring is the act of collecting and analyzing data to determine the performance, health, and availability of
your application. An effective monitoring strategy helps you understand the detailed operation of the
components of your application. It helps you increase your uptime by notifying you of critical issues so that you
can resolve them before they become problems. It also helps you detect anomalies that might be security
related.
Use Azure Application Insights to monitor availability, performance, and usage of your application, whether it's
hosted in the cloud or on-premises. By using Application Insights, you can quickly identify and diagnose errors
in your application without waiting for a user to report them. With the information that you collect, you can
make informed choices on your application's maintenance and improvements.
Application Insights has extensive tools for interacting with the data that it collects. Application Insights stores its
data in a common repository. It can take advantage of shared functionality such as alerts, dashboards, and deep
analysis with the Kusto query language.

Perform security penetration testing


Validating security defenses is as important as testing any other functionality. Make penetration testing a
standard part of your build and deployment process. Schedule regular security tests and vulnerability scanning
on deployed applications, and monitor for open ports, endpoints, and attacks.
Fuzz testing is a method for finding program failures (code errors) by supplying malformed input data to
program interfaces (entry points) that parse and consume this data. Microsoft Security Risk Detection is a cloud-
based tool that you can use to look for bugs and other security vulnerabilities in your software before you
deploy it to Azure. The tool is designed to catch vulnerabilities before you deploy software so you don’t have to
patch a bug, deal with crashes, or respond to an attack after the software is released.

Next steps
In this article, we focused on security advantages of an Azure PaaS deployment and security best practices for
cloud applications. Next, learn recommended practices for securing your PaaS web and mobile solutions using
specific Azure services. We’ll start with Azure App Service, Azure SQL Database and Azure Synapse Analytics,
Azure Storage, and Azure Cloud Services. As articles on recommended practices for other Azure services
become available, links will be provided in the following list:
Azure App Service
Azure SQL Database and Azure Synapse Analytics
Azure Storage
Azure Cloud Services
Azure Cache for Redis
Azure Service Bus
Web Application Firewalls
See Developing secure applications on Azure for security questions and controls you should consider at each
phase of the software development lifecycle when developing applications for the cloud.
See Azure security best practices and patterns for more security best practices to use when you’re designing,
deploying, and managing your cloud solutions by using Azure.
The following resources are available to provide more general information about Azure security and related
Microsoft services:
Azure Security Team Blog - for up to date information on the latest in Azure Security
Microsoft Security Response Center - where Microsoft security vulnerabilities, including issues with Azure,
can be reported or via email to secure@microsoft.com
Best practices for securing PaaS web and mobile
applications using Azure App Service
12/12/2021 • 2 minutes to read • Edit Online

In this article, we discuss a collection of Azure App Service security best practices for securing your PaaS web
and mobile applications. These best practices are derived from our experience with Azure and the experiences of
customers like yourself.
Azure App Service is a platform-as-a-service (PaaS) offering that lets you create web and mobile apps for any
platform or device and connect to data anywhere, in the cloud or on-premises. App Service includes the web
and mobile capabilities that were previously delivered separately as Azure Websites and Azure Mobile Services.
It also includes new capabilities for automating business processes and hosting cloud APIs. As a single
integrated service, App Service brings a rich set of capabilities to web, mobile, and integration scenarios.

Authenticate through Azure Active Directory (AD)


App Service provides an OAuth 2.0 service for your identity provider. OAuth 2.0 focuses on client developer
simplicity while providing specific authorization flows for web applications, desktop applications, and mobile
phones. Azure AD uses OAuth 2.0 to enable you to authorize access to mobile and web applications. To learn
more, see Authentication and authorization in Azure App Service.

Restrict access based on role


Restricting access is imperative for organizations that want to enforce security policies for data access. You can
use Azure role-based access control (Azure RBAC) to assign permissions to users, groups, and applications at a
certain scope, such as the need to know and least privilege security principles. To learn more about granting
users access to applications, see What is Azure role-based access control (Azure RBAC).

Protect your keys


It doesn't matter how good your security is if you lose your subscription keys. Azure Key Vault helps safeguard
cryptographic keys and secrets used by cloud applications and services. With Key Vault, you can encrypt keys
and secrets (such as authentication keys, storage account keys, data encryption keys, .PFX files, and passwords)
by using keys that are protected by hardware security modules (HSMs). For added assurance, you can import or
generate keys in HSMs. You can also use Key Vault to manage your TLS certificates with auto-renewal. See What
is Azure Key Vault to learn more.

Restrict incoming source IP addresses


App Service Environments has a virtual network integration feature that helps you restrict incoming source IP
addresses through network security groups (NSGs). If you are unfamiliar with Azure Virtual Networks (VNETs),
this is a capability that allows you to place many of your Azure resources in a non-internet, routable network
that you control access to. To learn more, see Integrate your app with an Azure Virtual Network.
For App Service on Windows, you can also restrict IP addresses dynamically by configuring the web.config. For
more information, see Dynamic IP Security.

Next steps
This article introduced you to a collection of App Service security best practices for securing your PaaS web and
mobile applications. To learn more about securing your PaaS deployments, see:
Securing PaaS deployments
Securing PaaS databases in Azure
Best practices for securing PaaS web and mobile
applications using Azure Storage
12/12/2021 • 5 minutes to read • Edit Online

In this article, we discuss a collection of Azure Storage security best practices for securing your platform-as-a-
service (PaaS) web and mobile applications. These best practices are derived from our experience with Azure
and the experiences of customers like yourself.
Azure makes it possible to deploy and use storage in ways not easily achievable on-premises. With Azure
storage, you can reach high levels of scalability and availability with relatively little effort. Not only is Azure
Storage the foundation for Windows and Linux Azure Virtual Machines, it can also support large distributed
applications.
Azure Storage provides the following four services: Blob storage, Table storage, Queue storage, and File storage.
To learn more, see Introduction to Microsoft Azure Storage.
The Azure Storage security guide is a great source for detailed information about Azure Storage and security.
This best practices article addresses at a high level some of the concepts found in the security guide and links to
the security guide, as well as other sources, for more information.
This article addresses the following best practices:
Shared access signatures (SAS)
Azure role-based access control (Azure RBAC)
Client side encryption for high value data
Storage Service Encryption

Use a shared access signature instead of a storage account key


Access control is critical. To help you control access to Azure Storage, Azure generates two 512-bit storage
account keys (SAKs) when you create a storage account. The level of key redundancy makes it possible for you
to avoid service interruptions during routine key rotation.
Storage access keys are high priority secrets and should only be accessible to those responsible for storage
access control. If the wrong people get access to these keys, they will have complete control of storage and
could replace, delete, or add files to storage. This includes malware and other types of content that can
potentially compromise your organization or your customers.
You still need a way to provide access to objects in storage. To provide more granular access you can take
advantage of shared access signature (SAS). The SAS makes it possible for you to share specific objects in
storage for a pre-defined time-interval and with specific permissions. A shared access signature allows you to
define:
The interval over which the SAS is valid, including the start time and the expiry time.
The permissions granted by the SAS. For example, a SAS on a blob might grant a user read and write
permissions to that blob, but not delete permissions.
An optional IP address or range of IP addresses from which Azure Storage accepts the SAS. For example, you
might specify a range of IP addresses belonging to your organization. This provides another measure of
security for your SAS.
The protocol over which Azure Storage accepts the SAS. You can use this optional parameter to restrict access
to clients using HTTPS.
SAS allows you to share content the way you want to share it without giving away your storage account keys.
Always using SAS in your application is a secure way to share your storage resources without compromising
your storage account keys.
To learn more about shared access signature, see Using shared access signatures.

Use Azure role-based access control


Another way to manage access is to use Azure role-based access control (Azure RBAC). With Azure RBAC, you
focus on giving employees the exact permissions they need, based on the need to know and least privilege
security principles. Too many permissions can expose an account to attackers. Too few permissions means that
employees can't get their work done efficiently. Azure RBAC helps address this problem by offering fine-grained
access management for Azure. This is imperative for organizations that want to enforce security policies for data
access.
You can use Azure built-in roles in Azure to assign privileges to users. For example, use Storage Account
Contributor for cloud operators that need to manage storage accounts and Classic Storage Account Contributor
role to manage classic storage accounts. For cloud operators that need to manage VMs but not the virtual
network or storage account to which they are connected, you can add them to the Virtual Machine Contributor
role.
Organizations that do not enforce data access control by using capabilities such as Azure RBAC may be giving
more privileges than necessary for their users. This can lead to data compromise by allowing some users access
to data they shouldn’t have in the first place.
To learn more about Azure RBAC see:
Assign Azure roles using the Azure portal
Azure built-in roles
Azure Storage security guide

Use client-side encryption for high value data


Client-side encryption enables you to programmatically encrypt data in transit before uploading to Azure
Storage, and programmatically decrypt data when retrieving it. This provides encryption of data in transit but it
also provides encryption of data at rest. Client-side encryption is the most secure method of encrypting your
data but it does require you to make programmatic changes to your application and put key management
processes in place.
Client-side encryption also enables you to have sole control over your encryption keys. You can generate and
manage your own encryption keys. It uses an envelope technique where the Azure storage client library
generates a content encryption key (CEK) that is then wrapped (encrypted) using the key encryption key (KEK).
The KEK is identified by a key identifier and can be an asymmetric key pair or a symmetric key and can be
managed locally or stored in Azure Key Vault.
Client-side encryption is built into the Java and the .NET storage client libraries. See Client-side encryption and
Azure Key Vault for Microsoft Azure Storage for information on encrypting data within client applications and
generating and managing your own encryption keys.

Enable Storage Service Encryption for data at rest


When Storage Service Encryption for File storage is enabled, the data is encrypted automatically using AES-256
encryption. Microsoft handles all the encryption, decryption, and key management. This feature is available for
LRS and GRS redundancy types.
Next steps
This article introduced you to a collection of Azure Storage security best practices for securing your PaaS web
and mobile applications. To learn more about securing your PaaS deployments, see:
Securing PaaS deployments
Securing PaaS web and mobile applications using Azure App Services
Securing PaaS databases in Azure
Best practices for securing PaaS databases in Azure
12/12/2021 • 4 minutes to read • Edit Online

In this article, we discuss a collection of Azure SQL Database and Azure Synapse Analytics security best practices
for securing your platform-as-a-service (PaaS) web and mobile applications. These best practices are derived
from our experience with Azure and the experiences of customers like yourself.
Azure SQL Database and Azure Synapse Analytics provide a relational database service for your internet-based
applications. Let’s look at services that help protect your applications and data when using Azure SQL Database
and Azure Synapse Analytics in a PaaS deployment:
Azure Active Directory authentication (instead of SQL Server authentication)
Azure SQL firewall
Transparent Data Encryption (TDE)

Use a centralized identity repository


Azure SQL Database can be configured to use one of two types of authentication:
SQL authentication uses a username and password. When you created the server for your database,
you specified a "server admin" login with a username and password. Using these credentials, you can
authenticate to any database on that server as the database owner.
Azure Active Director y authentication uses identities managed by Azure Active Directory and is
supported for managed and integrated domains. To use Azure Active Directory Authentication, you must
create another server admin called the "Azure AD admin," which is allowed to administer Azure AD users
and groups. This admin can also perform all operations that a regular server admin can.
Azure Active Directory authentication is a mechanism of connecting to Azure SQL Database and Azure Synapse
Analytics by using identities in Azure Active Directory (AD). Azure AD provides an alternative to SQL Server
authentication so you can stop the proliferation of user identities across database servers. Azure AD
authentication enables you to centrally manage the identities of database users and other Microsoft services in
one central location. Central ID management provides a single place to manage database users and simplifies
permission management.
Benefits of using Azure AD instead of SQL authentication
Allows password rotation in a single place.
Manages database permissions using external Azure AD groups.
Eliminates storing passwords by enabling integrated Windows authentication and other forms of
authentication supported by Azure AD.
Uses contained database users to authenticate identities at the database level.
Supports token-based authentication for applications connecting to SQL Database.
Supports domain federation with Active Directory Federation Services (ADFS) or native user/password
authentication for a local Azure AD without domain synchronization.
Supports connections from SQL Server Management Studio that use Active Directory Universal
Authentication, which includes Multi-Factor Authentication (MFA). MFA includes strong authentication with a
range of easy verification options — phone call, text message, smart cards with pin, or mobile app
notification. For more information, see Universal Authentication with SQL Database and Azure Synapse
Analytics.
To learn more about Azure AD authentication, see:
Use Azure Active Directory Authentication for authentication with SQL Database, Managed Instance, or Azure
Synapse Analytics
Authentication to Azure Synapse Analytics
Token-based authentication support for Azure SQL Database using Azure AD authentication

NOTE
To ensure that Azure Active Directory is a good fit for your environment, see Azure AD features and limitations.

Restrict access based on IP address


You can create firewall rules that specify ranges of acceptable IP addresses. These rules can be targeted at both
the server and database levels. We recommend using database-level firewall rules whenever possible to
enhance security and to make your database more portable. Server-level firewall rules are best used for
administrators and when you have many databases that have the same access requirements but you don't want
to spend time configuring each database individually.
SQL Database default source IP address restrictions allow access from any Azure address, including other
subscriptions and tenants. You can restrict this to only allow your IP addresses to access the instance. Even with
your SQL firewall and IP address restrictions, strong authentication is still needed. See the recommendations
made earlier in this article.
To learn more about Azure SQL Firewall and IP restrictions, see:
Azure SQL Database and Azure Synapse Analytics access control
Azure SQL Database and Azure Synapse Analytics firewall rules

Encrypt data at rest


Transparent Data Encryption (TDE) is enabled by default. TDE transparently encrypts SQL Server, Azure SQL
Database, and Azure Synapse Analytics data and log files. TDE protects against a compromise of direct access to
the files or their backup. This enables you to encrypt data at rest without changing existing applications. TDE
should always stay enabled; however, this will not stop an attacker using the normal access path. TDE provides
the ability to comply with many laws, regulations, and guidelines established in various industries.
Azure SQL manages key related issues for TDE. As with TDE, on-premises special care must be taken to ensure
recoverability and when moving databases. In more sophisticated scenarios, the keys can be explicitly managed
in Azure Key Vault through extensible key management. See Enable TDE on SQL Server Using EKM. This also
allows for Bring Your Own Key (BYOK) through Azure Key Vaults BYOK capability.
Azure SQL provides encryption for columns through Always Encrypted. This allows only authorized applications
access to sensitive columns. Using this kind of encryption limits SQL queries for encrypted columns to equality-
based values.
Application level encryption should also be used for selective data. Data sovereignty concerns can sometimes be
mitigated by encrypting data with a key that is kept in the correct country/region. This prevents even accidental
data transfer from causing an issue since it is impossible to decrypt the data without the key, assuming a strong
algorithm is used (such as AES 256).
You can use additional precautions to help secure the database, such as designing a secure system, encrypting
confidential assets, and building a firewall around the database servers.
Next steps
This article introduced you to a collection of SQL Database and Azure Synapse Analytics security best practices
for securing your PaaS web and mobile applications. To learn more about securing your PaaS deployments, see:
Securing PaaS deployments
Securing PaaS web and mobile applications using Azure App Services
Azure Service Fabric security best practices
12/12/2021 • 10 minutes to read • Edit Online

Deploying an application on Azure is fast, easy, and cost-effective. Before you deploy your cloud application into
production, review our list of essential and recommended best practices for implementing secure clusters in
your application.
Azure Service Fabric is a distributed systems platform that makes it easy to package, deploy, and manage
scalable and reliable microservices. Service Fabric also addresses the significant challenges in developing and
managing cloud applications. Developers and administrators can avoid complex infrastructure problems and
focus on implementing mission-critical, demanding workloads that are scalable, reliable, and manageable.
For each best practice, we explain:
What the best practice is.
Why you should implement the best practice.
What might happen if you don't implement the best practice.
How you can learn to implement the best practice.
We recommend the following Azure Service Fabric security best practices:
Use Azure Resource Manager templates and the Service Fabric PowerShell module to create secure clusters.
Use X.509 certificates.
Configure security policies.
Implement the Reliable Actors security configuration.
Configure TLS for Azure Service Fabric.
Use network isolation and security with Azure Service Fabric.
Configure Azure Key Vault for security.
Assign users to roles.

Best practices for securing your clusters


Always use a secure cluster:
Implement cluster security by using certificates.
Provide client access (admin and read-only) by using Azure Active Directory (Azure AD).
Use automated deployments:
Use scripts to generate, deploy, and roll over the secrets.
Store the secrets in Azure Key Vault and use Azure AD for all other client access.
Require authentication for human access to the secrets.
Additionally, consider the following configuration options:
Create perimeter networks (also known as demilitarized zones, DMZs, and screened subnets) by using Azure
Network Security Groups (NSGs).
Access cluster virtual machines (VMs) or manage your cluster by using jump servers with Remote Desktop
Connection.
Your clusters must be secured to prevent unauthorized users from connecting, especially when a cluster is
running in production. Although it's possible to create an unsecured cluster, anonymous users can connect to
your cluster if the cluster exposes management endpoints to the public internet.
There are three scenarios for implementing cluster security by using various technologies:
Node-to-node security: This scenario secures communication between the VMs and the computers in the
cluster. This form of security ensures that only those computers that are authorized to join the cluster can
host applications and services in the cluster. In this scenario, the clusters that run on Azure, or standalone
clusters that run on Windows, can use either certificate security or Windows security for Windows Server
machines.
Client-to-node security: This scenario secures communication between a Service Fabric client and the
individual nodes in the cluster.
Service Fabric role-based access control (Service Fabric RBAC): This scenario uses separate identities
(certificates, Azure AD, and so on) for each administrator and user client role that accesses the cluster. You
specify the role identities when you create the cluster.

NOTE
Security recommendation for Azure clusters: Use Azure AD security to authenticate clients and certificates for
node-to-node security.

To configure a standalone Windows cluster, see Configure settings for a standalone Windows cluster.
Use Azure Resource Manager templates and the Service Fabric PowerShell module to create a secure cluster. For
step-by-step instructions to create a secure Service Fabric cluster by using Azure Resource Manager templates,
see Creating a Service Fabric cluster.
Use the Azure Resource Manager template:
Customize your cluster by using the template to configure managed storage for VM virtual hard disks
(VHDs).
Drive changes to your resource group by using the template for easy configuration management and
auditing.
Treat your cluster configuration as code:
Be thorough when checking your deployment configurations.
Avoid using implicit commands to directly modify your resources.
Many aspects of the Service Fabric application lifecycle can be automated. The Service Fabric PowerShell module
automates common tasks for deploying, upgrading, removing, and testing Azure Service Fabric applications.
Managed APIs and HTTP APIs for application management are also available.

Use X.509 certificates


Always secure your clusters by using X.509 certificates or Windows security. Security is only configured at
cluster creation time. It's not possible to turn on security after the cluster is created.
To specify a cluster certificate, set the value of the ClusterCredentialType property to X509. To specify a server
certificate for outside connections, set the Ser verCredentialType property to X509.
In addition, follow these practices:
Create the certificates for production clusters by using a correctly configured Windows Server certificate
service. You can also obtain the certificates from an approved certificate authority (CA).
Never use a temporary or test certificate for production clusters if the certificate was created by using
MakeCert.exe or a similar tool.
Use a self-signed certificate for test clusters, but not for production clusters.
If the cluster is unsecure, anyone can connect to the cluster anonymously and perform management operations.
For this reason, always secure production clusters by using X.509 certificates or Windows security.
To learn more about using X.509 certificates, see Add or remove certificates for a Service Fabric cluster.

Configure security policies


Service Fabric also secures the resources that are used by applications. Resources like files, directories, and
certificates are stored under the user accounts when the application is deployed. This feature makes running
applications more secure from one another, even in a shared hosted environment.
Use an Active Directory domain group or user: Run the service under the credentials for an Active
Directory user or group account. Be sure to use Active Directory on-premises within your domain and
not Azure Active Directory. Access other resources in the domain that have been granted permissions by
using a domain user or group. For example, resources such as file shares.
Assign a security access policy for HTTP and HTTPS endpoints: Specify the SecurityAccessPolicy
property to apply a RunAs policy to a service when the service manifest declares endpoint resources
with HTTP. Ports allocated to the HTTP endpoints are correctly access-controlled lists for the RunAs user
account that the service runs under. When the policy isn't set, http.sys doesn't have access to the service
and you can get failures with calls from the client.
To learn how to use security policies in a Service Fabric cluster, see Configure security policies for your
application.

Implement the Reliable Actors security configuration


Service Fabric Reliable Actors is an implementation of the actor design pattern. As with any software design
pattern, the decision to use a specific pattern is based on whether a software problem fits the pattern.
In general, use the actor design pattern to help model solutions for the following software problems or security
scenarios:
Your problem space involves a large number (thousands or more) of small, independent, and isolated units
of state and logic.
You're working with single-threaded objects that don't require significant interaction from external
components, including querying state across a set of actors.
Your actor instances don't block callers with unpredictable delays by issuing I/O operations.
In Service Fabric, actors are implemented in the Reliable Actors application framework. This framework is based
on the actor pattern and built on top of Service Fabric Reliable Services. Each reliable actor service that you write
is a partitioned stateful reliable service.
Every actor is defined as an instance of an actor type, identical to the way a .NET object is an instance of a .NET
type. For example, an actor type that implements the functionality of a calculator can have many actors of that
type that are distributed on various nodes across a cluster. Each of the distributed actors is uniquely
characterized by an actor identifier.
Replicator security configurations are used to secure the communication channel that is used during replication.
This configuration prevents services from seeing each other's replication traffic and ensures that highly available
data is secure. By default, an empty security configuration section prevents replication security. Replicator
configurations configure the replicator that is responsible for making the Actor State Provider state highly
reliable.
Configure TLS for Azure Service Fabric
The server authentication process authenticates the cluster management endpoints to a management client. The
management client then recognizes that it's talking to the real cluster. This certificate also provides a TLS for the
HTTPS management API and for Service Fabric Explorer over HTTPS. You must obtain a custom domain name
for your cluster. When you request a certificate from a certificate authority, the certificate's subject name must
match the custom domain name that you use for your cluster.
To configure TLS for an application, you first need to obtain an SSL/TLS certificate that has been signed by a CA.
The CA is a trusted third party that issues certificates for TLS security purposes. If you don't already have an
SSL/TLS certificate, you need to obtain one from a company that sells SSL/TLS certificates.
The certificate must meet the following requirements for SSL/TLS certificates in Azure:
The certificate must contain a private key.
The certificate must be created for key exchange and be exportable to a personal information exchange
(.pfx) file.
The certificate's subject name must match the domain name that is used to access your cloud service.
Acquire a custom domain name to use for accessing your cloud service.
Request a certificate from a CA with a subject name that matches your service's custom domain name.
For example, if your custom domain name is contoso .com , the certificate from your CA should have
the subject name .contoso.com or www .contoso.com .

NOTE
You cannot obtain an SSL/TLS certificate from a CA for the cloudapp .net domain.

The certificate must use a minimum of 2,048-bit encryption.


The HTTP protocol is unsecure and subject to eavesdropping attacks. Data that is transmitted over HTTP is sent
as plain text from the web browser to the web server or between other endpoints. Attackers can intercept and
view sensitive data that is sent via HTTP, such as credit card details and account logins. When data is sent or
posted through a browser via HTTPS, SSL ensures that sensitive information is encrypted and secure from
interception.
To learn more about using SSL/TLS certificates, see Configuring TLS for an application in Azure.

Use network isolation and security with Azure Service Fabric


Set up a 3 nodetype secure cluster by using the Azure Resource Manager template as a sample. Control the
inbound and outbound network traffic by using the template and Network Security Groups.
The template has an NSG for each of the virtual machine scale sets and is used to control the traffic in and out of
the set. The rules are configured by default to allow all traffic necessary for the system services and the
application ports specified in the template. Review these rules and make any changes to fit your needs, including
adding new rules for your applications.
For more information, see Common networking scenarios for Azure Service Fabric.

Set up Azure Key Vault for security


Service Fabric uses certificates to provide authentication and encryption for securing a cluster and its
applications.
Service Fabric uses X.509 certificates to secure a cluster and to provide application security features. You use
Azure Key Vault to manage certificates for Service Fabric clusters in Azure. The Azure resource provider that
creates the clusters pulls the certificates from a key vault. The provider then installs the certificates on the VMs
when the cluster is deployed on Azure.
A certificate relationship exists between Azure Key Vault, the Service Fabric cluster, and the resource provider
that uses the certificates. When the cluster is created, information about the certificate relationship is stored in a
key vault.
There are two basic steps to set up a key vault:
1. Create a resource group specifically for your key vault.
We recommend that you put the key vault in its own resource group. This action helps to prevent the loss
of your keys and secrets if other resource groups are removed, such as storage, compute, or the group
that contains your cluster. The resource group that contains your key vault must be in the same region as
the cluster that is using it.
2. Create a key vault in the new resource group.
The key vault must be enabled for deployment. The compute resource provider can then get the
certificates from the vault and install them on the VM instances.
To learn more about how to set up a key vault, see What is Azure Key Vault?.

Assign users to roles


After you've created the applications to represent your cluster, assign your users to the roles that are supported
by Service Fabric: read-only and admin. You can assign these roles by using the Azure portal.

NOTE
For more information about using roles in Service Fabric, see Service Fabric role-based access control for Service Fabric
clients.

Azure Service Fabric supports two access control types for clients that are connected to a Service Fabric cluster:
administrator and user. The cluster administrator can use access control to limit access to certain cluster
operations for different groups of users. Access control makes the cluster more secure.

Next steps
Service Fabric security checklist
Set up your Service Fabric development environment.
Learn about Service Fabric support options.
Azure security logging and auditing
12/12/2021 • 3 minutes to read • Edit Online

Azure provides a wide array of configurable security auditing and logging options to help you identify gaps in
your security policies and mechanisms. This article discusses generating, collecting, and analyzing security logs
from services hosted on Azure.

NOTE
Certain recommendations in this article might result in increased data, network, or compute resource usage, and increase
your license or subscription costs.

Types of logs in Azure


Cloud applications are complex with many moving parts. Logging data can provide insights about your
applications and help you:
Troubleshoot past problems or prevent potential ones
Improve application performance or maintainability
Automate actions that would otherwise require manual intervention
Azure logs are categorized into the following types:
Control/management logs provide information about Azure Resource Manager CREATE, UPDATE, and
DELETE operations. For more information, see Azure activity logs.
Data plane logs provide information about events raised as part of Azure resource usage. Examples of
this type of log are the Windows event system, security, and application logs in a virtual machine (VM)
and the diagnostics logs that are configured through Azure Monitor.
Processed events provide information about analyzed events/alerts that have been processed on your
behalf. Examples of this type are Microsoft Defender for Cloud alerts where Microsoft Defender for Cloud
has processed and analyzed your subscription and provides concise security alerts.
The following table lists the most important types of logs available in Azure:

LO G C AT EGO RY LO G T Y P E USA GE IN T EGRAT IO N

Activity logs Control-plane events on Provides insight into the Rest API, Azure Monitor
Azure Resource Manager operations that were
resources performed on resources in
your subscription.

Azure Resource logs Frequent data about the Provides insight into Azure Monitor
operation of Azure Resource operations that your
Manager resources in resource itself performed.
subscription
LO G C AT EGO RY LO G T Y P E USA GE IN T EGRAT IO N

Azure Active Directory Logs and reports Reports user sign-in Graph API
reporting activities and system
activity information about
users and group
management.

Virtual machines and cloud Windows Event Log service Captures system data and Windows (using Windows
services and Linux Syslog logging data on the virtual Azure Diagnostics [WAD]
machines and transfers that storage) and Linux in Azure
data into a storage account Monitor
of your choice.

Azure Storage Analytics Storage logging, provides Provides insight into trace REST API or the client
metrics data for a storage requests, analyzes usage library
account trends, and diagnoses
issues with your storage
account.

Network security group JSON format, shows Displays information about Azure Network Watcher
(NSG) flow logs outbound and inbound ingress and egress IP traffic
flows on a per-rule basis through a Network Security
Group.

Application insight Logs, exceptions, and Provides an application REST API, Power BI
custom diagnostics performance monitoring
(APM) service for web
developers on multiple
platforms.

Process data / security Microsoft Defender for Provides security REST APIs, JSON
alerts Cloud alerts, Azure Monitor information and alerts.
logs alerts

Log integration with on-premises SIEM systems


Integrating Defender for Cloud alerts discusses how to sync Defender for Cloud alerts, virtual machine security
events collected by Azure diagnostics logs, and Azure audit logs with your Azure Monitor logs or SIEM solution.

Next steps
Auditing and logging: Protect data by maintaining visibility and responding quickly to timely security
alerts.
Security logging and audit-log collection within Azure: Enforce these settings to ensure that your Azure
instances are collecting the correct security and audit logs.
Configure audit settings for a site collection: If you're a site collection administrator, retrieve the history of
individual users' actions and the history of actions taken during a particular date range.
Search the audit log in the Microsoft 365 Defender portal: Use the Microsoft 365 Defender portal to
search the unified audit log and view user and administrator activity in your organization.
Azure security management and monitoring
overview
12/12/2021 • 5 minutes to read • Edit Online

This article provides an overview of the security features and services that Azure provides to aid in the
management and monitoring of Azure cloud services and virtual machines.

Azure role-based access control


Azure role-based access control (Azure RBAC) provides detailed access management for Azure resources. By
using Azure RBAC, you can grant people only the amount of access that they need to perform their jobs. Azure
RBAC can also help you ensure that when people leave the organization, they lose access to resources in the
cloud.
Learn more:
Active Directory team blog on Azure RBAC
Azure role-based access control (Azure RBAC)

Antimalware
With Azure, you can use antimalware software from major security vendors such as Microsoft, Symantec, Trend
Micro, McAfee, and Kaspersky. This software helps protect your virtual machines from malicious files, adware,
and other threats.
Microsoft Antimalware for Azure Cloud Services and Virtual Machines offers you the ability to install an
antimalware agent for both PaaS roles and virtual machines. Based on System Center Endpoint Protection, this
feature brings proven on-premises security technology to the cloud.
We also offer deep integration for Trend’s Deep Security and SecureCloud products in the Azure platform. Deep
Security is an antivirus solution, and SecureCloud is an encryption solution. Deep Security is deployed inside
VMs through an extension model. By using the Azure portal UI and PowerShell, you can choose to use Deep
Security inside new VMs that are being spun up, or existing VMs that are already deployed.
Symantec Endpoint Protection (SEP) is also supported on Azure. Through portal integration, you can specify that
you intend to use SEP on a VM. SEP can be installed on a new VM via the Azure portal, or it can be installed on
an existing VM via PowerShell.
Learn more:
Deploying Antimalware Solutions on Azure Virtual Machines
Microsoft Antimalware for Azure Cloud Services and Virtual Machines
How to install and configure Trend Micro Deep Security as a Service on a Windows VM
How to install and configure Symantec Endpoint Protection on a Windows VM
New Antimalware Options for Protecting Azure Virtual Machines

Multi-Factor Authentication
Azure AD Multi-Factor Authentication is a method of authentication that requires the use of more than one
verification method. It adds a critical second layer of security to user sign-ins and transactions.
Multi-Factor Authentication helps safeguard access to data and applications while meeting user demand for a
simple sign-in process. It delivers strong authentication via a range of verification options (phone call, text
message, or mobile app notification or verification code) and third-party OATH tokens.
Learn more:
Multi-Factor Authentication
What is Azure AD Multi-Factor Authentication?
How Azure AD Multi-Factor Authentication works

ExpressRoute
You can use Azure ExpressRoute to extend your on-premises networks into the Microsoft Cloud over a dedicated
private connection that's facilitated by a connectivity provider. With ExpressRoute, you can establish connections
to Microsoft cloud services such as Azure, Microsoft 365, and CRM Online. Connectivity can be from:
An any-to-any (IP VPN) network.
A point-to-point Ethernet network.
A virtual cross-connection through a connectivity provider at a co-location facility.
ExpressRoute connections don't go over the public internet. They can offer more reliability, faster speeds, lower
latencies, and higher security than typical connections over the internet.
Learn more:
ExpressRoute technical overview

Virtual network gateways


VPN gateways, also called Azure virtual network gateways, are used to send network traffic between virtual
networks and on-premises locations. They are also used to send traffic between multiple virtual networks within
Azure (network to network). VPN gateways provide secure cross-premises connectivity between Azure and your
infrastructure.
Learn more:
About VPN gateways
Azure network security overview

Privileged Identity Management


Sometimes users need to carry out privileged operations in Azure resources or other SaaS applications. This
often means organizations give them permanent privileged access in Azure Active Directory (Azure AD).
This is a growing security risk for cloud-hosted resources because organizations can't sufficiently monitor what
those users are doing with their privileged access. Additionally, if a user account with privileged access is
compromised, that one breach can affect an organization's overall cloud security. Azure AD Privileged Identity
Management helps to resolve this risk by lowering the exposure time of privileges and increasing visibility into
usage.
Privileged Identity Management introduces the concept of a temporary admin for a role or “just in time”
administrator access. This kind of admin is a user who needs to complete an activation process for that assigned
role. The activation process changes the assignment of the user to a role in Azure AD from inactive to active, for
a specified time period.
Learn more:
Azure AD Privileged Identity Management
Get started with Azure AD Privileged Identity Management

Identity Protection
Azure AD Identity Protection provides a consolidated view of suspicious sign-in activities and potential
vulnerabilities to help protect your business. Identity Protection detects suspicious activities for users and
privileged (admin) identities, based on signals like:
Brute-force attacks.
Leaked credentials.
Sign-ins from unfamiliar locations and infected devices.
By providing notifications and recommended remediation, Identity Protection helps to mitigate risks in real time.
It calculates user risk severity. You can configure risk-based policies to automatically help safeguard application
access from future threats.
Learn more:
Azure Active Directory Identity Protection
Channel 9: Azure AD and Identity Show: Identity Protection Preview

Defender for Cloud


Microsoft Defender for Cloud helps you prevent, detect, and respond to threats. Defender for Cloud gives you
increased visibility into, and control over, the security of your Azure resources as well as those in your hybrid
cloud environment.
Defender for Cloud performs continuous security assessments of your connected resources and compares their
configuration and deployment against the Azure Security Benchmark to provide detailed security
recommendations tailored for your environment.
Defender for Cloud helps you optimize and monitor the security of your Azure resources by:
Enabling you to define policies for your Azure subscription resources according to:
Your organization’s security needs.
The type of applications or sensitivity of the data in each subscription.
Any industry or regulatory standards or benchmarks you apply to your subscriptions.
Monitoring the state of your Azure virtual machines, networking, and applications.
Providing a list of prioritized security alerts, including alerts from integrated partner solutions. It also
provides the information that you need to quickly investigate an attack and recommendations on how to
remediate it.
Learn more:
Introduction to Microsoft Defender for Cloud
Improve your secure score in Microsoft Defender for Cloud

Intelligent Security Graph


Intelligent Security Graph provides real-time threat protection in Microsoft products and services. It uses
advanced analytics that link a massive amount of threat intelligence and security data to provide insights that
can strengthen organizational security. Microsoft uses advanced analytics—processing more than 450 billion
authentications per month, scanning 400 billion emails for malware and phishing, and updating one billion
devices—to deliver richer insights. These insights can help your organization detect and respond to attacks
quickly.
Intelligent Security Graph

Next Steps
Learn about the shared responsibility model and which security tasks are handled by Microsoft and which tasks
are handled by you.
For more information about security management, see Security management in Azure.
Security management in Azure
12/12/2021 • 18 minutes to read • Edit Online

Azure subscribers may manage their cloud environments from multiple devices, including management
workstations, developer PCs, and even privileged end-user devices that have task-specific permissions. In some
cases, administrative functions are performed through web-based consoles such as the Azure portal. In other
cases, there may be direct connections to Azure from on-premises systems over Virtual Private Networks
(VPNs), Terminal Services, client application protocols, or (programmatically) the Azure Service Management
API (SMAPI). Additionally, client endpoints can be either domain joined or isolated and unmanaged, such as
tablets or smartphones.
Although multiple access and management capabilities provide a rich set of options, this variability can add
significant risk to a cloud deployment. It can be difficult to manage, track, and audit administrative actions. This
variability may also introduce security threats through unregulated access to client endpoints that are used for
managing cloud services. Using general or personal workstations for developing and managing infrastructure
opens unpredictable threat vectors such as web browsing (for example, watering hole attacks) or email (for
example, social engineering and phishing).

The potential for attacks increases in this type of environment because it is challenging to construct security
policies and mechanisms to appropriately manage access to Azure interfaces (such as SMAPI) from widely
varied endpoints.
Remote management threats
Attackers often attempt to gain privileged access by compromising account credentials (for example, through
password brute forcing, phishing, and credential harvesting), or by tricking users into running harmful code (for
example, from harmful websites with drive-by downloads or from harmful email attachments). In a remotely
managed cloud environment, account breaches can lead to an increased risk due to anywhere, anytime access.
Even with tight controls on primary administrator accounts, lower-level user accounts can be used to exploit
weaknesses in one’s security strategy. Lack of appropriate security training can also lead to breaches through
accidental disclosure or exposure of account information.
When a user workstation is also used for administrative tasks, it can be compromised at many different points.
Whether a user is browsing the web, using 3rd-party and open-source tools, or opening a harmful document
file that contains a trojan.
In general, most targeted attacks that result in data breaches can be traced to browser exploits, plug-ins (such as
Flash, PDF, Java), and spear phishing (email) on desktop machines. These machines may have administrative-
level or service-level permissions to access live servers or network devices for operations when used for
development or management of other assets.
Operational security fundamentals
For more secure management and operations, you can minimize a client’s attack surface by reducing the
number of possible entry points. This can be done through security principles: “separation of duties” and
“segregation of environments.”
Isolate sensitive functions from one another to decrease the likelihood that a mistake at one level leads to a
breach in another. Examples:
Administrative tasks should not be combined with activities that might lead to a compromise (for example,
malware in an administrator’s email that then infects an infrastructure server).
A workstation used for high-sensitivity operations should not be the same system used for high-risk
purposes such as browsing the Internet.
Reduce the system’s attack surface by removing unnecessary software. Example:
Standard administrative, support, or development workstation should not require installation of an email
client or other productivity applications if the device’s main purpose is to manage cloud services.
Client systems that have administrator access to infrastructure components should be subjected to the strictest
possible policy to reduce security risks. Examples:
Security policies can include Group Policy settings that deny open Internet access from the device and use of
a restrictive firewall configuration.
Use Internet Protocol security (IPsec) VPNs if direct access is needed.
Configure separate management and development Active Directory domains.
Isolate and filter management workstation network traffic.
Use antimalware software.
Implement multi-factor authentication to reduce the risk of stolen credentials.
Consolidating access resources and eliminating unmanaged endpoints also simplifies management tasks.
Providing security for Azure remote management
Azure provides security mechanisms to aid administrators who manage Azure cloud services and virtual
machines. These mechanisms include:
Authentication and Azure role-based access control (Azure RBAC).
Monitoring, logging, and auditing.
Certificates and encrypted communications.
A web management portal.
Network packet filtering.
With client-side security configuration and datacenter deployment of a management gateway, it is possible to
restrict and monitor administrator access to cloud applications and data.
NOTE
Certain recommendations in this article may result in increased data, network, or compute resource usage, and may
increase your license or subscription costs.

Hardened workstation for management


The goal of hardening a workstation is to eliminate all but the most critical functions required for it to operate,
making the potential attack surface as small as possible. System hardening includes minimizing the number of
installed services and applications, limiting application execution, restricting network access to only what is
needed, and always keeping the system up to date. Furthermore, using a hardened workstation for
management segregates administrative tools and activities from other end-user tasks.
Within an on-premises enterprise environment, you can limit the attack surface of your physical infrastructure
through dedicated management networks, server rooms that have card access, and workstations that run on
protected areas of the network. In a cloud or hybrid IT model, being diligent about secure management services
can be more complex because of the lack of physical access to IT resources. Implementing protection solutions
requires careful software configuration, security-focused processes, and comprehensive policies.
Using a least-privilege minimized software footprint in a locked-down workstation for cloud management—and
for application development—can reduce the risk of security incidents by standardizing the remote
management and development environments. A hardened workstation configuration can help prevent the
compromise of accounts that are used to manage critical cloud resources by closing many common avenues
used by malware and exploits. Specifically, you can use Windows AppLocker and Hyper-V technology to control
and isolate client system behavior and mitigate threats, including email or Internet browsing.
On a hardened workstation, the administrator runs a standard user account (which blocks administrative-level
execution) and associated applications are controlled by an allow list. The basic elements of a hardened
workstation are as follows:
Active scanning and patching. Deploy antimalware software, perform regular vulnerability scans, and update
all workstations by using the latest security update in a timely fashion.
Limited functionality. Uninstall any applications that are not needed and disable unnecessary (startup)
services.
Network hardening. Use Windows Firewall rules to allow only valid IP addresses, ports, and URLs related to
Azure management. Ensure that inbound remote connections to the workstation are also blocked.
Execution restriction. Allow only a set of predefined executable files that are needed for management to run
(referred to as “default-deny”). By default, users should be denied permission to run any program unless it is
explicitly defined in the allow list.
Least privilege. Management workstation users should not have any administrative privileges on the local
machine itself. This way, they cannot change the system configuration or the system files, either intentionally
or unintentionally.
You can enforce all this by using Group Policy Objects (GPOs) in Active Directory Domain Services (AD DS) and
applying them through your (local) management domain to all management accounts.
Managing services, applications, and data
Azure cloud services configuration is performed through either the Azure portal or SMAPI, via the Windows
PowerShell command-line interface or a custom-built application that takes advantage of these RESTful
interfaces. Services using these mechanisms include Azure Active Directory (Azure AD), Azure Storage, Azure
Websites, and Azure Virtual Network, and others.
Virtual Machine–deployed applications provide their own client tools and interfaces as needed, such as the
Microsoft Management Console (MMC), an enterprise management console (such as Microsoft System Center
or Windows Intune), or another management application—Microsoft SQL Server Management Studio, for
example. These tools typically reside in an enterprise environment or client network. They may depend on
specific network protocols, such as Remote Desktop Protocol (RDP), that require direct, stateful connections.
Some may have web-enabled interfaces that should not be openly published or accessible via the Internet.
You can restrict access to infrastructure and platform services management in Azure by using multi-factor
authentication, X.509 management certificates, and firewall rules. The Azure portal and SMAPI require Transport
Layer Security (TLS). However, services and applications that you deploy into Azure require you to take
protection measures that are appropriate based on your application. These mechanisms can frequently be
enabled more easily through a standardized hardened workstation configuration.
Management gateway
To centralize all administrative access and simplify monitoring and logging, you can deploy a dedicated Remote
Desktop Gateway (RD Gateway) server in your on-premises network, connected to your Azure environment.
A Remote Desktop Gateway is a policy-based RDP proxy service that enforces security requirements.
Implementing RD Gateway together with Windows Server Network Access Protection (NAP) helps ensure that
only clients that meet specific security health criteria established by Active Directory Domain Services (AD DS)
Group Policy objects (GPOs) can connect. In addition:
Provision an Azure management certificate on the RD Gateway so that it is the only host allowed to access
the Azure portal.
Join the RD Gateway to the same management domain as the administrator workstations. This is necessary
when you are using a site-to-site IPsec VPN or ExpressRoute within a domain that has a one-way trust to
Azure AD, or if you are federating credentials between your on-premises AD DS instance and Azure AD.
Configure a client connection authorization policy to let the RD Gateway verify that the client machine name
is valid (domain joined) and allowed to access the Azure portal.
Use IPsec for Azure VPN to further protect management traffic from eavesdropping and token theft, or
consider an isolated Internet link via Azure ExpressRoute.
Enable multi-factor authentication (via Azure AD Multi-Factor Authentication) or smart-card authentication
for administrators who log on through RD Gateway.
Configure source IP address restrictions or Network Security Groups in Azure to minimize the number of
permitted management endpoints.

Security guidelines
In general, helping to secure administrator workstations for use with the cloud is similar to the practices used
for any workstation on-premises—for example, minimized build and restrictive permissions. Some unique
aspects of cloud management are more akin to remote or out-of-band enterprise management. These include
the use and auditing of credentials, security-enhanced remote access, and threat detection and response.
Authentication
You can use Azure logon restrictions to constrain source IP addresses for accessing administrative tools and
audit access requests. To help Azure identify management clients (workstations and/or applications), you can
configure both SMAPI (via customer-developed tools such as Windows PowerShell cmdlets) and the Azure
portal to require client-side management certificates to be installed, in addition to TLS/SSL certificates. We also
recommend that administrator access require multi-factor authentication.
Some applications or services that you deploy into Azure may have their own authentication mechanisms for
both end-user and administrator access, whereas others take full advantage of Azure AD. Depending on whether
you are federating credentials via Active Directory Federation Services (AD FS), using directory synchronization
or maintaining user accounts solely in the cloud, using Microsoft Identity Manager (part of Azure AD Premium)
helps you manage identity lifecycles between the resources.
Connectivity
Several mechanisms are available to help secure client connections to your Azure virtual networks. Two of these
mechanisms, site-to-site VPN (S2S) and point-to-site VPN (P2S), enable the use of industry standard IPsec (S2S)
or the Secure Socket Tunneling Protocol (SSTP) (P2S) for encryption and tunneling. When Azure is connecting to
public-facing Azure services management such as the Azure portal, Azure requires Hypertext Transfer Protocol
Secure (HTTPS).
A stand-alone hardened workstation that does not connect to Azure through an RD Gateway should use the
SSTP-based point-to-site VPN to create the initial connection to the Azure Virtual Network, and then establish
RDP connection to individual virtual machines from with the VPN tunnel.
Management auditing vs. policy enforcement
Typically, there are two approaches for helping to secure management processes: auditing and policy
enforcement. Doing both provides comprehensive controls, but may not be possible in all situations. In addition,
each approach has different levels of risk, cost, and effort associated with managing security, particularly as it
relates to the level of trust placed in both individuals and system architectures.
Monitoring, logging, and auditing provide a basis for tracking and understanding administrative activities, but it
may not always be feasible to audit all actions in complete detail due to the amount of data generated. Auditing
the effectiveness of the management policies is a best practice, however.
Policy enforcement that includes strict access controls puts programmatic mechanisms in place that can govern
administrator actions, and it helps ensure that all possible protection measures are being used. Logging
provides proof of enforcement, in addition to a record of who did what, from where, and when. Logging also
enables you to audit and crosscheck information about how administrators follow policies, and it provides
evidence of activities

Client configuration
We recommend three primary configurations for a hardened workstation. The biggest differentiators between
them are cost, usability, and accessibility, while maintaining a similar security profile across all options. The
following table provides a short analysis of the benefits and risks to each. (Note that “corporate PC” refers to a
standard desktop PC configuration that would be deployed for all domain users, regardless of roles.)

C O N F IGURAT IO N B EN EF IT S C ONS

Stand-alone hardened workstation Tightly controlled workstation higher cost for dedicated desktops

- Reduced risk of application exploits Increased management effort

- Clear separation of duties -

Corporate PC as virtual machine Reduced hardware costs -

- Segregation of role and applications -

It is important that the hardened workstation is the host and not the guest, with nothing between the host
operating system and the hardware. Following the “clean source principle” (also known as “secure origin”)
means that the host should be the most hardened. Otherwise, the hardened workstation (guest) is subject to
attacks on the system on which it is hosted.
You can further segregate administrative functions through dedicated system images for each hardened
workstation that have only the tools and permissions needed for managing select Azure and cloud applications,
with specific local AD DS GPOs for the necessary tasks.
For IT environments that have no on-premises infrastructure (for example, no access to a local AD DS instance
for GPOs because all servers are in the cloud), a service such as Microsoft Intune can simplify deploying and
maintaining workstation configurations.
Stand-alone hardened workstation for management
With a stand-alone hardened workstation, administrators have a PC or laptop that they use for administrative
tasks and another, separate PC or laptop for non-administrative tasks. A workstation dedicated to managing
your Azure services does not need other applications installed. Additionally, using workstations that support a
Trusted Platform Module (TPM) or similar hardware-level cryptography technology aids in device authentication
and prevention of certain attacks. TPM can also support full volume protection of the system drive by using
BitLocker Drive Encryption.
In the stand-alone hardened workstation scenario (shown below), the local instance of Windows Firewall (or a
non-Microsoft client firewall) is configured to block inbound connections, such as RDP. The administrator can log
on to the hardened workstation and start an RDP session that connects to Azure after establishing a VPN
connect with an Azure Virtual Network, but cannot log on to a corporate PC and use RDP to connect to the
hardened workstation itself.

Corporate PC as virtual machine


In cases where a separate stand-alone hardened workstation is cost prohibitive or inconvenient, the hardened
workstation can host a virtual machine to perform non-administrative tasks.
To avoid several security risks that can arise from using one workstation for systems management and other
daily work tasks, you can deploy a Windows Hyper-V virtual machine to the hardened workstation. This virtual
machine can be used as the corporate PC. The corporate PC environment can remain isolated from the Host,
which reduces its attack surface and removes the user’s daily activities (such as email) from coexisting with
sensitive administrative tasks.
The corporate PC virtual machine runs in a protected space and provides user applications. The host remains a
“clean source” and enforces strict network policies in the root operating system (for example, blocking RDP
access from the virtual machine).

Best practices
Consider the following additional guidelines when you are managing applications and data in Azure.
Dos and don'ts
Don't assume that because a workstation has been locked down that other common security requirements do
not need to be met. The potential risk is higher because of elevated access levels that administrator accounts
generally possess. Examples of risks and their alternate safe practices are shown in the table below.

DO N 'T DO

Don't email credentials for administrator access or other Maintain confidentiality by delivering account names and
secrets (for example, TLS/SSL or management certificates) passwords by voice (but not storing them in voice mail),
perform a remote installation of client/server certificates (via
an encrypted session), download from a protected network
share, or distribute by hand via removable media.

- Proactively manage your management certificate life cycles.

Don't store account passwords unencrypted or un-hashed in Establish security management principles and system
application storage (such as in spreadsheets, SharePoint hardening policies, and apply them to your development
sites, or file shares). environment.

- Use Enhanced Mitigation Experience Toolkit 5.5 certificate


pinning rules to ensure proper access to Azure SSL/TLS sites.
DO N 'T DO

Don't share accounts and passwords between Create a dedicated Microsoft account to manage your Azure
administrators, or reuse passwords across multiple user subscription—an account that is not used for personal email.
accounts or services, particularly those for social media or
other nonadministrative activities.

Don't email configuration files. Configuration files and profiles should be installed from a
trusted source (for example, an encrypted USB flash drive),
not from a mechanism that can be easily compromised, such
as email.

Don't use weak or simple logon passwords. Enforce strong password policies, expiration cycles
(changeon-first-use), console timeouts, and automatic
account lockouts. Use a client password management
system with multi-factor authentication for password vault
access.

Don't expose management ports to the Internet. Lock down Azure ports and IP addresses to restrict
management access. For more information, see the Azure
Network Security white paper.

- Use firewalls, VPNs, and NAP for all management


connections.

Azure operations
Within Microsoft’s operation of Azure, operations engineers and support personnel who access Azure’s
production systems use hardened workstation PCs with VMs provisioned on them for internal corporate
network access and applications (such as e-mail, intranet, etc.). All management workstation computers have
TPMs, the host boot drive is encrypted with BitLocker, and they are joined to a special organizational unit (OU) in
Microsoft’s primary corporate domain.
System hardening is enforced through Group Policy, with centralized software updating. For auditing and
analysis, event logs (such as security and AppLocker) are collected from management workstations and saved to
a central location.
In addition, dedicated jump-boxes on Microsoft’s network that require two-factor authentication are used to
connect to Azure’s production network.

Azure security checklist


Minimizing the number of tasks that administrators can perform on a hardened workstation helps minimize the
attack surface in your development and management environment. Use the following technologies to help
protect your hardened workstation:
IE hardening. The Internet Explorer browser (or any web browser, for that matter) is a key entry point for
harmful code due to its extensive interactions with external servers. Review your client policies and enforce
running in protected mode, disabling add-ons, disabling file downloads, and using Microsoft SmartScreen
filtering. Ensure that security warnings are displayed. Take advantage of Internet zones and create a list of
trusted sites for which you have configured reasonable hardening. Block all other sites and in-browser code,
such as ActiveX and Java.
Standard user. Running as a standard user brings a number of benefits, the biggest of which is that stealing
administrator credentials via malware becomes more difficult. In addition, a standard user account does not
have elevated privileges on the root operating system, and many configuration options and APIs are locked
out by default.
AppLocker. You can use AppLocker to restrict the programs and scripts that users can run. You can run
AppLocker in audit or enforcement mode. By default, AppLocker has an allow rule that enables users who
have an admin token to run all code on the client. This rule exists to prevent administrators from locking
themselves out, and it applies only to elevated tokens. See also Code Integrity as part of Windows Server
core security.
Code signing. Code signing all tools and scripts used by administrators provides a manageable mechanism
for deploying application lockdown policies. Hashes do not scale with rapid changes to the code, and file
paths do not provide a high level of security. You should combine AppLocker rules with a PowerShell
execution policy that only allows specific signed code and scripts to be executed.
Group Policy. Create a global administrative policy that is applied to any domain workstation that is used for
management (and block access from all others), and to user accounts authenticated on those workstations.
Security-enhanced provisioning. Safeguard your baseline hardened workstation image to help protect
against tampering. Use security measures like encryption and isolation to store images, virtual machines,
and scripts, and restrict access (perhaps use an auditable check-in/check-out process).
Patching. Maintain a consistent build (or have separate images for development, operations, and other
administrative tasks), scan for changes and malware routinely, keep the build up to date, and only activate
machines when they are needed.
Encryption. Make sure that management workstations have a TPM to more securely enable Encrypting File
System (EFS) and BitLocker.
Governance. Use AD DS GPOs to control all the administrators’ Windows interfaces, such as file sharing.
Include management workstations in auditing, monitoring, and logging processes. Track all administrator
and developer access and usage.

Summary
Using a hardened workstation configuration for administering your Azure cloud services, Virtual Machines, and
applications can help you avoid numerous risks and threats that can come from remotely managing critical IT
infrastructure. Both Azure and Windows provide mechanisms that you can employ to help protect and control
communications, authentication, and client behavior.

Next steps
The following resources are available to provide more general information about Azure and related Microsoft
services, in addition to specific items referenced in this paper:
Securing Privileged Access – get the technical details for designing and building a secure administrative
workstation for Azure management
Microsoft Trust Center - learn about Azure platform capabilities that protect the Azure fabric and the
workloads that run on Azure
Microsoft Security Response Center -- where Microsoft security vulnerabilities, including issues with Azure,
can be reported or via email to secure@microsoft.com
Azure operational security overview
12/12/2021 • 11 minutes to read • Edit Online

Azure operational security refers to the services, controls, and features available to users for protecting their
data, applications, and other assets in Microsoft Azure. It's a framework that incorporates the knowledge gained
through a variety of capabilities that are unique to Microsoft. These capabilities include the Microsoft Security
Development Lifecycle (SDL), the Microsoft Security Response Center program, and deep awareness of the
cybersecurity threat landscape.

Azure management services


An IT operations team is responsible for managing datacenter infrastructure, applications, and data, including
the stability and security of these systems. However, gaining security insights across increasing complex IT
environments often requires organizations to cobble together data from multiple security and management
systems.
Microsoft Azure Monitor logs is a cloud-based IT management solution that helps you manage and protect your
on-premises and cloud infrastructure. Its core functionality is provided by the following services that run in
Azure. Azure includes multiple services that help you manage and protect your on-premises and cloud
infrastructure. Each service provides a specific management function. You can combine services to achieve
different management scenarios.
Azure Monitor
Azure Monitor collects data from managed sources into central data stores. This data can include events,
performance data, or custom data provided through the API. After the data is collected, it's available for alerting,
analysis, and export.
You can consolidate data from a variety of sources and combine data from your Azure services with your
existing on-premises environment. Azure Monitor logs also clearly separates the collection of the data from the
action taken on that data, so that all actions are available to all kinds of data.
Automation
Azure Automation provides a way for you to automate the manual, long-running, error-prone, and frequently
repeated tasks that are commonly performed in a cloud and enterprise environment. It saves time and increases
the reliability of administrative tasks. It even schedules these tasks to be automatically performed at regular
intervals. You can automate processes by using runbooks or automate configuration management by using
Desired State Configuration.
Backup
Azure Backup is the Azure-based service that you can use to back up (or protect) and restore your data in the
Microsoft Cloud. Azure Backup replaces your existing on-premises or off-site backup solution with a cloud-
based solution that's reliable, secure, and cost-competitive.
Azure Backup offers components that you download and deploy on the appropriate computer or server, or in
the cloud. The component, or agent, that you deploy depends on what you want to protect. All Azure Backup
components (whether you're protecting data on-premises or in the cloud) can be used to back up data to an
Azure Recovery Services vault in Azure.
For more information, see the Azure Backup components table.
Site Recovery
Azure Site Recovery provides business continuity by orchestrating the replication of on-premises virtual and
physical machines to Azure, or to a secondary site. If your primary site is unavailable, you fail over to the
secondary location so that users can keep working. You fail back when systems return to working order. Use
Microsoft Defender for Cloud to perform more intelligent and effective threat detection.

Azure Active Directory


Azure Active Directory (Azure AD) is a comprehensive identity service that:
Enables identity and access management (IAM) as a cloud service.
Provides central access management, single sign-on (SSO), and reporting.
Supports integrated access management for thousands of applications in the Azure Marketplace, including
Salesforce, Google Apps, Box, and Concur.
Azure AD also includes a full suite of identity management capabilities, including these:
Multi-factor authentication
Self-service password management
Self-service group management
Privileged account management
Azure role-based access control (Azure RBAC)
Application usage monitoring
Rich auditing
Security monitoring and alerting
With Azure Active Directory, all applications that you publish for your partners and customers (business or
consumer) have the same identity and access management capabilities. This enables you to significantly reduce
your operational costs.

Microsoft Defender for Cloud


Microsoft Defender for Cloud helps you prevent, detect, and respond to threats with increased visibility into (and
control over) the security of your Azure resources. It provides integrated security monitoring and policy
management across your subscriptions. It helps detect threats that might otherwise go unnoticed, and it works
with a broad ecosystem of security solutions.
Safeguard virtual machine (VM) data in Azure by providing visibility into your virtual machine’s security settings
and monitoring for threats. Defender for Cloud can monitor your virtual machines for:
Operating system security settings with the recommended configuration rules.
System security and critical updates that are missing.
Endpoint protection recommendations.
Disk encryption validation.
Network-based attacks.
Defender for Cloud uses Azure role-based access control (Azure RBAC). Azure RBAC provides built-in roles that
can be assigned to users, groups, and services in Azure.
Defender for Cloud assesses the configuration of your resources to identify security issues and vulnerabilities. In
Defender for Cloud, you see information related to a resource only when you're assigned the role of owner,
contributor, or reader for the subscription or resource group that a resource belongs to.
NOTE
To learn more about roles and allowed actions in Defender for Cloud, see Permissions in Microsoft Defender for Cloud.

Defender for Cloud uses the Microsoft Monitoring Agent. This is the same agent that the Azure Monitor service
uses. Data collected from this agent is stored in either an existing Log Analytics workspace associated with your
Azure subscription or a new workspace, taking into account the geolocation of the VM.

Azure Monitor
Performance issues in your cloud app can affect your business. With multiple interconnected components and
frequent releases, degradations can happen at any time. And if you’re developing an app, your users usually
discover issues that you didn’t find in testing. You should know about these issues immediately, and you should
have tools for diagnosing and fixing the problems.
Azure Monitor is basic tool for monitoring services running on Azure. It gives you infrastructure-level data
about the throughput of a service and the surrounding environment. If you're managing your apps all in Azure
and deciding whether to scale up or down resources, Azure Monitor is the place to start.
You can also use monitoring data to gain deep insights about your application. That knowledge can help you to
improve application performance or maintainability, or automate actions that would otherwise require manual
intervention.
Azure Monitor includes the following components.
Azure Activity Log
The Azure Activity Log provides insight into the operations that were performed on resources in your
subscription. It was previously known as “Audit Log” or “Operational Log,” because it reports control-plane
events for your subscriptions.
Azure diagnostic logs
Azure diagnostic logs are emitted by a resource and provide rich, frequent data about the operation of that
resource. The content of these logs varies by resource type.
Windows event system logs are one category of diagnostic logs for VMs. Blob, table, and queue logs are
categories of diagnostic logs for storage accounts.
Diagnostic logs differ from the Activity Log. The Activity log provides insight into the operations that were
performed on resources in your subscription. Diagnostic logs provide insight into operations that your resource
performed itself.
Metrics
Azure Monitor provides telemetry that gives you visibility into the performance and health of your workloads
on Azure. The most important type of Azure telemetry data is the metrics (also called performance counters)
emitted by most Azure resources. Azure Monitor provides several ways to configure and consume these metrics
for monitoring and troubleshooting.
Azure Diagnostics
Azure Diagnostics enables the collection of diagnostic data on a deployed application. You can use the
Diagnostics extension from various sources. Currently supported are Azure cloud service roles, Azure virtual
machines running Microsoft Windows, and Azure Service Fabric.

Azure Network Watcher


Customers build an end-to-end network in Azure by orchestrating and composing individual network resources
such as virtual networks, Azure ExpressRoute, Azure Application Gateway, and load balancers. Monitoring is
available on each of the network resources.
The end-to-end network can have complex configurations and interactions between resources. The result is
complex scenarios that need scenario-based monitoring through Azure Network Watcher.
Network Watcher simplifies monitoring and diagnosing of your Azure network. You can use the diagnostic and
visualization tools in Network Watcher to:
Take remote packet captures on an Azure virtual machine.
Gain insights into your network traffic by using flow logs.
Diagnose Azure VPN Gateway and connections.
Network Watcher currently has the following capabilities:
Topology: Provides a view of the various interconnections and associations between network resources in a
resource group.
Variable packet capture: Captures packet data in and out of a virtual machine. Advanced filtering options and
fine-tuned controls, such as the ability to set time and size limitations, provide versatility. The packet data can
be stored in a blob store or on the local disk in .cap format.
IP flow verify: Checks if a packet is allowed or denied based on 5-tuple packet parameters for flow
information (destination IP, source IP, destination port, source port, and protocol). If a security group denies
the packet, the rule and group that denied the packet are returned.
Next hop: Determines the next hop for packets being routed in the Azure network fabric, so you can diagnose
any misconfigured user-defined routes.
Security group view: Gets the effective and applied security rules that are applied on a VM.
NSG flow logs for network security groups: Enable you to capture logs related to traffic that is allowed or
denied by the security rules in the group. The flow is defined by 5-tuple information: source IP, destination IP,
source port, destination port, and protocol.
Virtual network gateway and connection troubleshooting: Provides the ability to troubleshoot virtual
network gateways and connections.
Network subscription limits: Enables you to view network resource usage against limits.
Diagnostic logs: Provides a single pane to enable or disable diagnostic logs for network resources in a
resource group.
For more information, see Configure Network Watcher.

Cloud Service Provider Access Transparency


Customer Lockbox for Microsoft Azure is a service integrated into Azure portal that gives you explicit control in
the rare instance when a Microsoft Support Engineer may need access to your data to resolve an issue. There
are very few instances, such as a debugging remote access issue, where a Microsoft Support Engineer requires
elevated permissions to resolve this issue. In such cases, Microsoft engineers use just-in-time access service that
provides limited, time-bound authorization with access limited to the service.
While Microsoft has always obtained customer consent for access, Customer Lockbox now gives you the ability
to review and approve or deny such requests from the Azure Portal. Microsoft support engineers will not be
granted access until you approve the request.

Standardized and Compliant Deployments


Azure Blueprints enable cloud architects and central information technology groups to define a repeatable set of
Azure resources that implement and adhere to an organization's standards, patterns, and requirements.
This makes it possible for DevOps teams to rapidly build and stand up new environments and trust that they're
building them with infrastructure that maintains organizational compliance. Blueprints provide a declarative way
to orchestrate the deployment of various resource templates and other artifacts such as:
Role Assignments
Policy Assignments
Azure Resource Manager templates
Resource Groups

DevOps
Before Developer Operations (DevOps) application development, teams were in charge of gathering business
requirements for a software program and writing code. Then a separate QA team tested the program in an
isolated development environment. If requirements were met, the QA team released the code for operations to
deploy. The deployment teams were further fragmented into groups like networking and database. Each time a
software program was “thrown over the wall” to an independent team, it added bottlenecks.
DevOps enables teams to deliver more secure, higher-quality solutions faster and more cheaply. Customers
expect a dynamic and reliable experience when consuming software and services. Teams must rapidly iterate on
software updates and measure the impact of the updates. They must respond quickly with new development
iterations to address issues or provide more value.
Cloud platforms such as Microsoft Azure have removed traditional bottlenecks and helped commoditize
infrastructure. Software reigns in every business as the key differentiator and factor in business outcomes. No
organization, developer, or IT worker can or should avoid the DevOps movement.
Mature DevOps practitioners adopt several of the following practices. These practices involve people to form
strategies based on the business scenarios. Tooling can help automate the various practices.
Agile planning and project management techniques are used to plan and isolate work into sprints, manage
team capacity, and help teams quickly adapt to changing business needs.
Version control, usually with Git, enables teams located anywhere in the world to share source and integrate
with software development tools to automate the release pipeline.
Continuous integration drives the ongoing merging and testing of code, which leads to finding defects early.
Other benefits include less time wasted on fighting merge issues and rapid feedback for development teams.
Continuous delivery of software solutions to production and testing environments helps organizations
quickly fix bugs and respond to ever-changing business requirements.
Monitoring of running applications--including production environments for application health, as well as
customer usage--helps organizations form a hypothesis and quickly validate or disprove strategies. Rich data
is captured and stored in various logging formats.
Infrastructure as Code (IaC) is a practice that enables the automation and validation of creation and teardown
of networks and virtual machines to help with delivering secure, stable application hosting platforms.
Microservices architecture is used to isolate business use cases into small reusable services. This architecture
enables scalability and efficiency.

Next steps
To learn about the Security and Audit solution, see the following articles:
Security and compliance
Microsoft Defender for Cloud
Azure Monitor
Azure Operational Security best practices
12/12/2021 • 17 minutes to read • Edit Online

This article provides a set of operational best practices for protecting your data, applications, and other assets in
Azure.
The best practices are based on a consensus of opinion, and they work with current Azure platform capabilities
and feature sets. Opinions and technologies change over time and this article is updated on a regular basis to
reflect those changes.

Define and deploy strong operational security practices


Azure operational security refers to the services, controls, and features available to users for protecting their
data, applications, and other assets in Azure. Azure operational security is built on a framework that incorporates
the knowledge gained through capabilities that are unique to Microsoft, including the Security Development
Lifecycle (SDL), the Microsoft Security Response Center program, and deep awareness of the cybersecurity
threat landscape.

Manage and monitor user passwords


The following table lists some best practices related to managing user passwords:
Best practice : Ensure you have the proper level of password protection in the cloud.
Detail : Follow the guidance in Microsoft Password Guidance, which is scoped to users of the Microsoft identity
platforms (Azure Active Directory, Active Directory, and Microsoft account).
Best practice : Monitor for suspicious actions related to your user accounts.
Detail : Monitor for users at risk and risky sign-ins by using Azure AD security reports.
Best practice : Automatically detect and remediate high-risk passwords.
Detail : Azure AD Identity Protection is a feature of the Azure AD Premium P2 edition that enables you to:
Detect potential vulnerabilities that affect your organization’s identities
Configure automated responses to detected suspicious actions that are related to your organization’s
identities
Investigate suspicious incidents and take appropriate actions to resolve them

Receive incident notifications from Microsoft


Be sure your security operations team receives Azure incident notifications from Microsoft. An incident
notification lets your security team know you have compromised Azure resources so they can quickly respond
to and remediate potential security risks.
In the Azure enrollment portal, you can ensure admin contact information includes details that notify security
operations. Contact information is an email address and phone number.

Organize Azure subscriptions into management groups


If your organization has many subscriptions, you might need a way to efficiently manage access, policies, and
compliance for those subscriptions. Azure management groups provide a level of scope that’s above
subscriptions. You organize subscriptions into containers called management groups and apply your
governance conditions to the management groups. All subscriptions within a management group automatically
inherit the conditions applied to the management group.
You can build a flexible structure of management groups and subscriptions into a directory. Each directory is
given a single top-level management group called the root management group. This root management group is
built into the hierarchy to have all management groups and subscriptions fold up to it. The root management
group allows global policies and Azure role assignments to be applied at the directory level.
Here are some best practices for using management groups:
Best practice : Ensure that new subscriptions apply governance elements like policies and permissions as they
are added.
Detail : Use the root management group to assign enterprise-wide security elements that apply to all Azure
assets. Policies and permissions are examples of elements.
Best practice : Align the top levels of management groups with segmentation strategy to provide a point for
control and policy consistency within each segment.
Detail : Create a single management group for each segment under the root management group. Don’t create
any other management groups under the root.
Best practice : Limit management group depth to avoid confusion that hampers both operations and security.
Detail : Limit your hierarchy to three levels, including the root.
Best practice : Carefully select which items to apply to the entire enterprise with the root management group.
Detail : Ensure root management group elements have a clear need to be applied across every resource and
that they’re low impact.
Good candidates include:
Regulatory requirements that have a clear business impact (for example, restrictions related to data
sovereignty)
Requirements with near-zero potential negative affect on operations, like policy with audit effect or Azure
RBAC permission assignments that have been carefully reviewed
Best practice : Carefully plan and test all enterprise-wide changes on the root management group before
applying them (policy, Azure RBAC model, and so on).
Detail : Changes in the root management group can affect every resource on Azure. While they provide a
powerful way to ensure consistency across the enterprise, errors or incorrect usage can negatively affect
production operations. Test all changes to the root management group in a test lab or production pilot.

Streamline environment creation with blueprints


The Azure Blueprints service enables cloud architects and central information technology groups to define a
repeatable set of Azure resources that implements and adheres to an organization's standards, patterns, and
requirements. Azure Blueprints makes it possible for development teams to rapidly build and stand up new
environments with a set of built-in components and the confidence that they're creating those environments
within organizational compliance.

Monitor storage services for unexpected changes in behavior


Diagnosing and troubleshooting issues in a distributed application hosted in a cloud environment can be more
complex than it is in traditional environments. Applications can be deployed in a PaaS or IaaS infrastructure, on-
premises, on a mobile device, or in some combination of these environments. Your application's network traffic
might traverse public and private networks, and your application might use multiple storage technologies.
You should continuously monitor the storage services that your application uses for any unexpected changes in
behavior (such as slower response times). Use logging to collect more detailed data and to analyze a problem in
depth. The diagnostics information that you obtain from both monitoring and logging helps you to determine
the root cause of the issue that your application encountered. Then you can troubleshoot the issue and
determine the appropriate steps to remediate it.
Azure Storage Analytics performs logging and provides metrics data for an Azure storage account. We
recommend that you use this data to trace requests, analyze usage trends, and diagnose issues with your
storage account.

Prevent, detect, and respond to threats


Microsoft Defender for Cloud helps you prevent, detect, and respond to threats by providing increased visibility
into (and control over) the security of your Azure resources. It provides integrated security monitoring and
policy management across your Azure subscriptions, helps detect threats that might otherwise go unnoticed,
and works with various security solutions.
The Free tier of Defender for Cloud offers limited security for only your Azure resources. The Standard tier
extends these capabilities to on-premises and other clouds. Defender for Cloud Standard helps you find and fix
security vulnerabilities, apply access and application controls to block malicious activity, detect threats by using
analytics and intelligence, and respond quickly when under attack. You can try Defender for Cloud Standard at
no cost for the first 60 days. We recommend that you upgrade your Azure subscription to Defender for Cloud
Standard.
Use Defender for Cloud to get a central view of the security state of all your Azure resources. At a glance, verify
that the appropriate security controls are in place and configured correctly, and quickly identify any resources
that need attention.
Defender for Cloud also integrates with Microsoft Defender Advanced Threat Protection (ATP), which provides
comprehensive Endpoint Detection and Response (EDR) capabilities. With Microsoft Defender ATP integration,
you can spot abnormalities. You can also detect and respond to advanced attacks on server endpoints
monitored by Defender for Cloud.
Almost all enterprise organizations have a security information and event management (SIEM) system to help
identify emerging threats by consolidating log information from diverse signal gathering devices. The logs are
then analyzed by a data analytics system to help identify what’s “interesting” from the noise that is inevitable in
all log gathering and analytics solutions.
Microsoft Sentinel is a scalable, cloud-native, security information and event management (SIEM) and security
orchestration automated response (SOAR) solution. Microsoft Sentinel provides intelligent security analytics and
threat intelligence via alert detection, threat visibility, proactive hunting, and automated threat response.
Here are some best practices for preventing, detecting, and responding to threats:
Best practice : Increase the speed and scalability of your SIEM solution by using a cloud-based SIEM.
Detail : Investigate the features and capabilities of Microsoft Sentinel and compare them with the capabilities of
what you’re currently using on-premises. Consider adopting Microsoft Sentinel if it meets your organization’s
SIEM requirements.
Best practice : Find the most serious security vulnerabilities so you can prioritize investigation.
Detail : Review your Azure secure score to see the recommendations resulting from the Azure policies and
initiatives built into Microsoft Defender for Cloud. These recommendations help address top risks like security
updates, endpoint protection, encryption, security configurations, missing WAF, internet-connected VMs, and
many more.
The secure score, which is based on Center for Internet Security (CIS) controls, lets you benchmark your
organization’s Azure security against external sources. External validation helps validate and enrich your team’s
security strategy.
Best practice : Monitor the security posture of machines, networks, storage and data services, and applications
to discover and prioritize potential security issues.
Detail : Follow the security recommendations in Defender for Cloud starting, with the highest priority items.
Best practice : Integrate Defender for Cloud alerts into your security information and event management
(SIEM) solution.
Detail : Most organizations with a SIEM use it as a central clearinghouse for security alerts that require an
analyst response. Processed events produced by Defender for Cloud are published to the Azure Activity Log, one
of the logs available through Azure Monitor. Azure Monitor offers a consolidated pipeline for routing any of
your monitoring data into a SIEM tool. See Stream alerts to a SIEM, SOAR, or IT Service Management solution
for instructions. If you’re using Microsoft Sentinel, see Connect Microsoft Defender for Cloud.
Best practice : Integrate Azure logs with your SIEM.
Detail : Use Azure Monitor to gather and export data. This practice is critical for enabling security incident
investigation, and online log retention is limited. If you’re using Microsoft Sentinel, see Connect data sources.
Best practice : Speed up your investigation and hunting processes and reduce false positives by integrating
Endpoint Detection and Response (EDR) capabilities into your attack investigation.
Detail : Enable the Microsoft Defender for Endpoint integration via your Defender for Cloud security policy.
Consider using Microsoft Sentinel for threat hunting and incident response.

Monitor end-to-end scenario-based network monitoring


Customers build an end-to-end network in Azure by combining network resources like a virtual network,
ExpressRoute, Application Gateway, and load balancers. Monitoring is available on each of the network
resources.
Azure Network Watcher is a regional service. Use its diagnostic and visualization tools to monitor and diagnose
conditions at a network scenario level in, to, and from Azure.
The following are best practices for network monitoring and available tools.
Best practice : Automate remote network monitoring with packet capture.
Detail : Monitor and diagnose networking issues without logging in to your VMs by using Network Watcher.
Trigger packet capture by setting alerts and gain access to real-time performance information at the packet level.
When you see an issue, you can investigate in detail for better diagnoses.
Best practice : Gain insight into your network traffic by using flow logs.
Detail : Build a deeper understanding of your network traffic patterns by using network security group flow logs.
Information in flow logs helps you gather data for compliance, auditing, and monitoring your network security
profile.
Best practice : Diagnose VPN connectivity issues.
Detail : Use Network Watcher to diagnose your most common VPN Gateway and connection issues. You can not
only identify the issue but also use detailed logs to further investigate.

Secure deployment by using proven DevOps tools


Use the following DevOps best practices to ensure that your enterprise and teams are productive and efficient.
Best practice : Automate the build and deployment of services.
Detail : Infrastructure as code is a set of techniques and practices that help IT pros remove the burden of day-to-
day build and management of modular infrastructure. It enables IT pros to build and maintain their modern
server environment in a way that’s like how software developers build and maintain application code.
You can use Azure Resource Manager to provision your applications by using a declarative template. In a single
template, you can deploy multiple services along with their dependencies. You use the same template to
repeatedly deploy your application in every stage of the application lifecycle.
Best practice : Automatically build and deploy to Azure web apps or cloud services.
Detail : You can configure your Azure DevOps Projects to automatically build and deploy to Azure web apps or
cloud services. Azure DevOps automatically deploys the binaries after doing a build to Azure after every code
check-in. The package build process is equivalent to the Package command in Visual Studio, and the publishing
steps are equivalent to the Publish command in Visual Studio.
Best practice : Automate release management.
Detail : Azure Pipelines is a solution for automating multiple-stage deployment and managing the release
process. Create managed continuous deployment pipelines to release quickly, easily, and often. With Azure
Pipelines, you can automate your release process, and you can have predefined approval workflows. Deploy on-
premises and to the cloud, extend, and customize as required.
Best practice : Check your app's performance before you launch it or deploy updates to production.
Detail : Run cloud-based load tests to:
Find performance problems in your app.
Improve deployment quality.
Make sure that your app is always available.
Make sure that your app can handle traffic for your next launch or marketing campaign.
Apache JMeter is a free, popular open source tool with a strong community backing.
Best practice : Monitor application performance.
Detail : Azure Application Insights is an extensible application performance management (APM) service for web
developers on multiple platforms. Use Application Insights to monitor your live web application. It automatically
detects performance anomalies. It includes analytics tools to help you diagnose issues and to understand what
users actually do with your app. It's designed to help you continuously improve performance and usability.

Mitigate and protect against DDoS


Distributed denial of service (DDoS) is a type of attack that tries to exhaust application resources. The goal is to
affect the application’s availability and its ability to handle legitimate requests. These attacks are becoming more
sophisticated and larger in size and impact. They can be targeted at any endpoint that is publicly reachable
through the internet.
Designing and building for DDoS resiliency requires planning and designing for a variety of failure modes.
Following are best practices for building DDoS-resilient services on Azure.
Best practice : Ensure that security is a priority throughout the entire lifecycle of an application, from design
and implementation to deployment and operations. Applications can have bugs that allow a relatively low
volume of requests to use a lot of resources, resulting in a service outage.
Detail : To help protect a service running on Microsoft Azure, you should have a good understanding of your
application architecture and focus on the five pillars of software quality. You should know typical traffic volumes,
the connectivity model between the application and other applications, and the service endpoints that are
exposed to the public internet.
Ensuring that an application is resilient enough to handle a denial of service that's targeted at the application
itself is most important. Security and privacy are built into the Azure platform, beginning with the Security
Development Lifecycle (SDL). The SDL addresses security at every development phase and ensures that Azure is
continually updated to make it even more secure.
Best practice : Design your applications to scale horizontally to meet the demand of an amplified load,
specifically in the event of a DDoS attack. If your application depends on a single instance of a service, it creates
a single point of failure. Provisioning multiple instances makes your system more resilient and more scalable.
Detail : For Azure App Service, select an App Service plan that offers multiple instances.
For Azure Cloud Services, configure each of your roles to use multiple instances.
For Azure Virtual Machines, ensure that your VM architecture includes more than one VM and that each VM is
included in an availability set. We recommend using virtual machine scale sets for autoscaling capabilities.
Best practice : Layering security defenses in an application reduces the chance of a successful attack.
Implement secure designs for your applications by using the built-in capabilities of the Azure platform.
Detail : The risk of attack increases with the size (surface area) of the application. You can reduce the surface area
by using an approval list to close down the exposed IP address space and listening ports that are not needed on
the load balancers (Azure Load Balancer and Azure Application Gateway).
Network security groups are another way to reduce the attack surface. You can use service tags and application
security groups to minimize complexity for creating security rules and configuring network security, as a natural
extension of an application’s structure.
You should deploy Azure services in a virtual network whenever possible. This practice allows service resources
to communicate through private IP addresses. Azure service traffic from a virtual network uses public IP
addresses as source IP addresses by default.
Using service endpoints switches service traffic to use virtual network private addresses as the source IP
addresses when they're accessing the Azure service from a virtual network.
We often see customers' on-premises resources getting attacked along with their resources in Azure. If you're
connecting an on-premises environment to Azure, minimize exposure of on-premises resources to the public
internet.
Azure has two DDoS service offerings that provide protection from network attacks:
Basic protection is integrated into Azure by default at no additional cost. The scale and capacity of the
globally deployed Azure network provides defense against common network-layer attacks through always-
on traffic monitoring and real-time mitigation. Basic requires no user configuration or application changes
and helps protect all Azure services, including PaaS services like Azure DNS.
Standard protection provides advanced DDoS mitigation capabilities against network attacks. It's
automatically tuned to protect your specific Azure resources. Protection is simple to enable during the
creation of virtual networks. It can also be done after creation and requires no application or resource
changes.

Enable Azure Policy


Azure Policy is a service in Azure that you use to create, assign, and manage policies. These policies enforce rules
and effects over your resources, so those resources stay compliant with your corporate standards and service-
level agreements. Azure Policy meets this need by evaluating your resources for non-compliance with assigned
policies.
Enable Azure Policy to monitor and enforce your organization’s written policy. This will ensure compliance with
your company or regulatory security requirements by centrally managing security policies across your hybrid
cloud workloads. Learn how to create and manage policies to enforce compliance. See Azure Policy definition
structure for an overview of the elements of a policy.
Here are some security best practices to follow after you adopt Azure Policy:
Best practice : Policy supports several types of effects. You can read about them in Azure Policy definition
structure. Business operations can be negatively affected by the deny effect and the remediate effect, so start
with the audit effect to limit the risk of negative impact from policy.
Detail : Start policy deployments in audit mode and then later progress to deny or remediate . Test and review
the results of the audit effect before you move to deny or remediate .
For more information, see Create and manage policies to enforce compliance.
Best practice : Identify the roles responsible for monitoring for policy violations and ensuring the right
remediation action is taken quickly.
Detail : Have the assigned role monitor compliance through the Azure portal or via the command line.
Best practice : Azure Policy is a technical representation of an organization's written policies. Map all Azure
Policy definitions to organizational policies to reduce confusion and increase consistency.
Detail : Document mapping in your organization's documentation or in the Azure Policy definition itself by
adding a reference to the organizational policy in the policy definition or the initiative definition description.

Monitor Azure AD risk reports


The vast majority of security breaches take place when attackers gain access to an environment by stealing a
user’s identity. Discovering compromised identities is no easy task. Azure AD uses adaptive machine learning
algorithms and heuristics to detect suspicious actions that are related to your user accounts. Each detected
suspicious action is stored in a record called a risk detection. Risk detections are recorded in Azure AD security
reports. For more information, read about the users at risk security report and the risky sign-ins security report.

Next steps
See Azure security best practices and patterns for more security best practices to use when you’re designing,
deploying, and managing your cloud solutions by using Azure.
The following resources are available to provide more general information about Azure security and related
Microsoft services:
Azure Security Team Blog - for up to date information on the latest in Azure Security
Microsoft Security Response Center - where Microsoft security vulnerabilities, including issues with Azure,
can be reported or via email to secure@microsoft.com
Azure operational security checklist
12/12/2021 • 4 minutes to read • Edit Online

Deploying an application on Azure is fast, easy, and cost-effective. Before deploying cloud application in
production useful to have a checklist to assist in evaluating your application against a list of essential and
recommended operational security actions for you to consider.

Introduction
Azure provides a suite of infrastructure services that you can use to deploy your applications. Azure Operational
Security refers to the services, controls, and features available to users for protecting their data, applications,
and other assets in Microsoft Azure.
To get the maximum benefit out of the cloud platform, we recommend that you leverage Azure services and
follow the checklist.
Organizations that invest time and resources assessing the operational readiness of their applications before
launch have a much higher rate of satisfaction than those who don’t. When performing this work, checklists
can be an invaluable mechanism to ensure that applications are evaluated consistently and holistically.
The level of operational assessment varies depending on the organization’s cloud maturity level and the
application’s development phase, availability needs, and data sensitivity requirements.

Checklist
This checklist is intended to help enterprises think through various operational security considerations as they
deploy sophisticated enterprise applications on Azure. It can also be used to help you build a secure cloud
migration and operation strategy for your organization.

C H EC K L IST C AT EGO RY DESC RIP T IO N

Use Azure role-based access control (Azure RBAC) to


Security Roles & Access Controls provide user-specific that used to assign permissions
to users, groups, and applications at a certain scope.
C H EC K L IST C AT EGO RY DESC RIP T IO N

Use Management Plane Security to secure your


Data Collection & Storage Storage Account using Azure role-based access
control (Azure RBAC).
Data Plane Security to Securing Access to your Data
using Shared Access Signatures (SAS) and Stored
Access Policies.
Use Transport-Level Encryption – Using HTTPS and
the encryption used by SMB (Server message block
protocols) 3.0 for Azure File Shares.
Use Client-side encryption to secure data that you
send to storage accounts when you require sole
control of encryption keys.
Use Storage Service Encryption (SSE) to automatically
encrypt data in Azure Storage, and Azure Disk
Encryption to encrypt virtual machine disk files for
the OS and data disks.
Use Azure Storage Analytics to monitor authorization
type; like with Blob Storage, you can see if users have
used a Shared Access Signature or the storage
account keys.
Use Cross-Origin Resource Sharing (CORS) to access
storage resources from different domains.

Use Microsoft Defender for Cloud to deploy endpoint


Security Policies & Recommendations solutions.
Add a web application firewall (WAF) to secure web
applications.
Use a firewall from a Microsoft partner to increase
your security protections.
Apply security contact details for your Azure
subscription; this the Microsoft Security Response
Center (MSRC) contacts you if it discovers that your
customer data has been accessed by an unlawful or
unauthorized party.

Synchronize your on-premises directory with your


Identity & Access Management cloud directory using Azure AD.
Use Single Sign-On to enable users to access their
SaaS applications based on their organizational
account in Azure AD.
Use the Password Reset Registration Activity report
to monitor the users that are registering.
Enable multi-factor authentication (MFA) for users.
Developers to use secure identity capabilities for apps
like Microsoft Security Development Lifecycle (SDL).
Actively monitor for suspicious activities by using
Azure AD Premium anomaly reports and Azure AD
identity protection capability.
C H EC K L IST C AT EGO RY DESC RIP T IO N

Use Malware Assessment Solution Azure Monitor


Ongoing Security Monitoring logs to report on the status of antimalware
protection in your infrastructure.
Use Update assessment to determine the overall
exposure to potential security problems, and whether
or how critical these updates are for your
environment.
The Identity and Access provide you an overview of
user
user identity state,
number of failed attempts to sign in,
the user’s account that were used during those
attempts, accounts that were locked out
accounts with changed or reset password
Currently number of accounts that are logged in.

Use detection capabilities, to identify active threats


Microsoft Defender for Cloud detection capabilities targeting your Microsoft Azure resources.
Use integrated threat intelligence that looks for
known bad actors by leveraging global threat
intelligence from Microsoft products and services, the
Microsoft Digital Crimes Unit (DCU), the Microsoft
Security Response Center (MSRC), and external feeds.
Use Behavioral analytics that applies known patterns
to discover malicious behavior.
Use Anomaly detection that uses statistical profiling
to build a historical baseline.

Infrastructure as Code (IaC) is a practice, which


Developer Operations (DevOps) enables the automation and validation of creation
and teardown of networks and virtual machines to
help with delivering secure, stable application hosting
platforms.
Continuous Integration and Deployment drive the
ongoing merging and testing of code, which leads to
finding defects early.
Release Management Manage automated
deployments through each stage of your pipeline.
App Performance Monitoring of running applications
including production environments for application
health and customer usage help organizations form a
hypothesis and quickly validate or disprove
strategies.
Using Load Testing & Auto-Scale we can find
performance problems in our app to improve
deployment quality and to make sure our app is
always up or available to cater to the business needs.

Conclusion
Many organizations have successfully deployed and operated their cloud applications on Azure. The checklists
provided highlight several checklists that are essential and help you to increase the likelihood of successful
deployments and frustration-free operations. We highly recommend these operational and strategic
considerations for your existing and new application deployments on Azure.
Next steps
To learn more about Security, see the following articles:
Design and operational security.
Microsoft Defender for Cloud planning and operations.
Security services and technologies available on
Azure
12/12/2021 • 4 minutes to read • Edit Online

In our discussions with current and future Azure customers, we're often asked "do you have a list of all the
security-related services and technologies that Azure has to offer?"
When you evaluate cloud service provider options, it's helpful to have this information. So we have provided
this list to get you started.
Over time, this list will change and grow, just as Azure does. Make sure to check this page on a regular basis to
stay up-to-date on our security-related services and technologies.

General Azure security


SERVIC E DESC RIP T IO N

Azure Security Center A cloud workload protection solution that provides security
management and advanced threat protection across hybrid
cloud workloads.

Azure Key Vault A secure secrets store for the passwords, connection strings,
and other information you need to keep your apps working.

Azure Monitor logs A monitoring service that collects telemetry and other data,
and provides a query language and analytics engine to
deliver operational insights for your apps and resources. Can
be used alone or with other services such as Defender for
Cloud.

Azure Dev/Test Labs A service that helps developers and testers quickly create
environments in Azure while minimizing waste and
controlling cost.

Storage security
SERVIC E DESC RIP T IO N

Azure Storage Service Encryption A security feature that automatically encrypts your data in
Azure storage.

StorSimple Encrypted Hybrid Storage An integrated storage solution that manages storage tasks
between on-premises devices and Azure cloud storage.

Azure Client-Side Encryption A client-side encryption solution that encrypts data inside
client applications before uploading to Azure Storage; also
decrypts the data while downloading.

Azure Storage Shared Access Signatures A shared access signature provides delegated access to
resources in your storage account.
SERVIC E DESC RIP T IO N

Azure Storage Account Keys An access control method for Azure storage that is used for
authentication when the storage account is accessed.

Azure File shares with SMB 3.0 Encryption A network security technology that enables automatic
network encryption for the Server Message Block (SMB) file
sharing protocol.

Azure Storage Analytics A logging and metrics-generating technology for data in


your storage account.

Database security
SERVIC E DESC RIP T IO N

Azure SQL Firewall A network access control feature that protects against
network-based attacks to database.

Azure SQL Cell Level Encryption A database security technology that provides encryption at
a granular level.

Azure SQL Connection Encryption To provide security, SQL Database controls access with
firewall rules limiting connectivity by IP address,
authentication mechanisms requiring users to prove their
identity, and authorization mechanisms limiting users to
specific actions and data.

Azure SQL Always Encryption Protects sensitive data, such as credit card numbers or
national identification numbers (for example, U.S. social
security numbers), stored in Azure SQL Database or SQL
Server databases.

Azure SQL Transparent Data Encryption A database security feature that encrypts the storage of an
entire database.

Azure SQL Database Auditing A database auditing feature that tracks database events and
writes them to an audit log in your Azure storage account.

Identity and access management


SERVIC E DESC RIP T IO N

Azure role-based access control An access control feature designed to allow users to access
only the resources they are required to access based on their
roles within the organization.

Azure Active Directory A cloud-based authentication repository that supports a


multi-tenant, cloud-based directory and multiple identity
management services within Azure.

Azure Active Directory B2C An identity management service that enables control over
how customers sign-up, sign-in, and manage their profiles
when using Azure-based applications.
SERVIC E DESC RIP T IO N

Azure Active Directory Domain Services A cloud-based and managed version of Active Directory
Domain Services.

Azure AD Multi-Factor Authentication A security provision that employs several different forms of
authentication and verification before allowing access to
secured information.

Backup and disaster recovery


SERVIC E DESC RIP T IO N

Azure Backup An Azure-based service used to back up and restore data in


the Azure cloud.

Azure Site Recovery An online service that replicates workloads running on


physical and virtual machines (VMs) from a primary site to a
secondary location to enable recovery of services after a
failure.

Networking
SERVIC E DESC RIP T IO N

Network Security Groups A network-based access control feature using a 5-tuple to


make allow or deny decisions.

Azure VPN Gateway A network device used as a VPN endpoint to allow cross-
premises access to Azure Virtual Networks.

Azure Application Gateway An advanced web application load balancer that can route
based on URL and perform SSL-offloading.

Web application firewall (WAF) A feature of Application Gateway that provides centralized
protection of your web applications from common exploits
and vulnerabilities

Azure Load Balancer A TCP/UDP application network load balancer.

Azure ExpressRoute A dedicated WAN link between on-premises networks and


Azure Virtual Networks.

Azure Traffic Manager A global DNS load balancer.

Azure Application Proxy An authenticating front-end used to secure remote access


for web applications hosted on-premises.

Azure Firewall A managed, cloud-based network security service that


protects your Azure Virtual Network resources.

Azure DDoS protection Combined with application design best practices, provides
defense against DDoS attacks.
SERVIC E DESC RIP T IO N

Virtual Network service endpoints Extends your virtual network private address space and the
identity of your VNet to the Azure services, over a direct
connection.
Cloud feature availability for commercial and US
Government customers
12/12/2021 • 18 minutes to read • Edit Online

This article describes feature availability in the Microsoft Azure and Azure Government clouds for the following
security services:
Azure Information Protection
Microsoft Defender for Cloud
Microsoft Sentinel
Microsoft Defender for IoT
Azure Attestation

NOTE
Additional security services will be added to this article soon.

Azure Government
Azure Government uses the same underlying technologies as Azure (sometimes referred to as Azure
Commercial or Azure Public), which includes the core components of Infrastructure-as-a-Service (IaaS),
Platform-as-a-Service (PaaS), and Software-as-a-Service (SaaS). Both Azure and Azure Government have
comprehensive security controls in place, and the Microsoft commitment on the safeguarding of customer data.
Azure Government is a physically isolated cloud environment dedicated to US federal, state, local, and tribal
governments, and their partners. Whereas both cloud environments are assessed and authorized at the
FedRAMP High impact level, Azure Government provides an extra layer of protection to customers through
contractual commitments regarding storage of customer data in the United States and limiting potential access
to systems processing customer data to screened US persons. These commitments may be of interest to
customers using the cloud to store or process data subject to US export control regulations such as the EAR,
ITAR, and DoE 10 CFR Part 810.
For more information about Azure Government, see What is Azure Government?

Microsoft 365 integration


Integrations between products rely on interoperability between Azure and Office platforms. Offerings hosted in
the Azure environment are accessible from the Microsoft 365 Enterprise and Microsoft 365 Government
platforms. Office 365 and Office 365 GCC are paired with Azure Active Directory (Azure AD) in Azure. Office 365
GCC High and Office 365 DoD are paired with Azure AD in Azure Government.
The following diagram displays the hierarchy of Microsoft clouds and how they relate to each other.
The Office 365 GCC environment helps customers comply with US government requirements, including
FedRAMP High, CJIS, and IRS 1075. The Office 365 GCC High and DoD environments support customers who
need compliance with DoD IL4/5, DFARS 7012, NIST 800-171, and ITAR.
For more information about Office 365 US Government environments, see:
Office 365 GCC
Office 365 GCC High and DoD
The following sections identify when a service has an integration with Microsoft 365 and the feature availability
for Office 365 GCC, Office 365 High, and Office 365 DoD.

Azure Information Protection


Azure Information Protection (AIP) is a cloud-based solution that enables organizations to discover, classify, and
protect documents and emails by applying labels to content.
AIP is part of the Microsoft Information Protection (MIP) solution, and extends the labeling and classification
functionality provided by Microsoft 365.
For more information, see the Azure Information Protection product documentation.
Office 365 GCC is paired with Azure Active Directory (Azure AD) in Azure. Office 365 GCC High and Office
365 DoD are paired with Azure AD in Azure Government. Make sure to pay attention to the Azure
environment to understand where interoperability is possible. In the following table, interoperability that
is not possible is marked with a dash (-) to indicate that support is not relevant.
Extra configurations are required for GCC-High and DoD customers. For more information, see Azure
Information Protection Premium Government Service Description.

NOTE
More details about support for government customers are listed in footnotes below the table.
Extra steps are required for configuring Azure Information Protection for GCC High and DoD customers. For more
information, see the Azure Information Protection Premium Government Service Description.

F EAT URE/ SERVIC E A Z URE A Z URE GO VERN M EN T

Azure Information Protection


scanner 1
F EAT URE/ SERVIC E A Z URE A Z URE GO VERN M EN T

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

Administration

Azure Information Protection portal


for scanner administration

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

Classification and labeling 2

AIP scanner to apply a default label to


all files in an on-premises file server /
repository

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

AIP scanner for automated


classification, labeling, and protection
of supported on-premises files

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

1 The scanner can function without Office 365 to scan files only. The scanner cannot apply labels to files without
Office 365.
2 The classification and labeling add-in is only supported for
government customers with Microsoft 365 Apps
(version 9126.1001 or higher), including Professional Plus (ProPlus) and Click-to-Run (C2R) versions. Office
2010, Office 2013, and other Office 2016 versions are not supported.
Office 365 features
F EAT URE/ SERVIC E O F F IC E 365 GC C O F F IC E 365 GC C H IGH O F F IC E 365 DO D

Administration
F EAT URE/ SERVIC E O F F IC E 365 GC C O F F IC E 365 GC C H IGH O F F IC E 365 DO D

- PowerShell for RMS GA GA GA


service administration

- PowerShell for AIP UL


client bulk operations

SDK

- MIP and AIP Software GA GA GA


Development Kit (SDK)

Customizations

- Document tracking and GA Not available Not available


revocation

Key management

- Bring Your Own Key GA GA GA


(BYOK)

- Double Key Encryption GA GA GA


(DKE)

Office files 3

- Protection for Microsoft GA GA 4 GA 4


Exchange Online, Microsoft
SharePoint Online, and
Microsoft OneDrive for
Business

- Protection for on- GA 5 Not available Not available


premises Exchange and
SharePoint content via the
Rights Management
connector

- Office 365 Message GA GA GA


Encryption

- Set labels to automatically GA GA GA


apply pre-configured
M/MIME protection in
Outlook

- Control oversharing of GA GA 6 GA 6
information when using
Outlook

Classification and
labeling 2 / 7
F EAT URE/ SERVIC E O F F IC E 365 GC C O F F IC E 365 GC C H IGH O F F IC E 365 DO D

- Custom templates, GA GA GA
including departmental
templates

- Manual, default, and GA GA GA


mandatory document
classification

- Configure conditions for GA GA


automatic and
recommended classification
GA

- Protection for non- GA GA GA


Microsoft Office file formats,
including PTXT, PJPG, and
PFILE (generic protection)

3 The Mobile Device Extension for AD RMS is currently not available for government customers.
4 Information Rights Management with SharePoint Online (IRM-protected sites and libraries) is currently not

available.
5 Information Rights Management (IRM) is supported only for Microsoft 365 Apps (version 9126.1001 or
higher), including Professional Plus (ProPlus) and Click-to-Run (C2R) versions. Office 2010, Office 2013, and
other Office 2016 versions are not supported.
6 Sharing of protected documents and emails from government clouds to users in the commercial cloud is not
currently available. Includes Microsoft 365 Apps users in the commercial cloud, non-Microsoft 365 Apps users
in the commercial cloud, and users with an RMS for Individuals license.
7 The number of Sensitive Information Types in your Microsoft 365 Security & Compliance Center may vary
based on region.

Microsoft Defender for Cloud


Microsoft Defender for Cloud is a unified infrastructure security management system that strengthens the
security posture of your data centers, and provides advanced threat protection across your hybrid workloads in
the cloud - whether they're in Azure or not - as well as on premises.
For more information, see the Microsoft Defender for Cloud product documentation.
The following table displays the current Defender for Cloud feature availability in Azure and Azure Government.

F EAT URE/ SERVIC E A Z URE A Z URE GO VERN M EN T

Microsoft Defender for Cloud


free features

Continuous export GA GA

Workflow automation GA GA
F EAT URE/ SERVIC E A Z URE A Z URE GO VERN M EN T

Recommendation exemption rules Public Preview Not Available

Alert suppression rules GA GA

Email notifications for security alerts GA GA

Auto provisioning for agents and GA GA


extensions

Asset inventory GA GA

Azure Monitor Workbooks reports GA GA


in Microsoft Defender for Cloud's
workbooks gallery

Microsoft Defender plans and


extensions

Microsoft Defender for servers GA GA

Microsoft Defender for App Service GA Not Available

Microsoft Defender for DNS GA GA

Microsoft Defender for container GA GA 2


registries 1

Microsoft Defender for container Public Preview Not Available


registries scanning of images in CI/CD
workflows 3

Microsoft Defender for Kubernetes 4 GA GA

Defender extension for Azure Arc Public Preview Not Available


enabled Kubernetes clusters 5

Microsoft Defender for Azure SQL GA GA


database servers

Microsoft Defender for SQL servers GA GA


on machines

Microsoft Defender for open-source GA Not Available


relational databases

Microsoft Defender for Key Vault GA Not Available

Microsoft Defender for Resource GA GA


Manager

Microsoft Defender for Storage 6 GA GA


F EAT URE/ SERVIC E A Z URE A Z URE GO VERN M EN T

Threat protection for Cosmos DB Public Preview Not Available

Kubernetes workload protection GA GA

Bi-directional alert synchronization Public Preview Not Available


with Sentinel

Microsoft Defender for ser vers


features 7

Just-in-time VM access GA GA

File integrity monitoring GA GA

Adaptive application controls GA GA

Adaptive network hardening GA Not Available

Docker host hardening GA GA

Integrated vulnerability assessment GA Not Available


for machines

Regulatory compliance dashboard & GA GA


reports 8

Microsoft Defender for Endpoint GA GA


deployment and integrated license

Connect AWS account GA Not Available

Connect GCP account GA Not Available

1 Partially GA: The ability to disable specific findings from vulnerability scans is in public preview.
2 Vulnerability scans of container registries on Azure Gov can only be performed with the scan on push feature.
3 Requires Microsoft Defender for container registries.
4 Partially GA: Support for Azure Arc-enabled clusters is in public preview and not available on Azure
Government.
5 Requires Microsoft Defender for Kubernetes.
6 Partially GA: Some of the threat protection alerts from Microsoft Defender for Storage are in public preview.
7 These features all require Microsoft Defender for servers.
8 There may be differences in the standards offered per cloud type.

Microsoft Sentinel
Microsoft Sentinel is a scalable, cloud-native, security information event management (SIEM), and security
orchestration automated response (SOAR) solution. Microsoft Sentinel delivers intelligent security analytics and
threat intelligence across the enterprise, providing a single solution for alert detection, threat visibility, proactive
hunting, and threat response.
For more information, see the Microsoft Sentinel product documentation.
The following tables display the current Microsoft Sentinel feature availability in Azure and Azure Government.

F EAT URE A Z URE A Z URE GO VERN M EN T

Incidents

- Automation rules Public Preview Public Preview

- Cross-tenant/Cross-workspace Public Preview Public Preview


incidents view

- Entity insights GA Public Preview

- SOC incident audit metrics GA GA

- Incident advanced search GA GA

- Microsoft Teams integrations Public Preview Not Available

- Bring Your Own ML (BYO-ML) Public Preview Public Preview

Notebooks

- Notebooks GA GA

- Notebook integration with Azure Public Preview Not Available


Synapse

Watchlists

- Watchlists GA GA

Hunting

- Hunting GA GA

Content and content


management

- Content hub and solutions Public preview Not Available

- Repositories Public preview Not Available

Data collection

- Advanced SIEM Information Model Public Preview Not Available


(ASIM)
F EAT URE A Z URE A Z URE GO VERN M EN T

Threat intelligence suppor t

- Threat Intelligence - TAXII data GA GA


connector

- Threat Intelligence Platform data Public Preview Not Available


connector

- Threat Intelligence Research Blade GA GA

- URL Detonation Public Preview Not Available

- Threat Intelligence workbook GA GA

- GeoLocation and WhoIs data Public Preview Not Available


enrichment

- Threat intelligence matching analytics Public Preview Not Available

Detection suppor t

- Fusion GA GA
Advanced multistage attack detections
1

- Fusion detection for ransomware Public Preview Not Available

- Fusion for emerging threats Public Preview Not Available

- Anomalous Windows File Share Public Preview Not Available


Access Detection

- Anomalous RDP Login Detection Public Preview Not Available


Built-in ML detection

- Anomalous SSH login detection Public Preview Not Available


Built-in ML detection

Azure ser vice connectors

- Azure Activity Logs GA GA

- Azure Active Directory GA GA

- Azure ADIP GA GA

- Azure DDoS Protection GA GA

- Microsoft Defender for Cloud GA GA

- Microsoft Defender for IoT Public Preview Not Available


F EAT URE A Z URE A Z URE GO VERN M EN T

- Microsoft Insider Risk Management Public Preview Not Available

- Azure Firewall GA GA

- Azure Information Protection Public Preview Not Available

- Azure Key Vault Public Preview Not Available

- Azure Kubernetes Services (AKS) Public Preview Not Available

- Azure SQL Databases GA GA

- Azure WAF GA GA

Windows connectors

- Windows Firewall GA GA

- Windows Security Events GA GA

External connectors

- Agari Phishing Defense and Brand Public Preview Public Preview


Protection

- AI Analyst Darktrace Public Preview Public Preview

- AI Vectra Detect Public Preview Public Preview

- Akamai Security Events Public Preview Public Preview

- Alcide kAudit Public Preview Not Available

- Alsid for Active Directory Public Preview Not Available

- Apache HTTP Server Public Preview Not Available

- Arista Networks Public Preview Not Available

- Armorblox Public Preview Not Available

- Aruba ClearPass Public Preview Public Preview

- AWS GA GA

- Barracuda CloudGen Firewall GA GA

- Barracuda Web App Firewall GA GA

- BETTER Mobile Threat Defense MTD Public Preview Not Available


F EAT URE A Z URE A Z URE GO VERN M EN T

- Beyond Security beSECURE Public Preview Not Available

- Blackberry CylancePROTECT Public Preview Public Preview

- Box Public Preview Not Available

- Broadcom Symantec DLP Public Preview Public Preview

- Check Point GA GA

- Cisco ACI Public Preview Not Available

- Cisco ASA GA GA

- Cisco Duo Security Public Preview Not Available

- Cisco ISE Public Preview Not Available

- Cisco Meraki Public Preview Public Preview

- Cisco Secure Email Gateway / ESA Public Preview Not Available

- Cisco Umbrella Public Preview Public Preview

- Cisco UCS Public Preview Public Preview

- Cisco Firepower EStreamer Public Preview Public Preview

- Cisco Web Security Appliance (WSA) Public Preview Not Available

- Citrix Analytics WAF GA GA

- Cloudflare Public Preview Not Available

- Common Event Format (CEF) GA GA

- Contrast Security Public Preview Not Available

- CrowdStrike Public Preview Not Available

- CyberArk Enterprise Password Vault Public Preview Public Preview


(EPV) Events

- Digital Guardian Public Preview Not Available

- ESET Enterprise Inspector Public Preview Not Available

- Eset Security Management Center Public Preview Not Available

- ExtraHop Reveal(x) GA GA
F EAT URE A Z URE A Z URE GO VERN M EN T

- F5 BIG-IP GA GA

- F5 Networks GA GA

- FireEye NX (Network Security) Public Preview Not Available

- Flare Systems Firework Public Preview Not Available

- Forcepoint NGFW Public Preview Public Preview

- Forcepoint CASB Public Preview Public Preview

- Forcepoint DLP Public Preview Not Available

- Forescout Public Preview Not Available

- ForgeRock Common Audit for CEF Public Preview Public Preview

- Fortinet GA GA

- Google Cloud Platform DNS Public Preview Not Available

- Google Cloud Platform Public Preview Not Available

- Google Workspace (G Suite) Public Preview Not Available

- Illusive Attack Management System Public Preview Public Preview

- Imperva WAF Gateway Public Preview Public Preview

- InfoBlox Cloud Public Preview Not Available

- Infoblox NIOS Public Preview Public Preview

- Juniper IDP Public Preview Not Available

- Juniper SRX Public Preview Public Preview

- Kaspersky AntiVirus Public Preview Not Available

- Lookout Mobile Threat Defense Public Preview Not Available

- McAfee ePolicy Public Preview Not Available

- McAfee Network Security Platform Public Preview Not Available

- Morphisec UTPP Public Preview Public Preview

- Netskope Public Preview Public Preview


F EAT URE A Z URE A Z URE GO VERN M EN T

- NXLog Windows DNS Public Preview Not Available

- NXLog LinuxAudit Public Preview Not Available

- Okta Single Sign On Public Preview Public Preview

- Onapsis Platform Public Preview Public Preview

- One Identity Safeguard GA GA

- Oracle Cloud Infrastructure Public Preview Not Available

- Oracle Database Audit Public Preview Not Available

- Orca Security Alerts Public Preview Not Available

- Palo Alto Networks GA GA

- Perimeter 81 Activity Logs GA Not Available

- Ping Identity Public Preview Not Available

- Proofpoint On Demand Email Public Preview Not Available


Security

- Proofpoint TAP Public Preview Public Preview

- Pulse Connect Secure Public Preview Public Preview

- Qualys Vulnerability Management Public Preview Public Preview

- Rapid7 Public Preview Not Available

- RSA SecurID Public Preview Not Available

- Salesforce Service Cloud Public Preview Not Available

- SAP (Continuous Threat Monitoring Public Preview Not Available


for SAP)

- Semperis Public Preview Not Available

- Senserva Pro Public Preview Not Available

- Slack Audit Public Preview Not Available

- SonicWall Firewall Public Preview Public Preview

- Sonrai Security Public Preview Not Available


F EAT URE A Z URE A Z URE GO VERN M EN T

- Sophos Cloud Optix Public Preview Not Available

- Sophos XG Firewall Public Preview Public Preview

- Squadra Technologies secRMM GA GA

- Squid Proxy Public Preview Not Available

- Symantec Integrated Cyber Defense GA GA


Exchange

- Symantec ProxySG Public Preview Public Preview

- Symantec VIP Public Preview Public Preview

- Syslog GA GA

- Tenable Public Preview Not Available

- Thycotic Secret Server Public Preview Public Preview

- Trend Micro Deep Security GA GA

- Trend Micro TippingPoint Public Preview Public Preview

- Trend Micro XDR Public Preview Not Available

- Ubiquiti Public Preview Not Available

- vArmour Public Preview Not Available

- Vectra Public Preview Not Available

- VMware Carbon Black Endpoint Public Preview Public Preview


Standard

- VMware ESXi Public Preview Public Preview

- WireX Network Forensics Platform Public Preview Public Preview

- Zeek Network (Corelight) Public Preview Not Available

- Zimperium Mobile Threat Defense Public Preview Not Available

- Zscaler GA GA

1 SSH and RDP detections are not supported for sovereign clouds because the Databricks ML platform is not
available.
Microsoft 365 data connectors
Office 365 GCC is paired with Azure Active Directory (Azure AD) in Azure. Office 365 GCC High and Office 365
DoD are paired with Azure AD in Azure Government.

TIP
Make sure to pay attention to the Azure environment to understand where interoperability is possible. In the following
table, interoperability that is not possible is marked with a dash (-) to indicate that support is not relevant.

C O N N EC TO R A Z URE A Z URE GO VERN M EN T

Office IRM

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available

Dynamics365

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available

Microsoft 365 Defender

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available

Microsoft Defender for Cloud


Apps

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

Microsoft Defender for Cloud


Apps
Shadow IT logs

- Office 365 GCC Public Preview -

- Office 365 GCC High - Public Preview

- Office 365 DoD - Public Preview


C O N N EC TO R A Z URE A Z URE GO VERN M EN T

Microsoft Defender for Cloud


Apps
Alerts

- Office 365 GCC Public Preview -

- Office 365 GCC High - Public Preview

- Office 365 DoD - Public Preview

Microsoft Defender for Endpoint

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

Microsoft Defender for Identity

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available

Microsoft Defender for Office


365

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available

Office 365

- Office 365 GCC GA -

- Office 365 GCC High - GA

- Office 365 DoD - GA

Teams

- Office 365 GCC Public Preview -

- Office 365 GCC High - Not Available

- Office 365 DoD - Not Available


C O N N EC TO R A Z URE A Z URE GO VERN M EN T

Microsoft Defender for IoT


Microsoft Defender for IoT lets you accelerate IoT/OT innovation with comprehensive security across all your
IoT/OT devices.For end-user organizations, Microsoft Defender for IoT offers agentless, network-layer security
that is rapidly deployed, works with diverse industrial equipment, and interoperates with Microsoft Sentinel and
other SOC tools. Deploy on-premises or in Azure-connected environments.For IoT device builders, the Microsoft
Defender for IoT security agents allow you to build security directly into your new IoT devices and Azure IoT
projects. The micro agent has flexible deployment options, including the ability to deploy as a binary package or
modify source code. And the micro agent is available for standard IoT operating systems like Linux and Azure
RTOS. For more information, see the Microsoft Defender for IoT product documentation.
The following table displays the current Microsoft Defender for IoT feature availability in Azure, and Azure
Government.
For organizations
F EAT URE A Z URE A Z URE GO VERN M EN T

On-premises device discovery and GA GA


inventory

Vulnerability management GA GA

Threat detection with IoT, and OT GA GA


behavioral analytics

Manual and automatic threat GA GA


intelligence updates

Unify IT, and OT security with


SIEM, SOAR and XDR

Active Directory GA GA

ArcSight GA GA

ClearPass (Alerts & Inventory) GA GA

CyberArk PSM GA GA

Email GA GA

FortiGate GA GA

FortiSIEM GA GA

Microsoft Sentinel Public Preview Public Preview

NetWitness GA GA
F EAT URE A Z URE A Z URE GO VERN M EN T

Palo Alto NGFW GA GA

Palo Alto Panorama GA GA

ServiceNow (Alerts & Inventory) GA GA

SNMP MIB Monitoring GA GA

Splunk GA GA

SYSLOG Server (CEF format) GA GA

SYSLOG Server (LEEF format) GA GA

SYSLOG Server (Object) GA GA

SYSLOG Server (Text Message) GA GA

Web callback (Webhook) GA GA

For device builders


F EAT URE A Z URE A Z URE GO VERN M EN T

Micro agent for Azure RTOS GA GA

Configure Sentinel with Microsoft Public Preview Public Preview


Defender for IoT

Standalone micro agent for Linux

Standalone agent binary installation Public Preview Public Preview

Azure Attestation
Microsoft Azure Attestation is a unified solution for remotely verifying the trustworthiness of a platform and
integrity of the binaries running inside it. The service receives evidence from the platform, validates it with
security standards, evaluates it against configurable policies, and produces an attestation token for claims-based
applications (e.g., relying parties, auditing authorities).
Azure Attestation is currently available in multiple regions across Azure public and Government clouds. In Azure
Government, the service is available in preview status across US Gov Virginia and US Gov Arizona.
For more information, see Azure Attestation public documentation.

F EAT URE A Z URE A Z URE GO VERN M EN T

Portal experience to perform control- GA -


plane and data-plane operations
F EAT URE A Z URE A Z URE GO VERN M EN T

PowerShell experience to perform GA GA


control-plane and data-plane
operations

TLS 1.2 enforcement GA GA

BCDR support GA -

Service tag integration GA GA

Immutable log storage GA GA

Network isolation using private link Public Preview -

FedRAMP High certification GA -

Customer lockbox GA -

Next steps
Understand the shared responsibility model and which security tasks are handled by the cloud provider and
which tasks are handled by you.
Understand the Azure Government Cloud capabilities and the trustworthy design and security used to
support compliance applicable to federal, state, and local government organizations and their partners.
Understand the Office 365 Government plan.
Understand compliance in Azure for legal and regulatory standards.
Azure security best practices and patterns
12/12/2021 • 2 minutes to read • Edit Online

The articles below contain security best practices to use when you’re designing, deploying, and managing your
cloud solutions by using Azure. These best practices come from our experience with Azure security and the
experiences of customers like you.
The best practices are intended to be a resource for IT pros. This might include designers, architects, developers,
and testers who build and deploy secure Azure solutions.
Azure boundary security best practices
Azure database security best practices
Azure data security and encryption best practices
Azure identity management and access control security best practices
Azure network security best practices
Azure operational security best practices
Azure PaaS Best Practices
Azure Service Fabric security best practices
Best practices for Azure VM security
Implementing a secure hybrid network architecture in Azure
Internet of Things security best practices
Securing PaaS databases in Azure
Securing PaaS web and mobile applications using Azure App Service
Securing PaaS web and mobile applications using Azure Storage
Security best practices for IaaS workloads in Azure
The white paper Security best practices for Azure solutions is a collection of the security best practices found in
the articles listed above.
Download the white paper
Microsoft Services in Cybersecurity
12/12/2021 • 2 minutes to read • Edit Online

Microsoft Services provides a comprehensive approach to security, identity, and cybersecurity. They include an
array of Security and Identity services across strategy, planning, implementation, and ongoing support. These
services can help Enterprise customers implement security solutions that align with their strategic goals.
Microsoft services can create solutions that integrate, and enhance the latest security and identity capabilities of
our products to help protect your business and drive innovation.
Our team of technical professionals consists of highly trained experts who offer a wealth of security and identity
experience.
Learn more about services provided by Microsoft Services:
Security Risk Assessment
Dynamic Identity Framework Assessment
Offline Assessment for Active Directory Services
Enhanced Security Administration Environment
Azure AD Implementation Services
Securing Against Lateral Account Movement
Incident Response and Recovery
Learn more about Microsoft Services Security consulting services.
How to Log a Security Event Support Ticket
12/12/2021 • 2 minutes to read • Edit Online

1. Navigate to Publisher Support and sign in with your Microsoft credentials.


2. Select "Security Event" as the Problem Type and choose between the "Security Incident" and
"Vulnerability" categories.

3. After you select the Problem Type and Category, click the 'Star t request ' button. Provide the following
information to help us better understand the issue.
i. What is the problem and/or vulnerability?
ii. For vulnerabilities, please provide the CVE (mitre.org) or the filled out CVSS3 v3 calculator
(https://www.first.org/cvss/calculator/3.0).
iii. Is there a resolution or mitigation? If yes, then please provide the remediation steps.
iv. Do you have a message that you want to send to customers? We will work with you to craft an
appropriate message if applicable.
4. Submission confirmation - Once you have submitted your issue, we will acknowledge receipt within one
business day and assign your issue a priority and severity.
If you need to communicate with us about your issue, use the confirmation number in all
correspondence.
You can view progress on your issue at any time.
5. What happens next? Depending on the issue and severity, the following steps may be taken:
We will communicate the outcome of our assessment to you. Depending on the outcome, we may
remove or request that you modify your offering. In this event, we will work with you to ensure that
disruption to impacted customers is minimized.
We will work with you to help mitigate the impact of the incident/vulnerability for our mutual
customers.
Penetration testing
12/12/2021 • 2 minutes to read • Edit Online

One of the benefits of using Azure for application testing and deployment is that you can quickly get
environments created. You don’t have to worry about requisitioning, acquiring, and “racking and stacking” your
own on-premises hardware.
Quickly creating environments is great – but you still need to make sure you perform your normal security due
diligence. One of the things you likely want to do is penetration test the applications you deploy in Azure.
We don’t perform penetration testing of your application for you, but we do understand that you want and need
to perform testing on your own applications. That’s a good thing, because when you enhance the security of
your applications you help make the entire Azure ecosystem more secure.
As of June 15, 2017, Microsoft no longer requires pre-approval to conduct a penetration test against Azure
resources. This process is only related to Microsoft Azure, and not applicable to any other Microsoft Cloud
Service.

IMPORTANT
While notifying Microsoft of pen testing activities is no longer required customers must still comply with the Microsoft
Cloud Unified Penetration Testing Rules of Engagement.

Standard tests you can perform include:


Tests on your endpoints to uncover the Open Web Application Security Project (OWASP) top 10
vulnerabilities
Fuzz testing of your endpoints
Port scanning of your endpoints
One type of pen test that you can’t perform is any kind of Denial of Service (DoS) attack. This test includes
initiating a DoS attack itself, or performing related tests that might determine, demonstrate, or simulate any type
of DoS attack.

NOTE
Microsoft has partnered with BreakingPoint Cloud to build an interface where you can generate traffic against DDoS
Protection-enabled public IP addresses for simulations. To learn more about the BreakingPoint Cloud simulation, see
testing through simulations.

Next steps
Learn more about the Penetration Testing Rules of Engagement.
Reference list of Azure domains (not
comprehensive)
12/12/2021 • 2 minutes to read • Edit Online

This page is a partial list of the Azure domains in use. Some of them are REST API endpoints.

SERVIC E SUB DO M A IN

Azure Access Control Service (retired) *.accesscontrol.windows.net

Azure Active Directory *.graph.windows.net / *.onmicrosoft.com

Azure API Management *.azure-api.net

Azure BizTalk Services (retired) *.biztalk.windows.net

Azure Blob storage *.blob.core.windows.net

Azure Cloud Services and Azure Virtual Machines *.cloudapp.net

Azure Cloud Services *.cloudapp.azure.com

Azure Container Registry *.azurecr.io

Azure Container Service (ACS) (deprecated) *.azurecontainer.io

Azure Content Delivery Network (CDN) *.vo.msecnd.net

Azure Files *.file.core.windows.net

Azure Front Door *.azurefd.net

Azure Management Services *.management.core.windows.net

Azure Media Services *.origin.mediaservices.windows.net

Azure Mobile Apps *.azure-mobile.net

Azure Queue Storage *.queue.core.windows.net

Azure Service Bus *.servicebus.windows.net

Azure SQL Database *.database.windows.net

Azure Stack Edge and Azure IoT Edge *.azureedge.net

Azure Table Storage *.table.core.windows.net


SERVIC E SUB DO M A IN

Azure Traffic Manager *.trafficmanager.net

Azure Websites *.azurewebsites.net

Visual Studio Codespaces *.visualstudio.com

You might also like