Skip to content

Adding an Azure Data Lake Connection

Prerequisites

  • A user with sufficient permissions is required to establish a connection with Azure Data Lake.
  • Zeenea traffic flows towards the Data Lake must be open.

Note

You can find a link to the configuration template in Zeenea Connector Downloads.

Supported Versions

The Azure connection can be set up towards ADLS Gen 2. To choose the appropriate connector, you must select ADSLGen2 in the corresponding list.

Installing the Plugin

Starting with scanner version 54, the ADLS connector is provided as a plugin.

You can download the Azure plugin from Zeenea Connector Downloads and requires a scanner version 64 or later.

For more information about how to install a plugin, see Installing and Configuring Connectors as a Plugin.

Declaring the Connection

Connectors are created and configured through a dedicated configuration file located in the /connections folder of the relevant scanner.

For more information about managing connections, see Managing Connections.

To establish a connection with an Azure Gen 2 cluster, fill in the following parameters in the dedicated configuration file:

Parameter Expected Value
name Specifies the display name for the connection.
code Specifies the unique identifier of the connection on the Zeenea platform. Once registered on the platform, this code must not be modified or the connection will be considered as new and the old one removed from the scanner.
connector_id Specifies the type of connector to be used for the connection. The value must be ADLSGen2 and must not be modified.
enabled Specifies whether to enable or disable the connection (true or false).
The default value is true.
catalog_code Specifies the catalog code associated with the connection (default when empty).
alias Specifies the list of aliases used by other connectors to generate lineage link.
For example, ["localhost:1234/db","https://some-url.org"]
secret_manager.enabled Specifies whether to enable or disable the secret manager for the connection.
This configuration works only with Scanner 73 or later and requires a functional secret manager configured in the scanner configuration file.
The default value is true.
secret_manager.key Specifies the name of the secret.
connection.account_name Specifies the ADLS account name.
connection.account_key Specifies the account Key. It can be retrieved in the Access Key section of the Azure menu.
connection.container_name Specifies the list of containers to browse, separated by spaces.
connection.oauth.tenant_id Specifies the tenant ID as defined in Azure.
connection.oauth.client_id Specifies the application ID (client) as defined in Azure.
connection.oauth.client_secret Specifies the client secret.
filter Specifies the filter used to include or exclude datasets during inventory. See Rich Filters.

Optional parameters for customizing dataset detection

Parameter Expected Value
inventory.partition Regex to identify partition folders.
inventory.skippedDirectory Regex on the name of the folders to ignore while keeping the content taken into account. The content will be scanned as if it were at the root of the parent folder. No folder is ignored by default.
inventory.ignoredDirectory Regex on the name of the folders to ignore: their content will also be ignored. No folder is ignored by default.
inventory.ignoredFile Regex in the name of the files to ignore.
Default value: "\..* \| _.* \| .*\\.crc"
inventory.extension.csv For CSV files detection.
Default value: "csv, tsv, csv.gz, tsv.gz, csv.zip, tsv.zip"
inventory.extension.parquet For Parquet files detection.
Default value: parquet.
inventory.extension.avro For Avro files detection.
Default value: avro.
inventory.extension.orc For Orc files detection.
Default value: orc.
inventory.extension.xml For Xml files detection.
Default value: xml, xml.gz, xml.zip.
inventory.extension.json For Json files detection.
Default value: json, json.gz, json.zip.
inventory.csv.header Used for configuring csv files header detection pattern. Use always to force recognizing the schema on the first line of csv files. Possible values are: never, always, and only string.
xml.namespace_identification Used for configuring XML fields identification. Use uri, except to keep the compatibility with a scanner previous to version 43, where it is necessary to use the value legacy (default value).
xml.fields_ordering Starting from version 67.
Allows ordering the list of retrieved fields.
Possible values are:
  • alphabetical: Fields are ordered alphabetically
  • "", legacy or unordered: Fields are ordered as they are read.

User Permissions

To collect metadata, the running user's permissions must allow them to access and read reports that need cataloging.

There is no specific authorization to be configured for Azure Gen 2. The connector uses the key and the string connection specified for the data lake.

Rich Filters

Since version 54 of the scanner, the ADLS connector benefits from the feature of rich filters in the configuration of the connector. You can use the following keys to filter objects during inventory:

  • container: The name of the container.
  • path: The path of the file in the container.

Paths don't start with slashes for all file systems for consistency reasons between connectors. (The choice was made based on S3 choice where the slash has no specific meaning and is only a convention).

So to excludes items in a folder test at any level you have to write:

not (path starts with 'test/' or path contains '/test/')

or with a regex (slashes in regex must be escaped):

not path ~ /(^|.*\/)test\/.*/

For more information about filters, see Filters.

Data Extraction

To extract data, the connector needs to follow specified rules in order to rebuild the hierarchy and the datasets.

For more information, see Dataset Detection on File Systems.

Collected Metadata

Inventory

The Inventory collects the list of reports along with any related data source that the user can access.

Datasets

A dataset is identified according to the connector's rules.

  • Name
  • Source Description: Not supported
  • Technical Data:

    • File Format
    • File Path

Fields

  • Name
  • Source Description
  • Type
  • Can be null: Depending on the field settings (ORC and parquet). Default value No.
  • Multivalued: Depending on the field settings (ORC and parquet). Default value No.
  • Primary Key: Not supported. Default value No.
  • Technical Data:

    • Technical Name: Field technical name
    • Native type: Field native type

Unique Identifier Keys

Each object in the catalog is associated with a unique identifier key. When the object is imported from an external system, the key is generated and provided by the connector.

For more information about identifier keys, see Identification Keys.

Object Identification Key Description
Dataset code/path/dataset name - code: Unique identifier of the connection noted in the configuration file
- path: Full path including the container name
- dataset name
Field code/path/dataset name/field name - code: Unique identifier of the connection noted in the configuration file
- path: Full path including the container name
- dataset name
- field name