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
Potenziare Azure AI Search con la ricerca vettoriale
Recuperare l'ultima versione di una release di GitHub
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Ottimizzazione dei block template in Angular 17
Path addizionali per gli asset in ASP.NET Core MVC
Creare una libreria CSS universale: Nav menu
Creare gruppi di client per Event Grid MQTT
Creare una libreria CSS universale: i bottoni
Criptare la comunicazione con mTLS in Azure Container Apps
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Creare classi CSS custom per Bootstrap 5
- Webcast 'ASP.NET 2.0 DataBinding: avanzato'
- Curiosi di sapere le novità di #azure per gli sviluppatori? Sintonizzatevi su #aspilive, con @crad77 Siamo sempre live da https://aspit.co/Rebuild-20
- Sviluppare applicazioni web mobile con HTML5 e jQuery mobile
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Le novità di Angular: i miglioramenti alla CLI
- Introduzione a #azure Container Apps https://aspit.co/b92 di @CristianCivera #containers