Description
The Storage Queue service stores messages that may be read by any client who has access to the storage account. A queue can contain an unlimited number of messages, each of which can be up to 64KB in size using version 2011-08-18 or newer. Storage Logging happens server-side and allows details for both successful and failed requests to be recorded in the storage account. These logs allow users to see the details of read, write, and delete operations against the queues. Storage Logging log entries contain the following information about individual requests: Timing information such as start time, end-to-end latency, and server latency, authentication details, concurrency information, and the sizes of the request and response messages.
Rationaleβ
Storage Analytics logs contain 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.
Storage Analytics logging is not enabled by default for your storage account.
Impactβ
Enabling this setting can have a high impact on the cost of the log analytics service and data storage used by logging more data per each request. Do not enable this without determining your need for this level of logging, and do not forget to check in on data usage and projected cost. Some users have seen their logging costs increase from $10 per month to $10,000 per month.
Auditβ
From Azure Portalβ
- Go to
Storage Accounts
. - For each storage account, under
Monitoring
, clickDiagnostics settings
. - Select the
queue
tab indented below the storage account. - Ensure that at least one diagnostic setting is listed.
- Click
Edit setting
on a diagnostic setting. - Ensure that at least one diagnostic setting has
StorageRead
,StorageWrite
, andStorageDelete
options selected under theLogs
section and that they are sent to an appropriate destination.
From Azure CLIβ
Ensure the below command's output contains properties delete
, read
and write
set to true
:
az storage logging show --services q --account-name <storageAccountName>
From Azure Policyβ
If referencing a digital copy of this Benchmark, clicking a Policy ID will open a link to the associated Policy definition in Azure.
- Policy ID: 7bd000e3-37c7-4928-9f31-86c4b77c5c45 - Name:
Configure diagnostic settings for Queue Services to Log Analytics workspace
Default Valueβ
By default storage account queue services are not logged.
Referencesβ
- https://docs.microsoft.com/en-us/rest/api/storageservices/about-storage-analytics-logging
- https://docs.microsoft.com/en-us/cli/azure/storage/logging?view=azure-cli-latest
- https://learn.microsoft.com/en-us/security/benchmark/azure/mcsb-logging-threat-detection#lt-4-enable-network-logging-for-security-investigation
- https://docs.microsoft.com/en-us/azure/storage/queues/monitor-queue-storage?tabs=azure-portal
Additional Informationβ
We cannot practically generalize detailed audit log requirements for every queue due to their nature and intent. This recommendation may be applicable to storage account queue services where the security is paramount.