QueueServiceClient Class  
A client to interact with the Queue Service at the account level.
This client provides operations to retrieve and configure the account properties as well as list, create and delete queues within the account. For operations relating to a specific queue, a client for this entity can be retrieved using the get_queue_client function.
Constructor
QueueServiceClient(account_url: str, credential: str | Dict[str, str] | AzureNamedKeyCredential | AzureSasCredential | AsyncTokenCredential | None = None, *, api_version: str | None = None, secondary_hostname: str | None = None, audience: str | None = None, **kwargs: Any)Parameters
| Name | Description | 
|---|---|
| account_url 
				Required
			 | The URL to the queue service endpoint. Any other entities included in the URL path (e.g. queue) will be discarded. This URL can be optionally authenticated with a SAS token. | 
| credential | 
				AzureNamedKeyCredential or 
				AzureSasCredential or 
				AsyncTokenCredential or 
				str or 
				dict[str, str] or 
				None
		 The credentials with which to authenticate. This is optional if the account URL already has a SAS token. The value can be a SAS token string, an instance of a AzureSasCredential or AzureNamedKeyCredential from azure.core.credentials, an account shared access key, or an instance of a TokenCredentials class from azure.identity. If the resource URI already contains a SAS token, this will be ignored in favor of an explicit credential 
 Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| api_version | The Storage API version to use for requests. Default value is the most recent service version that is compatible with the current SDK. Setting to an older version may result in reduced feature compatibility. Default value: None | 
| secondary_hostname | The hostname of the secondary endpoint. Default value: None | 
| audience | The audience to use when requesting tokens for Azure Active Directory authentication. Only has an effect when credential is of type TokenCredential. The value could be https://storage.azure.com/ (default) or https://<account>.queue.core.windows.net. Default value: None | 
Examples
Creating the QueueServiceClient with an account url and credential.
   from azure.storage.queue.aio import QueueServiceClient
   queue_service = QueueServiceClient(account_url=self.account_url, credential=self.access_key)
Creating the QueueServiceClient with Default Azure Identity credentials.
   # Get a token credential for authentication
   from azure.identity.aio import DefaultAzureCredential
   token_credential = DefaultAzureCredential()
   # Instantiate a QueueServiceClient using a token credential
   from azure.storage.queue.aio import QueueServiceClient
   queue_service = QueueServiceClient(account_url=self.account_url, credential=token_credential)
Methods
| close | This method is to close the sockets opened by the client. It need not be used when using with a context manager. | 
| create_queue | Creates a new queue under the specified account. If a queue with the same name already exists, the operation fails. Returns a client with which to interact with the newly created queue. | 
| delete_queue | Deletes the specified queue and any messages it contains. When a queue is successfully deleted, it is immediately marked for deletion and is no longer accessible to clients. The queue is later removed from the Queue service during garbage collection. Note that deleting a queue is likely to take at least 40 seconds to complete. If an operation is attempted against the queue while it was being deleted, an ~azure.core.exceptions.HttpResponseError will be thrown. | 
| from_connection_string | Create QueueServiceClient from a Connection String. | 
| get_queue_client | Get a client to interact with the specified queue. The queue need not already exist. | 
| get_service_properties | Gets the properties of a storage account's Queue service, including Azure Storage Analytics. | 
| get_service_stats | Retrieves statistics related to replication for the Queue service. It is only available when read-access geo-redundant replication is enabled for the storage account. With geo-redundant replication, Azure Storage maintains your data durable in two locations. In both locations, Azure Storage constantly maintains multiple healthy replicas of your data. The location where you read, create, update, or delete data is the primary storage account location. The primary location exists in the region you choose at the time you create an account via the Azure Management Azure classic portal, for example, North Central US. The location to which your data is replicated is the secondary location. The secondary location is automatically determined based on the location of the primary; it is in a second data center that resides in the same region as the primary location. Read-only access is available from the secondary location, if read-access geo-redundant replication is enabled for your storage account. | 
| list_queues | Returns a generator to list the queues under the specified account. The generator will lazily follow the continuation tokens returned by the service and stop when all queues have been returned. | 
| set_service_properties | Sets the properties of a storage account's Queue service, including Azure Storage Analytics. If an element (e.g. analytics_logging) is left as None, the existing settings on the service for that functionality are preserved. | 
close
This method is to close the sockets opened by the client. It need not be used when using with a context manager.
async close() -> NoneReturns
| Type | Description | 
|---|---|
| None | 
create_queue
Creates a new queue under the specified account.
If a queue with the same name already exists, the operation fails. Returns a client with which to interact with the newly created queue.
async create_queue(name: str, metadata: Dict[str, str] | None = None, *, timeout: int | None = None, **kwargs: Any) -> QueueClientParameters
| Name | Description | 
|---|---|
| name 
				Required
			 | The name of the queue to create. | 
