Chapter 39. Azure Storage Blob Service Component
Available as of Camel version 2.19
The Azure Blob component supports storing and retrieving the blobs to/from Azure Storage Blob service.
Prerequisites
You must have a valid Windows Azure Storage account. More information is available at Azure Documentation Portal.
39.1. URI Format
azure-blob://accountName/containerName[/blobName][?options]
In most cases a blobName
is required and the blob will be created if it does not already exist.
You can append query options to the URI in the following format: ?options=value&option2=value&…
For example, to download a blob content from the public block blob blockBlob
located on the container1
in the camelazure
storage account, use the following snippet:
from("azure-blob:camelazure/container1/blockBlob"). to("file://blobdirectory");
39.2. URI Options
The Azure Storage Blob Service component has no options.
The Azure Storage Blob Service endpoint is configured using URI syntax:
azure-blob:containerOrBlobUri
with the following path and query parameters:
39.2.1. Path Parameters (1 parameter)
Name | Description | Default | Type |
---|---|---|---|
containerOrBlobUri | Required: Container or Blob compact URI. | String |
39.2.2. Query Parameters (19 parameters)
Name | Description | Default | Type |
---|---|---|---|
azureBlobClient (common) | The blob service client. | CloudBlob | |
blobOffset (common) | Set the blob offset for the upload or download operations, default is 0. | 0 | Long |
blobType (common) |
Set a blob type, | blockblob | BlobType |
closeStreamAfterRead (common) | Close the stream after read or keep it open, default is true. | true | boolean |
credentials (common) | Set the storage credentials, required in most cases. | StorageCredentials | |
dataLength (common) | Set the data length for the download or page blob upload operations. | Long | |
fileDir (common) | Set the file directory where the downloaded blobs will be saved. | String | |
publicForRead (common) | Storage resources can be public for reading their content. If this property is enabled, the credentials do not have to be set. | false | boolean |
streamReadSize (common) | Set the minimum read size in bytes when reading the blob content. | int | |
bridgeErrorHandler (consumer) |
Allows for bridging the consumer to the Camel routing Error Handler. This means any exceptions that occurred (for example, while the consumer was trying to pick up incoming messages), will now be processed as a message and handled by the routing Error Handler. By default, the consumer will use the | false | boolean |
exceptionHandler (consumer) |
To let the consumer use a custom | ExceptionHandler | |
exchangePattern (consumer) | Sets the exchange pattern when the consumer creates an exchange. | ExchangePattern | |
blobMetadata (producer) | Set the blob metadata. | Map | |
blobPrefix (producer) | Set a prefix that can be used for listing the blobs. | String | |
closeStreamAfterWrite (producer) | Close the stream after write or keep it open, default is true. | true | boolean |
operation (producer) | Blob service operation hint to the producer. | listBlobs | BlobServiceOperations |
streamWriteSize (producer) | Set the size of the buffer for writing block and page blocks. | int | |
useFlatListing (producer) | Specify if the flat or hierarchical blob listing should be used. | true | boolean |
synchronous (advanced) | Sets whether synchronous processing should be strictly used, or Camel is allowed to use asynchronous processing (if supported). | false | boolean |
Required Azure Storage Blob Service component options
You must provide the containerOrBlob
name and the credentials if the private blob needs to be accessed.
39.3. Usage
39.3.1. Message headers set by the Azure Storage Blob Service producer
Header | Type | Description |
---|---|---|
|
| The file name for the downloaded blob content. |
39.3.2. Message headers set by the Azure Storage Blob Service producer consumer
Header | Type | Description |
---|---|---|
|
| The file name for the downloaded blob content. |
39.3.3. Azure Blob Service operations
Operations common to all block types
Operation | Description |
---|---|
| Get the content of the blob. You can restrict the output of this operation to a blob range. |
| Delete the blob. |
| List the blobs. |
Block blob operations
Operation | Description |
---|---|
| Put block blob content that either creates a new block blob or overwrites the existing block blob content. |
|
Upload block blob content, by first generating a sequence of blob blocks and then committing them to a blob. If you enable the message CommitBlockListLater property, you can execute the commit later with the |
|
Commit a sequence of blob blocks to the block list that you previously uploaded to the blob service (by using the |
| Get the block blob list. |
Append blob operations
Operation | Description |
---|---|
|
Create an append block. By default, if the block already exists then it is not reset. Note that you can alternately create an append blob by enabling the message AppendBlobCreated property and using the |
| Append the new content to the blob. This operation also creates the blob if it does not already exist and if you enabled a message AppendBlobCreated property. |
Page Block operations
Operation | Description |
---|---|
|
Create a page block. By default, if the block already exists then it is not reset. Note that you can also create a page blob (and set its contents) by enabling a message PageBlobCreated property and by using the |
| Create a page block (unless you enable a message PageBlobCreated property and the identically named block already exists) and set the content of this blob. |
| Resize the page blob. |
| Clear the page blob. |
| Get the page blob page ranges. |
39.3.4. Azure Blob Client configuration
If your Camel application is running behind a firewall or if you need more control over the Azure Blob Client configuration, you can create your own instance:
StorageCredentials credentials = new StorageCredentialsAccountAndKey(accountName, accessKey); CloudBlob client = new CloudBlockBlob(URI.create("https://" + accountName + ".blob.core.windows.net/" + containerName + "/" + fileName), credentials); registry.bind("azureBlobClient", client);
Refer to this instance in your Camel azure-blob
component configuration:
from("azure-blob://" + accountName + "/" + containerName + "/" + fileName + "?azureBlobClient=#client") .to("mock:result");
39.4. Dependencies
Maven users must add the following dependency to their pom.xml
:
pom.xml
<dependency> <groupId>org.apache.camel</groupId> <artifactId>camel-azure</artifactId> <version>${camel-version}</version> </dependency>
where ${camel-version}
must be replaced by the actual version of Camel (2.19.0 or higher).
39.5. See Also
- Configuring Camel
- Component
- Endpoint
- Getting Started
- Azure Component