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
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Eseguire attività con Azure Container Jobs
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Creare un'applicazione React e configurare Tailwind CSS
Assegnare un valore di default a un parametro di una lambda in C#
Creazione di componenti personalizzati in React.js con Tailwind CSS
Eseguire operazioni sui blob con Azure Storage Actions
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
What's new in Azure Functions and Extensions
Come EF 8 ha ottimizzato le query che usano il metodo Contains
I più letti di oggi
- Gli oggetti CallOut di Expression Blend 4.0
- Configurazione tramite environment variable in ASP.NET Core
- Controllare gli accessi IP alle app con Azure Container Apps
- Creare applicazioni web native con Electron
- Utilizzare le sequence di SQL Server in Entity Framework Core
- Update NoDo di marzo 2011 di Windows Phone in fase di distribuzione
- Tile, notifiche e background task in Windows Phone 8
- Mantenere l'ordine dei dati in una query PLINQ