| metadata | A dict with name_value pairs to associate with the queue as metadata. Example: {'Category': 'test'} Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | The timeout parameter is expressed in seconds. Default value: None | 
Returns
| Type | Description | 
|---|---|
| A QueueClient for the newly created Queue. | 
Examples
Create a queue in the service.
   await queue_service.create_queue("asyncmyqueue1")
delete_queue
Deletes the specified queue and any messages it contains.
When a queue is successfully deleted, it is immediately marked for deletion and is no longer accessible to clients. The queue is later removed from the Queue service during garbage collection.
Note that deleting a queue is likely to take at least 40 seconds to complete. If an operation is attempted against the queue while it was being deleted, an ~azure.core.exceptions.HttpResponseError will be thrown.
async delete_queue(queue: QueueProperties | str, *, timeout: int | None = None, **kwargs: Any) -> NoneParameters
| Name | Description | 
|---|---|
| queue 
				Required
			 | The queue to delete. This can either be the name of the queue, or an instance of QueueProperties. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | The timeout parameter is expressed in seconds. Default value: None | 
Returns
| Type | Description | 
|---|---|
Examples
Delete a queue in the service.
   await queue_service.delete_queue("asyncmyqueue1")
from_connection_string
Create QueueServiceClient from a Connection String.
from_connection_string(conn_str: str, credential: str | Dict[str, str] | AzureNamedKeyCredential | AzureSasCredential | AsyncTokenCredential | None = None, *, api_version: str | None = None, secondary_hostname: str | None = None, audience: str | None = None, **kwargs: Any) -> SelfParameters
| Name | Description | 
|---|---|
| conn_str 
				Required
			 | A connection string to an Azure Storage account. | 
| credential | 
				Optional[Union[str, Dict[str, str], <xref:AzureNamedKeyCredential>, <xref:AzureSasCredential>, <xref:AsyncTokenCredential>]]
		 The credentials with which to authenticate. This is optional if the account URL already has a SAS token, or the connection string already has shared access key values. The value can be a SAS token string, an instance of a AzureSasCredential or AzureNamedKeyCredential from azure.core.credentials, an account shared access key, or an instance of a TokenCredentials class from azure.identity. Credentials provided here will take precedence over those in the connection string. If using an instance of AzureNamedKeyCredential, "name" should be the storage account name, and "key" should be the storage account key. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| api_version | The Storage API version to use for requests. Default value is the most recent service version that is compatible with the current SDK. Setting to an older version may result in reduced feature compatibility. Default value: None | 
| secondary_hostname | The hostname of the secondary endpoint. Default value: None | 
| audience | The audience to use when requesting tokens for Azure Active Directory authentication. Only has an effect when credential is of type TokenCredential. The value could be https://storage.azure.com/ (default) or https://<account>.queue.core.windows.net. Default value: None | 
Returns
| Type | Description | 
|---|---|
| A Queue service client. | 
Examples
Creating the QueueServiceClient with a connection string.
   from azure.storage.queue import QueueServiceClient
   queue_service = QueueServiceClient.from_connection_string(conn_str=self.connection_string)
get_queue_client
Get a client to interact with the specified queue.
The queue need not already exist.
get_queue_client(queue: QueueProperties | str, **kwargs: Any) -> QueueClientParameters
| Name | Description | 
|---|---|
| queue 
				Required
			 | The queue. This can either be the name of the queue, or an instance of QueueProperties. | 
Returns
| Type | Description | 
|---|---|
| A ~azure.storage.queue.aio.QueueClient object. | 
Examples
Get the queue client.
   # Get the queue client to interact with a specific queue
   queue = queue_service.get_queue_client(queue="asyncmyqueue2")
get_service_properties
Gets the properties of a storage account's Queue service, including Azure Storage Analytics.
async get_service_properties(*, timeout: int | None = None, **kwargs: Any) -> Dict[str, Any]Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | The timeout parameter is expressed in seconds. Default value: None | 
Returns
| Type | Description | 
|---|---|
| An object containing queue service properties such as analytics logging, hour/minute metrics, cors rules, etc. | 
Examples
Getting queue service properties.
   properties = await queue_service.get_service_properties()
