Skip to main content

Azure Batch Service - Overview (part 1)

In the last few days a new Azure service catch my eyes. Unfortunately only today I had time to write about it.
Azure Batch Service is the today star. Why? Because enables us to run tasks over Azure infrastructure without having to think about scaling, parallel and performance problems. You only need to write the batch logic, upload to Azure and everything else will be managed by Azure Batch Service.
On top this, we have a scheduling and auto scaling mechanism that enable us to have more granular control to compute resources. The API give us the possibility to publish and run batch applications without thinking about resources, service management and so on. Also, Batch Service provide us full access to configuration, giving us the possibility to manage all the resources and task execution pipeline. In this case you need to manage how content is moved, persisted and so on.

What you can run? 
There are two types of formats that can be used in this moment. An classic .exe file that represents you batch application or a batch application (that is represented by a collection of assemblies, that implements specific interfaces – we will talk about this subject later on).

What is a TVM?
Task Virtual Machine (TVM) is an Azure VM where your tasks will run. All your workload created by your tasks will run on one or more dedicated TVM. User has the possibility to define a pool of TVM that will be managed by Azure.
When you create a pool of TVM you have the possibility to specify different attributes like size, OS, pool size, scaling policy, certificates and many more. In one world you have full control of what kind of TVM are used for batch tasks. And yes, each TVM has his own IP and name.

What is a work item?
Work item is the template that specify how the application will run on TVM. It is the interfaced used by developers to control how a batch application runs.

What is a job?
A job is an instance of a work items that runs on TVM.

What is a task?
A task is the logic that is executed on TVM. One or more tasks define a job.

Do I need to manage all of them (work items, jobs and tasks)?
No. If you are adding an existing application and you only want to run in over Batch infrastructure, than the jobs, splitting into tasks, merging result and many more will be full managed by Batch Services.
On the other hand, if you want a full control of Batch, that you will need to manage and implement all of them.

What is a Merge Task?
It is the step when the results from each task is merged by the job to create the final result.

What is a file?
File represents the input data used by jobs. Based on your logic a task can use one or more files.

What is a directory?
Directory is the location under each task that is used to run the program and other temporary files. All file and directories under a job, can be accessed by the tasks of that job.

Where I need to store all this files?
All the files needs to be stored under the storage account of the subscription that is used by Batch Service.

How I trigger a batch action?
In general a batch by submitting a job. For input data, the files will be used that are related to that job. This can be done over REST API very easily.

Can I monitor a job?
Yes, when a job runs, you can monitor it (progress status) and access the output data at the end.

In the next post we will look over the code and discover how we can work with Azure Batch Service.


Popular posts from this blog

ADO.NET provider with invariant name 'System.Data.SqlClient' could not be loaded

Today blog post will be started with the following error when running DB tests on the CI machine:
threw exception: System.InvalidOperationException: The Entity Framework provider type 'System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer' registered in the application config file for the ADO.NET provider with invariant name 'System.Data.SqlClient' could not be loaded. Make sure that the assembly-qualified name is used and that the assembly is available to the running application. See for more information. at System.Data.Entity.Infrastructure.DependencyResolution.ProviderServicesFactory.GetInstance(String providerTypeName, String providerInvariantName) This error happened only on the Continuous Integration machine. On the devs machines, everything has fine. The classic problem – on my machine it’s working. The CI has the following configuration:

TeamCity.NET 4.51EF 6.0.2VS2013
It seems that there …

Entity Framework (EF) TransactionScope vs Database.BeginTransaction

In today blog post we will talk a little about a new feature that is available on EF6+ related to Transactions.
Until now, when we had to use transaction we used ‘TransactionScope’. It works great and I would say that is something that is now in our blood.
using (var scope = new TransactionScope(TransactionScopeOption.Required)) { using (SqlConnection conn = new SqlConnection("...")) { conn.Open(); SqlCommand sqlCommand = new SqlCommand(); sqlCommand.Connection = conn; sqlCommand.CommandText = ... sqlCommand.ExecuteNonQuery(); ... } scope.Complete(); } Starting with EF6.0 we have a new way to work with transactions. The new approach is based on Database.BeginTransaction(), Database.Rollback(), Database.Commit(). Yes, no more TransactionScope.
In the followi…

GET call of REST API that contains '/'-slash character in the value of a parameter

Let’s assume that we have the following scenario: I have a public HTTP endpoint and I need to post some content using GET command. One of the parameters contains special characters like “\” and “/”. If the endpoint is an ApiController than you may have problems if you encode the parameter using the http encoder.
using (var httpClient = new HttpClient()) { httpClient.BaseAddress = baseUrl; Task<HttpResponseMessage> response = httpClient.GetAsync(string.Format("api/foo/{0}", "qwert/qwerqwer"))); response.Wait(); response.Result.EnsureSuccessStatusCode(); } One possible solution would be to encode the query parameter using UrlTokenEncode method of HttpServerUtility class and GetBytes method ofUTF8. In this way you would get the array of bytes of the parameter and encode them as a url token.
The following code show to you how you could write the encode and decode methods.