azbak
v2.0.6
Published
Command-line utility and Node.js module to backup a file or a stream to Azure Blob Storage.
Downloads
17
Readme
azbak
Command-line utility and Node.js module to backup a file or a stream to Azure Blob Storage.
Features:
- Fully stream-based
- The CLI supports piping input from a stream or reading from a file on disk
- Automatically chunks files/streams bigger than the maximum blob size (~4.8 TB) into multiple blobs
- Supports SAS Tokens
- Cross-platform
- Small memory footprint
Full documentation on GitHub Pages.
Command-line tool
Installation
azbak requires Node.js 8 or higher and npm.
You can install the application from npm:
npm install --global azbak
Usage
Command reference:
azbak [options] <input> <destinationPath>
Authentication
You need to authenticate against Azure Blob Storage using a storage account name and an access key. azbak supports passing these values in the same way as the official Azure CLI, using environmental variables AZURE_STORAGE_ACCOUNT
and AZURE_STORAGE_ACCESS_KEY
.
Alternatively, you can authenticate using Shared Access Signature (SAS) tokens, which are limited in time and scope, and are a safer alternative for scripts, cron jobs, etc. To use SAS tokens, pass authentication data with the environmental variables AZURE_STORAGE_ACCOUNT
and AZURE_STORAGE_SAS_TOKEN
.
It's possible to pass authentication data also as command line arguments: --storage-account
, --access-key
and --sas-token
. This is implemented for those scenarios that don't easily support using environmental variables (e.g. certain scripts); however, it's recommended to use environmental variables whenever possible.
Arguments
input
is either:
- The path of a local file to upload (e.g.
/path/to/file.jpg
) - A dash (
-
) to read from stdin
destinationPath
is the path inside the Azure Blob Storage account used as destination. It has to start with a slash and include a container name (e.g. /container/path/to/file.jpg
). The destination name always has a sequence number automatically appended (e.g. .000
, .001
, etc), unless the --no-suffix
option is passed.
Options
The following command line options are available:
-b
or--blocks
: Number of blocks in each blob sent to Azure Blob Storage, each of a fixed size. The maximum (and default) value is 50,000. Setting this to a lower value can lead to more, separate blobs to be created. Because each blob has a performance target of 60MB/s, having your data split into multiple blobs allows for parallel downloads and so potentially faster restores. This has no impact on upload speed, however, as uploads are always sequential.-s
or--block-size
: Size of each block sent to Azure Blob Storage. The maximum size is 100MB, but the default value is 20MB to reduce memory footprint. Bigger block sizes allow for larger blobs: assuming 50,000 blocks per blob (the default and maximum value), with 100MB-blocks each blob can be up to ~4.8TB, while with 20MB-blocks blobs are limited to ~1TB.-c
or--concurrency
: Number of chunks to upload in parallel (default is 3). Higher parallelization could help ensuring an efficient use of your Internet connection, but will require more memory.--no-suffix
: Upload a single blob only, without appending a numeric suffix to the file name (e.g..000
). Please note that if the file is too big to fit in one blob (as defined byblocks * blockSize
), the upload will fail.--endpoint
: Endpoint to use. The default value isblob.core.windows.net
, which is used by the global Azure infrastructure. Other common values areblob.core.cloudapi.de
for Azure Germany andblob.core.chinacloudapi.cn
for Azure China. Users of Azure Stack can enter their custom endpoint.--no-md5
: Skip calculating MD5 checksums locally before uploading blocks. This can speed up operation on slower systems, but offers no protection against data corruption while in transit.--storage-account
: Name of the Azure Storage Account to use. This is an alternative to passing the environmental variableAZURE_STORAGE_ACCOUNT
.--access-key
: Access Key for the Azure Storage Account to use. This is an alternative to passing the environmental variableAZURE_STORAGE_ACCESS_KEY
.--sas-token
: SAS Token to use for authentication. This is an alternative to passing the environmental variableAZURE_STORAGE_SAS_TOKEN
.-h
or--help
: Prints help message-V
or--version
: Prints application version
Examples
Set credentials:
# First method: use export statements (bash syntax)
export AZURE_STORAGE_ACCOUNT="storageaccountname"
export AZURE_STORAGE_ACCESS_KEY="abc123"
azbak archive.tar /bak/data01.tar
# Second method: pass arguments inline
AZURE_STORAGE_ACCOUNT="storageaccountname" AZURE_STORAGE_ACCESS_KEY="abc123" azbak archive.tar /bak/data01.tar
# Use SAS Tokens
export AZURE_STORAGE_ACCOUNT="storageaccountname"
export AZURE_STORAGE_SAS_TOKEN="?sv=...&sig=..."
azbak archive.tar /bak/data01.tar
# Pass authentication data as command line arguments
azbak archive.tar /bak/data01.tar --storage-account "storageaccountname" --sas-token "?sv=...&sig=..."
Upload file from local disk:
# Upload file archive.tar to Azure Blob Storage, named "path/data01.tar" inside the Storage Account "bak"
azbak archive.tar /bak/path/data01.tar
Stream from stdin:
# Syntax
azbak - /container/file-from-stdin.tar
# Example: gzip file and upload
cat largefile.dat | gzip | azbak - /bak/largefile.dat.gz
Library
Installation
azbak requires Node.js version 8.0 or higher and npm.
You can install the package from npm:
npm install --save azbak
Usage
You can use azbak as a library for other Node.js applications.
Example code:
const StreamUpload = require('azbak')
// Authentication data
let authData = {
storageAccountName: storageAccountName,
storageAccountKey: storageAccountKey,
// If using SAS token, instead of storageAccountKey use:
//storageAccountSasToken: storageAccountSasToken
}
// Create the StreamUpload object
let upload = new StreamUpload(sourceStream, destinationPath, authData)
// Pass options
upload.blockSize = 10 * 1024 * 1024
// Start upload
let uploadPromise = upload.upload()
// uploadPromise is a then-able
uploadPromise.then((urls) => {
// List of blobs uploaded
console.log(urls)
}, (err) => {
// In case of errors
console.log('Upload failed: ', err)
})
Full API documentation is available in the /docs folder.
Docker
This utility is available as a Docker container too, published on Docker Hub on italypaleale/azbak You can pass data to be uploaded via stdin, or by mounting a local volume. Examples:
# Uploading a file from stdin
# Note the -i flag for docker run
# We also need to explicitly specify the "azbak" binary, or docker run will assume "-" is the executable
# You can pass any argument to azbak as if it were to be installed locally
cat archive.tar | docker run \
--rm \
-i \
italypaleale/azbak \
azbak - /container/archive.tar \
--storage-account "storageaccountname" \
--access-key "abc123"
# Same as above, but passing credentials as environmental variables
cat archive.tar | docker run \
--rm \
-i \
-e "AZURE_STORAGE_ACCOUNT=storageaccountname" \
-e "AZURE_STORAGE_ACCESS_KEY=abc123" \
italypaleale/azbak \
azbak - /container/archive.tar
# Mounting a local volume to upload a file from disk (test.jpg from the current folder)
docker run \
--rm \
-v "${PWD}/test.jpg:/tmp/test.jpg" \
-e "AZURE_STORAGE_ACCOUNT=storageaccountname" \
-e "AZURE_STORAGE_ACCESS_KEY=abc123" \
italypaleale/azbak \
azbak /tmp/test.jpg /container/test.jpg