Neste artigo, saiba como se conectar a fontes de dados localizadas fora do Azure, para disponibilizar esses dados para os serviços do Azure Machine Learning. As conexões do Azure servem como proxies de cofre de chave e as interações com conexões são interações diretas com um cofre de chaves do Azure. Uma conexão do Azure Machine Learning armazena com segurança recursos de dados de nome de usuário e senha, como segredos, em um cofre de chaves. O RBAC do cofre de chaves controla o acesso a esses recursos de dados. Para esta disponibilidade de dados, o Azure suporta ligações a estas fontes externas:
Flocos de neve DB
Amazon S3
BD SQL do Azure
Importante
Esta funcionalidade está atualmente em pré-visualização pública. Esta versão de pré-visualização é fornecida sem um contrato de nível de serviço e não a recomendamos para cargas de trabalho de produção. Algumas funcionalidades poderão não ser suportadas ou poderão ter capacidades limitadas.
Uma conexão do Azure Machine Learning armazena com segurança as credenciais passadas durante a criação da conexão no Cofre da Chave do Azure do Espaço de Trabalho. Uma conexão faz referência às credenciais do local de armazenamento do cofre de chaves para uso posterior. Você não precisa lidar diretamente com as credenciais depois que elas são armazenadas no cofre de chaves. Você tem a opção de armazenar as credenciais no arquivo YAML. Um comando ou SDK da CLI pode substituí-los. Recomendamos que você evite o armazenamento de credenciais em um arquivo YAML, porque uma violação de segurança pode levar a um vazamento de credenciais.
Nota
Para uma importação de dados bem-sucedida, verifique se você instalou o pacote azure-ai-ml mais recente (versão 1.5.0 ou posterior) para SDK e a extensão ml (versão 2.15.1 ou posterior).
Se você tiver um pacote SDK mais antigo ou uma extensão CLI, remova o antigo e instale o novo com o código mostrado na seção da guia. Siga as instruções para SDK e CLI como mostrado aqui:
Este arquivo YAML cria uma conexão Snowflake DB. Certifique-se de atualizar os valores apropriados:
# my_snowflakedb_connection.yaml
$schema: http://azureml/sdk-2-0/Connection.json
type: snowflake
name: my-sf-db-connection # add your datastore name here
target: jdbc:snowflake://<myaccount>.snowflakecomputing.com/?db=<mydb>&warehouse=<mywarehouse>&role=<myrole>
# add the Snowflake account, database, warehouse name and role name here. If no role name provided it will default to PUBLIC
credentials:
type: username_password
username: <username> # add the Snowflake database user name here or leave this blank and type in CLI command line
password: <password> # add the Snowflake database password here or leave this blank and type in CLI command line
Crie a conexão do Azure Machine Learning na CLI:
Opção 1: Use o nome de usuário e senha no arquivo YAML
az ml connection create --file my_snowflakedb_connection.yaml
Opção 2: Substituir o nome de usuário e a senha na linha de comando
az ml connection create --file my_snowflakedb_connection.yaml --set credentials.
username="<username>" credentials.
password="<password>"
Opção 2: Usar WorkspaceConnection() em um script Python
from azure.ai.ml import MLClient
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import UsernamePasswordConfiguration
# If using username/password, the name/password values should be url-encoded
import urllib.parse
username = urllib.parse.quote(os.environ["SNOWFLAKEDB_USERNAME"], safe="")
password = urllib.parse.quote(os.environ["SNOWFLAKEDB_PASSWORD"], safe="")
target= "jdbc:snowflake://<myaccount>.snowflakecomputing.com/?db=<mydb>&warehouse=<mywarehouse>&role=<myrole>"
# add the Snowflake account, database, warehouse name and role name here. If no role name provided it will default to PUBLIC
name= <my_snowflake_connection> # name of the connection
wps_connection = WorkspaceConnection(name= name,
type="snowflake",
target= target,
credentials= UsernamePasswordConfiguration(username=username, password=password)
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Em Ativos na navegação à esquerda, selecione Dados. Em seguida, selecione a guia Conexão de dados. Em seguida, selecione Criar como mostrado nesta captura de tela:
No painel Criar conexão, preencha os valores conforme mostrado na captura de tela. Escolha Snowflake para a categoria e Senha de nome de usuário para o tipo de autenticação. Certifique-se de especificar o valor da caixa de texto Destino neste formato, preenchendo seus valores específicos entre os <> caracteres:
jdbc:flocos de neve://<myaccount.snowflakecomputing.com/?db>=<mydb>&warehouse=mywarehouse>&<role=<myrole>
Selecione Salvar para armazenar com segurança as credenciais no cofre de chaves associado ao espaço de trabalho relevante. Essa conexão é usada ao executar um trabalho de importação de dados.
Criar uma conexão de banco de dados Snowflake que usa OAuth
As informações nesta seção descrevem como criar uma conexão de banco de dados Snowflake que usa OAuth para autenticar.
Importante
Antes de seguir as etapas nesta seção, você deve primeiro Configurar o Azure para emitir tokens OAuth em nome do cliente. Essa configuração cria uma entidade de serviço, que é necessária para a conexão OAuth. Você precisa das seguintes informações para criar a conexão:
ID do cliente: a ID da entidade de serviço
Segredo do cliente: O segredo da entidade de serviço
ID do locatário: a ID do locatário do Microsoft Entra ID
Este arquivo YAML cria uma conexão Snowflake DB que usa OAuth. Certifique-se de atualizar os valores apropriados:
# my_snowflakedb_connection.yaml
name: snowflake_service_principal_connection
type: snowflake
# Add the Snowflake account, database, warehouse name, and role name here. If no role name is provided, it will default to PUBLIC.
target: jdbc:snowflake://<myaccount>.snowflakecomputing.com/?db=<mydb>&warehouse=<mywarehouse>&scope=<scopeForServicePrincipal>
credentials:
type: service_principal
client_id: <client-id> # The service principal's client id
client_secret: <client-secret> # The service principal's client secret
tenant_id: <tenant-id> # The Microsoft Entra ID tenant id
Crie a conexão do Azure Machine Learning na CLI:
az ml connection create --file my_snowflakedb_connection.yaml
Você também pode substituir as informações no arquivo YAML na linha de comando:
az ml connection create --file my_snowflakedb_connection.yaml --set credentials.client_id="my-client-id" credentials.client_secret="my-client-secret" credentials.tenant_id="my-tenant-id"
Com o Python SDK, você pode criar uma conexão carregando as informações de conexão armazenadas no arquivo YAML. Opcionalmente, você pode substituir os valores:
Você também pode especificar diretamente as informações de conexão em um script Python sem depender de um arquivo YAML:
from azure.ai.ml import MLClient
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import ServicePrincipalConfiguration
target= "jdbc:snowflake://<myaccount>.snowflakecomputing.com/?db=<mydb>&warehouse=<mywarehouse>&role=<myrole>"
# add the Snowflake account, database, warehouse name and role name here. If no role name provided it will default to PUBLIC
name= <my_snowflake_connection> # name of the connection
auth = ServicePrincipalConfiguration(client_id="<my-client-id>", client_secret="<my-client-secret>", tenant_id="<my-tenant-id>")
wps_connection = WorkspaceConnection(name= name,
type="snowflake",
target=target,
credentials=auth
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Nota
A criação de uma conexão de banco de dados Snowflake usando uma entidade de serviço (para OAuth) só está disponível por meio da CLI do Azure ou do SDK do Python.
Este script YAML cria uma conexão do Banco de Dados SQL do Azure. Certifique-se de atualizar os valores apropriados:
# my_sqldb_connection.yaml
$schema: http://azureml/sdk-2-0/Connection.json
type: azure_sql_db
name: my-sqldb-connection
target: Server=tcp:<myservername>,<port>;Database=<mydatabase>;Trusted_Connection=False;Encrypt=True;Connection Timeout=30
# add the sql servername, port addresss and database
credentials:
type: sql_auth
username: <username> # add the sql database user name here or leave this blank and type in CLI command line
password: <password> # add the sql database password here or leave this blank and type in CLI command line
Crie a conexão do Azure Machine Learning na CLI:
Opção 1: Use o nome de usuário / senha do arquivo YAML
az ml connection create --file my_sqldb_connection.yaml
Opção 2: Substituir o nome de usuário e senha no arquivo YAML
az ml connection create --file my_sqldb_connection.yaml --set credentials.
username="<username>" credentials.
password="<password>"
from azure.ai.ml import MLClient
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import UsernamePasswordConfiguration
# If using username/password, the name/password values should be url-encoded
import urllib.parse
username = urllib.parse.quote(os.environ["MYSQL_USERNAME"], safe="")
password = urllib.parse.quote(os.environ["MYSQL_PASSWORD"], safe="")
target= "Server=tcp:<myservername>,<port>;Database=<mydatabase>;Trusted_Connection=False;Encrypt=True;Connection Timeout=30"
# add the sql servername, port address and database
name= <my_sql_connection> # name of the connection
wps_connection = WorkspaceConnection(name= name,
type="azure_sql_db",
target= target,
credentials= UsernamePasswordConfiguration(username=username, password=password)
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Em Ativos na navegação à esquerda, selecione Dados. Em seguida, selecione a guia Conexão de dados. Em seguida, selecione Criar como mostrado nesta captura de tela:
No painel Criar conexão, preencha os valores conforme mostrado na captura de tela. Escolha AzureSqlDb para a categoria e Senha de nome de usuário para o tipo de autenticação. Certifique-se de especificar o valor da caixa de texto Destino neste formato, preenchendo seus valores específicos entre os <> caracteres:
Servidor = tcp:< myservername>,< porta>; Banco de dados =< mydatabase>; Trusted_Connection=Falso; Encriptar=Verdadeiro; Tempo limite de conexão=30
Opção 2: Usar WorkspaceConnection() em um script Python
from azure.ai.ml import MLClient
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import AccessKeyConfiguration
target=<mybucket> # add the s3 bucket details
name=<my_s3_connection> # name of the connection
wps_connection=WorkspaceConnection(name=name,
type="s3",
target= target,
credentials= AccessKeyConfiguration(access_key_id="XXXJ5kL6mN7oP8qR9sT0uV1wX2yZ3aB4cXXX",acsecret_access_key="C2dE3fH4iJ5kL6mN7oP8qR9sT0uV1w")
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Em Ativos na navegação à esquerda, selecione Dados. Em seguida, selecione a guia Conexão de dados. Em seguida, selecione Criar como mostrado nesta captura de tela:
No painel Criar conexão, preencha os valores conforme mostrado na captura de tela. Escolha S3 para a categoria e Senha de nome de usuário para o tipo de autenticação. Certifique-se de especificar o valor da caixa de texto Destino neste formato, preenchendo seus valores específicos entre os <> caracteres:
<público-alvo>
Conexões sem dados
Você pode usar estes tipos de conexão para se conectar ao Git:
Feed Python
Registo de Contentores do Azure
uma conexão que usa uma chave de API
Essas conexões não são conexões de dados, mas são usadas para se conectar a serviços externos para uso em seu código.
O exemplo a seguir cria uma conexão do Registro de Contêiner do Azure. Uma identidade gerenciada autentica essa conexão:
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import UsernamePasswordConfiguration
# If using username/password, the name/password values should be url-encoded
import urllib.parse
username = urllib.parse.quote(os.environ["REGISTRY_USERNAME"], safe="")
password = urllib.parse.quote(os.environ["REGISTRY_PASSWORD"], safe="")
name = "my_acr_conn"
target = "https://iJ5kL6mN7.core.windows.net/mycontainer"
wps_connection = WorkspaceConnection(
name=name,
type="container_registry",
target=target,
credentials=UsernamePasswordConfiguration(username=username, password=password),
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Não é possível criar uma conexão do Registro de Contêiner do Azure no estúdio.
Chave de API
O exemplo a seguir cria uma conexão de chave de API:
from azure.ai.ml.entities import WorkspaceConnection
from azure.ai.ml.entities import UsernamePasswordConfiguration, ApiKeyConfiguration
name = "my_api_key"
target = "https://L6mN7oP8q.core.windows.net/mycontainer"
wps_connection = WorkspaceConnection(
name=name,
type="apikey",
target=target,
credentials=ApiKeyConfiguration(key="9sT0uV1wX"),
)
ml_client.connections.create_or_update(workspace_connection=wps_connection)
Registro de contêiner genérico
Usando a conexão do espaço de trabalho GenericContainerRegistry, você pode especificar um registro externo, como Nexus ou Artifactory, para compilações de imagem. As imagens de ambiente são enviadas por push do registro especificado e o cache anterior é ignorado.