Nel grosso ecosistema dei servizi di Microsoft Azure, lo storage è quello più importante e rappresenta le basi di molti altri servizi. In particolare, i blob ci permettono di memorizzare terabyte di file in maniera del tutto gestita, sicura e performante, il tutto attraverso operazioni REST.
Dal punto di vista delle prestazioni, caricare o leggere un file sapendone l'URI completo ci garantisce velocità, lasciando a noi quindi il compito di memorizzare in un database separato l'associazione del URI ad altre informazioni che permettano alle logiche applicative e all'utente di trovarlo facilmente. I blob, infatti, soffrono di scarse prestazioni nel momento in cui decidiamo di enumerare la lista dei file alla ricerca di uno con un determinato nome.
Per non dover affiancare un database, di recente è stata introdotta la possibilità di associare dei tag ai blob stessi. Si trattano di coppie chiave/valore che ci permettono di associare stringhe. Diversamente dai metadata, già disponibili, questi tag vengono immediatamente indicizzati, permettendoci di fare ricerche molto velocemente.
Per dare un primo sguardo a questa funzionalità possiamo usare direttamente il portale che, posizionandoci sulle proprietà di un file esistente o in fase di upload, ci permette di impostare questi tag.

Possiamo inserire fino ad un massimo di 10 chiavi, con una serie di vincoli su dimensioni e caratteri, compreso il fatto che le stringhe sono case sensitive. Possiamo impostare questi tag anche attraverso le API .NET.
var tags = new Dictionary<string, string> { { "project", "ASPItalia.com" }, { "type", "txt" }, }; await myBlob.SetTagsAsync(tags);
L'indicizzazione avviene immediatamente permettendoci poi di ricercare il file, da portale o tramite API.

Il corrispettivo con le API .NET è visibile nell'esempio seguente.
var query = "'project' = 'ASPItalia.com'"; await foreach (TaggedBlobItem taggedBlobItem in serviceClient.FindBlobsByTagsAsync(query)) { Console.WriteLine(taggedBlobItem.Uri); }
La ricerca non si limita al solo operatore di uguaglianza, ma anche quelli di comparazione oltre che a quello logico AND, consentendoci anche di fare ricerche parziali.
Un ultimo aspetto interessante è rappresentato dal fatto che possiamo usare gli indici anche nel lifecycle management per automatizzare processi come lo spostamento e la cancellazione di file. Per conoscere tutti gli aspetti e limiti, rimandiamo comunque alla documentazione ufficiale:
https://docs.microsoft.com/en-us/azure/storage/blobs/storage-manage-find-blobs
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Rendere i propri workflow e le GitHub Action utilizzate più sicure
Change tracking e composition in Entity Framework
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Gestire i dati con Azure Cosmos DB Data Explorer
Generare HTML a runtime a partire da un componente Razor in ASP.NET Core
Path addizionali per gli asset in ASP.NET Core MVC
Testare l'invio dei messaggi con Event Hubs Data Explorer
Utilizzare Azure Cosmos DB con i vettori
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
.NET Conference Italia 2024
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework