Jak nahrát soubory v Azure Data Manageru pro energii pomocí souborové služby

V tomto článku víte, jak nahrát velké soubory (~5 GB) pomocí rozhraní API služby File Service v Microsoft Azure Data Manageru pro energii. Proces nahrávání zahrnuje načtení podepsané adresy URL z rozhraní File API a následné použití podepsané adresy URL k uložení souboru do služby Azure Blob Storage.

Vygenerování podepsané adresy URL

Spuštěním následujícího příkazu curl v Azure Cloud Bash získejte podepsanou adresu URL ze souborové služby pro daný datový oddíl vašeho prostředku Azure Data Manageru pro energii.

    curl --location 'https://<URI>/api/file/v2/files/uploadURL' \
    --header 'data-partition-id: <data-partition-id>' \
    --header 'Authorization: Bearer <access_token>' \
    --header 'Content-Type: text/plain'

Ukázkový požadavek

Zvažte Azure Data Manager pro zdroj energie s názvem medstest s datovým oddílem s názvem dp1.

    curl --location --request POST 'https://medstest.energy.azure.com/api/file/v2/files/uploadURL' \
    --header 'data-partition-id: medstest-dp1' \
    --header 'Authorization: Bearer  eyxxxxxxx.........................' \
    --header 'Content-Type: text/plain'

Ukázková odpověď

{
    "FileID": "2c5e7ac738a64eaeb7c0bc8bd47f90b6",
    "Location": {
        "SignedURL": "https://dummy.bloburl.com",
        "FileSource": "/osdu-user/1686647303778-2023-06-13-09-08-23-778/2c5e7ac738a64eaeb7c0bc8bd47f90b6"
    }
}

Klíč SignedURL v objektu odpovědi se pak dá použít k nahrání souborů do služby Azure Blob Storage. Doba vypršení platnosti služby SignedURL pro službu File a Datová sada je 1 hodina podle vylepšení zabezpečení z OSDU.

Nahrání souborů s velikostí menší než 5 GB

Pokud chcete nahrát soubory menší než 5 GB, můžete přímo použít volání rozhraní PUT Blob API k nahrání souborů do služby Azure Blob Storage.

Ukázkový požadavek Curl

    curl --location --request PUT '<SIGNED_URL>' \
    --header 'x-ms-blob-type: BlockBlob' \
    --header 'Content-Type: <file_type>' \ # for instance application/zip or application/csv or application/json depending on file type
    --data '@/<path_to_file>'

Pokud je nahrávání úspěšné, dostaneme v odpovědi stavový 201 Created kód.

Nahrání souborů s velikostí větší nebo rovnou 5 GB

K nahrání souborů s velikostí >= 5 GB bychom potřebovali nástroj azcopy, protože jedno volání objektu blob PUT nemůže být větší než 5 GB odkazu na dokument.

Kroky

  1. Stáhnout azcopy pomocí tohoto odkazu

  2. Spuštěním tohoto příkazu nahrajte soubor.

    azcopy copy "<path_to_file>" "signed_url"
  1. Ukázková odpověď
    INFO: Could not read destination length. If the destination is write-only, use --check-length=false on the command line.
    100.0 %, 1 Done, 0 Failed, 0 Pending, 0 Skipped, 1 Total
    
    Job 624c59e8-9d5c-894a-582f-ef9d3fb3091d summary
    Elapsed Time (Minutes): 0.1002
    Number of File Transfers: 1
    Number of Folder Property Transfers: 0
    Number of Symlink Transfers: 0
    Total Number of Transfers: 1
    Number of File Transfers Completed: 1
    Number of Folder Transfers Completed: 0
    Number of File Transfers Failed: 0
    Number of Folder Transfers Failed: 0
    Number of File Transfers Skipped: 0
    Number of Folder Transfers Skipped: 0
    TotalBytesTransferred: 1367301
    Final Job Status: Completed

Další kroky

Začněte ingestováním dat do azure Data Manageru pro energetické zdroje.