get_service_stats
Retrieves statistics related to replication for the Queue service.
It is only available when read-access geo-redundant replication is enabled for the storage account.
With geo-redundant replication, Azure Storage maintains your data durable in two locations. In both locations, Azure Storage constantly maintains multiple healthy replicas of your data. The location where you read, create, update, or delete data is the primary storage account location. The primary location exists in the region you choose at the time you create an account via the Azure Management Azure classic portal, for example, North Central US. The location to which your data is replicated is the secondary location. The secondary location is automatically determined based on the location of the primary; it is in a second data center that resides in the same region as the primary location. Read-only access is available from the secondary location, if read-access geo-redundant replication is enabled for your storage account.
async get_service_stats(*, timeout: int | None = None, **kwargs: Any) -> Dict[str, Any]Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | The timeout parameter is expressed in seconds. Default value: None | 
Returns
| Type | Description | 
|---|---|
| The queue service stats. | 
list_queues
Returns a generator to list the queues under the specified account.
The generator will lazily follow the continuation tokens returned by the service and stop when all queues have been returned.
list_queues(name_starts_with: str | None = None, include_metadata: bool | None = False, *, results_per_page: int | None = None, timeout: int | None = None, **kwargs: Any) -> AsyncItemPagedParameters
| Name | Description | 
|---|---|
| name_starts_with | Filters the results to return only queues whose names begin with the specified prefix. Default value: None | 
| include_metadata | Specifies that queue metadata be returned in the response. Default value: False | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| results_per_page | The maximum number of queue names to retrieve per API call. If the request does not specify the server will return up to 5,000 items. Default value: None | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-queue-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. This function may make multiple calls to the service in which case the timeout value specified will be applied to each individual call. Default value: None | 
Returns
| Type | Description | 
|---|---|
| 
							<xref:azure.core.paging.AsyncItemPaged>[QueueProperties]
						 | An iterable (auto-paging) of QueueProperties. | 
Examples
List queues in the service.
   # List all the queues in the service
   list_queues = queue_service.list_queues()
   async for queue in list_queues:
       print(queue)
   # List the queues in the service that start with the name "my_"
   list_my_queues = queue_service.list_queues(name_starts_with="my_")
   async for queue in list_my_queues:
       print(queue)
set_service_properties
Sets the properties of a storage account's Queue service, including Azure Storage Analytics.
If an element (e.g. analytics_logging) is left as None, the existing settings on the service for that functionality are preserved.
async set_service_properties(analytics_logging: QueueAnalyticsLogging | None = None, hour_metrics: Metrics | None = None, minute_metrics: Metrics | None = None, cors: List[CorsRule] | None = None, *, timeout: int | None = None, **kwargs: Any) -> NoneParameters
| Name | Description | 
|---|---|
| analytics_logging | Groups the Azure Analytics Logging settings. Default value: None | 
| hour_metrics | The hour metrics settings provide a summary of request statistics grouped by API in hourly aggregates for queues. Default value: None | 
| minute_metrics | The minute metrics settings provide request statistics for each minute for queues. Default value: None | 
| cors | You can include up to five CorsRule elements in the list. If an empty list is specified, all CORS rules will be deleted, and CORS will be disabled for the service. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | The timeout parameter is expressed in seconds. Default value: None | 
Examples
Setting queue service properties.
   # Create service properties
   from azure.storage.queue import QueueAnalyticsLogging, Metrics, CorsRule, RetentionPolicy
   # Create logging settings
   logging = QueueAnalyticsLogging(
       read=True, write=True, delete=True, retention_policy=RetentionPolicy(enabled=True, days=5)
   )
   # Create metrics for requests statistics
   hour_metrics = Metrics(
       enabled=True, include_apis=True, retention_policy=RetentionPolicy(enabled=True, days=5)
   )
   minute_metrics = Metrics(
       enabled=True, include_apis=True, retention_policy=RetentionPolicy(enabled=True, days=5)
   )
   # Create CORS rules
   cors_rule1 = CorsRule(["www.xyz.com"], ["GET"])
   allowed_origins = ["www.xyz.com", "www.ab.com", "www.bc.com"]
   allowed_methods = ["GET", "PUT"]
   max_age_in_seconds = 500
   exposed_headers = ["x-ms-meta-data*", "x-ms-meta-source*", "x-ms-meta-abc", "x-ms-meta-bcd"]
   allowed_headers = ["x-ms-meta-data*", "x-ms-meta-target*", "x-ms-meta-xyz", "x-ms-meta-foo"]
   cors_rule2 = CorsRule(
       allowed_origins,
       allowed_methods,
       max_age_in_seconds=max_age_in_seconds,
       exposed_headers=exposed_headers,
       allowed_headers=allowed_headers,
   )
   cors = [cors_rule1, cors_rule2]
   # Set the service properties
   await queue_service.set_service_properties(logging, hour_metrics, minute_metrics, cors)
Attributes
api_version
location_mode
The location mode that the client is currently using.
By default this will be "primary". Options include "primary" and "secondary".
Returns
| Type | Description | 
|---|---|
| The current location mode. | 
primary_endpoint
primary_hostname
The hostname of the primary endpoint.
Returns
| Type | Description | 
|---|---|
| The hostname of the primary endpoint. | 
secondary_endpoint
The full secondary endpoint URL if configured.
If not available a ValueError will be raised. To explicitly specify a secondary hostname, use the optional secondary_hostname keyword argument on instantiation.
Returns
| Type | Description | 
|---|---|
| The full secondary endpoint URL. | 
Exceptions
| Type | Description | 
|---|---|
| If no secondary endpoint is configured. | 
secondary_hostname
url
The full endpoint URL to this entity, including SAS token if used.
This could be either the primary endpoint, or the secondary endpoint depending on the current location_mode.
Returns
| Type | Description | 
|---|---|
| The full endpoint URL to this entity, including SAS token if used. |