In the previous chapter we have used a customized Docker image to scan Azure's VMs.
This time we will scan Linux virtual machines SSH port and send the collected data to Azure Monitor(aka Operations Management Suite).
Azure Monitor, provides sophisticated tools for collecting and analyzing telemetry that allow you to maximize the performance and availability of your cloud and on-premises resources and applications.
All data collected by Azure Monitor fits into one of two fundamental types, metrics and logs. Metrics are numerical values that describe some aspect of a system at a particular point in time. They are lightweight and capable of supporting near real-time scenarios. Logs contain different kinds of data organized into records with different sets of properties for each type. Telemetry such as events and traces are stored as logs in addition to performance data so that it can all be combined for analysis.
Log data collected by Azure Monitor can be analyzed with queries to quickly retrieve, consolidate, and analyze collected data. Azure Monitor uses a version of the Kusto query language used by Azure Data Explorer that is suitable for simple log queries but also includes advanced functionality such as aggregations, joins, and smart analytics.
Before delving into technical details let’s first review what is needed to reproduce it on your side. List is following:
-
Setup a Docker environment(for example, in Azure Cloud Shell)
- Open a Docker environment (in this demo it is https://shell.azure.com/ )
- Download the image and run it interactively
docker pull groovysky/azure-audit:latest
docker run -it groovysky/azure-audit:latest pwsh
- Run 'Invoke-Audit' command
Invoke-Audit -AuditPort '22' -OSType 'Linux' -LogType 'AzureAudit' -CustomerId 'xxxxx' -SharedKey 'xxxxx'
- Authenticate to https://aka.ms/devicelogin by entering an authorization code
If everything went according to plan we should see information about scanned VMs and query it: