I blob di Windows Azure sono un comodo strumento per depositare file in modo sicuro e soprattutto scalabile. Il loro punto di forza risiede nel fatto che ogni file viene rindondato su più server sia a scopi di backup, sia per permettere il download e l'upload senza limiti di spazio, il tutto a ottime prestazioni. Può essere usato in situazioni in cui pochi scrivono (un engine o ruolo) e molti leggono, ma anche per quelle situazioni in cui molti scrivono e leggono. E' proprio nella fase di scrittura che, in alcune circostanze, abbiamo la necessità di evitare che più attori possano contemporaneamente scrivere su uno stesso file.
Per questo scopo viene in aiuto la possibilità di lease, cioè la possibilità che abbiamo di bloccare un risorsa e rilasciarla solo al termine dell'operazione su di essa. Data la natura scalabile di Windows Azure, la chiamata per ottenre il blocco, restituisce un ID, da presentare ad ogni richiesta, che ci dà l'autorizzazione alla modifica di quel file, mentre per chi non presenta questo ID, sarà consentito solo la lettura. Fare questo con le API di .NET è abbastanza semplice e possiamo vedere un esempio nello snippet seguente.
var account = CloudStorageAccount.DevelopmentStorageAccount; // Ottengo il riferimento al file $root/test.txt var client = account.CreateCloudBlobClient(); var container = client.GetRootContainerReference(); var blob = container.GetBlockBlobReference("test.txt"); // Acquisisco il lease (ricevo un errore se già acquisito) var leaseId = blob.AcquireLease(TimeSpan.FromSeconds(60), null); // Preparo l'oggetto da passare ad ogni chiamata per consentire la scrittura var ac = new AccessCondition { LeaseId = leaseId }; blob.UploadFromStream(new MemoryStream(), ac); // Rilascio il lease blob.ReleaseLease(ac); // Rinnovo il lease // blob.RenewLease // Interrompo il lease, ma finché non scade nessun altro può acquisirlo // blob.BreakLease
Molto importante è il TimeSpan che specifica per quanti secondi ottenere il lease. E' un parametro opzionale, ma che suggeriamo di utilizzare sempre. In caso di mancato rilascio, infatti, il timeout garantisce che dopo un certo periodo di tempo il lease venga rilasciato in automatico dal sistema. Nel codice precedente vengono indicati anche altri metodi rispettivamente per rinnovare il lease e per rompere il lease, cioè mantenere bloccato il file, ma senza la possibilità di continuare a scrivere fino allo scadere del timeout (tipicamente da chiamare in alternativa al rilascio).
Link di approfondimento
http://msdn.microsoft.com/en-us/library/windowsazure/ee691972.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Gestire gli accessi con Token su Azure Container Registry
Miglioramenti agli screen reader e al contrasto in Angular
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Cambiare la chiave di partizionamento di Azure Cosmos DB
Effettuare il refresh dei dati di una QuickGrid di Blazor
C# 12: Cosa c'è di nuovo e interessante
Eseguire query per recuperare il padre di un record che sfrutta il tipo HierarchyID in Entity Framework