# Setting Up Data Storage on Azure¶

No matter what kind of data science you’re doing on Azure, you’re probably gonna want a place to put and access… data. :) So let’s start our introduction to Azure by setting up storage!

As we discussed in our Cloud Overview, when working on the cloud your “compute” resources and your “storage” resources are sold (mostly) separately. This isn’t entirely true – your VM has some harddrive space – but that memory is tied to that compute, and so when you shut down your compute, anything saved on those harddrives goes away. So normally we need to get some persistent storage for our data and results. Here we’ll set up storage in 3 easy steps (one of which is getting an azure account, so many of you may only have 2 steps!).

## 1. Get an Azure Subscription¶

Unsurprisingly, we have to start by signing up with Azure. There are two ways to do this that will get you free credits:

• If you are a student, you can go here and sign up for a free student account. It’ll only get you 100 dollars, and it doesn’t require a credit card. It also has fewer restrictions than the next option, so its better even if there’s less mony.

• Create a new regular account (with 200 dollars free credit to use in your first 30 days!) by creating a standard new account here. Note you will need a credit card to verify your account if you go this route.

Note that if you have already gotten an account and used your free credits… try and make a new account with a new email address? For example, most universities give you a short-hand email, but you can also get a “vanity” long name (e.g. my email is both nce8@duke.edu and nick.eubank@duke.edu). And gmail address are easy to make.

If you do so, your Azure account will also be associated with a free-money Subscription. A Subscription is the name Azure has for the person responsible for paying the bills, and everything you do will have to be under a subscription. If you start using Azure for a company or other large organization (like Duke), your account will get connected to the institution’s subscription so your bills go to them. But for now, I think it makes more sense for you to set up your own account, both you can enjoy Microsoft’s free money, but also (and more importantly) so you feel like you have your own cloud account that isn’t dependent on someone else’s support. As we’ve discussed repeatedly, one goal of this class is to ensure that you don’t feel stranded when you leave this class (as sometimes happens when you learn on pre-configured VMs). The cloud is available to everyone, and by creating your own account, you now have access for yourself any time you want!

Once you have an account, you should end up at the Azure Portal page. This is your home for Azure, and you’ll come back here all the time.

## 2. Create a Resource Group¶

In Azure, all the concrete things you want to use – a virtual machine, a distributed cluster, a network storage drive – are called Resources, and every resource has to live in a Resource Group. I think the goal of this is that if all the Resources for a project live in one Resource Group, then when you finish the project you can easily delete them all, and I think they’re useful for corporations to manage billing. Personally, I find it’s just kinda annoying. :)

So to create a Storage Account (a Resource), we first need to create a Resource Group. Well, actually, that’s not quite true – you can create one in the process of creating a Storage Account – but let’s be explicit and create one ourselves first. Go to your Portal, search for Resource Group, and create a new one.

Note you’re gonna have to name a LOT of stuff, so I recommend a common name for your project (I’ll use my Duke id here: nce8) followed by a shorthand for the specific thing you’re creating. So for my Resource Group, I call it nce8rg.

## 3. Create A Storage Account¶

To store data, we first need to create a Storage Account! To do so, go to your “Storage Accounts” page (you can go back to your Portal and search for it if you need to).

Then on the top right, click on the + Add button:

Then put it in the Resource Group you already have, give it a good name (I used nce8sa), and just accept the defaults. Congratulations! You have a Storage Account!

### Containers¶

While you might think that Storage Accounts are where we put our data, though, that’s not quite right. Storage Accounts can hold 4 different kinds of things: Blob Containers, File Shares, Tables, and Queues. UGH.

The good news is that, at this point in your life, you only need to worry about Blob Containers. As we mentioned in our “What is the Cloud” tutorial, Cloud storage comes in different flavors, and Blob is the most flexible, as it can hold anything (BLOB standands for Binary Large OBject storage). So unless you have reason to do otherwise, just use Blob Containers.

Other types on Azure, just so you know them, are:

• File storage: similar to Blob. File storage supports certain file sharing protocols that people may have been using before they came to the cloud, so makes life easy for people moving to the cloud. But fewer features than BLOB, so almost surely not for you. Sounds like the storage that’d be most familiar to a normal computer user, but it’s a trick. Use BLOB.

• Queue storage: specialized storage for messaging services.

• Table storage: What’s known as a NoSQL database system.

And lest this whole “Storage Account” / Blob Containers / Files thing is getting confusing (I know, so many nested groups!!!), it looks something like this:

## 4. Create Container and Add Data¶

So let’s add some data! Navigate to your Storage Accounts page, and click on the Storage Account you just created. Then on the left menu, and click on Containers under Blob Services.

But now we can create a new Container for our data! So click the + Container button, pick a name, and click Create. Congrats! You have a blob!

We’ll talk more about managing data using Python or the command line later, but for the moment, let’s just upload an easy file. Click on your new Container, click Upload in the top left, and upload a file!