To begin, export environment variables as shown in "Sample .bashrc" below.
These environment variables will be used to create Azure resources.
export RESOURCEGROUP=myresouregroup
export LOCATION=westus
export VMNAME=myvmname
export VM_USER=azureuser
export STORAGEACCTNAME=mystorageaccount
# the following will be the same as the variables exported on the VM below
export AZURE_CONNECTION_STRING="1234567890" # use the connection string for your Azure account. # Note the quotation marks around the string
export BUCKET_NAME=hsdstest # set to the name of the container you will be using
Setup Pip and Python 3 on your local machine if not already installed (e.g. with Miniconda https://docs.conda.io/en/latest/miniconda.html)
- Install azure-cli:
pip install azure-cli
- Validate runtime version az-cli is at least 2.0.80:
az version
- Login to Azure Subscription using AZ-Cli.
az login
- After successful login, the list of available subscriptions will be displayed. If you have access to more than one subscription, set the proper subscription to be used:
az account set --subscription [name]
- Run the following commands to create Azure Resource Group
az group create --name $RESOURCEGROUP --location $LOCATION
- Create an Ubuntu Virtual Machine:
az vm create --resource-group $RESOURCEGROUP --name $VMNAME --image UbuntuLTS --admin-username $VM_USER --public-ip-address-dns-name $VMNAME --location $LOCATION --generate-ssh-keys
The--generate-ssh-keys
parameter is used to automatically generate an SSH key, and put it in the default key location (~/.ssh). To use a specific set of keys instead, use the--ssh-key-value
option.
Note:: To use $VMNAME as your public DNS name, it will need to be unique across the $LOCATION the VM is located. - The above command will output values after the successful creation of the VM. Keep the publicIpAddress for use below.
- Open port 80 to web traffic:
az vm open-port --port 80 --resource-group $RESOURCEGROUP --name $VMNAME
- Create a storage account if one does not exist:
az storage account create -n $STORAGEACCTNAME -g $RESOURCEGROUP -l $LOCATION --sku Standard_LRS
- Create a container for HSDS in the storage account:
az storage container create --name $BUCKET_NAME --connection-string $AZURE_CONNECTION_STRING
Note: The connection string for the storage account can be found in the portal under Settings > Access keys on the storage account or via this cli command: az storage account show-connection-string -n $STORAGEACCTNAME -g $RESOURCEGROUP
On the VM, export environment variables as shown in "Sample .bashrc" below. IMPORTANT: If you are not adding these variables into your .bashrc, they must be exported in step 7 below, after Docker is installed.
These environment variables will be passed to the Docker containers on startup.
export BUCKET_NAME=hsdstest # set to the name of the container you will be using
export HSDS_ENDPOINT=http://myvmname.westus.cloudapp.azure.com # Set to the public DNS name of the VM. Use https protocol if SSL is desired and configured
export AZURE_CONNECTION_STRING="1234567890" # use the connection string for your Azure account. Note the quotation marks around the string
Follow the following steps to setup HSDS:
- SSH to the VM created above. Replace [publicIpAddress] with the public IP displayed in the output of your VM creation command above:
ssh $VM_USER@[publicIpAddress]
- Install Docker and docker-compose if necessary. See Docker Setup
- Get project source code:
git clone https://github.com/HDFGroup/hsds
- If you plan to use HTTP Basic Auth (usernames and passwords managed by the service), go to hsds/admin/config directory:
cd admin/config
, and copy the file "passwd.default" to "passwd.txt". Add any usernames/passwords you wish. Modify existing passwords (for admin, test_user1, test_user2, etc.) for security. If you wish to use Azure Active Directory for authentication, follow the instructions in Azure Active Directory Setup - If group-level permissions are desired (See Authorization), copy the file "groups.default" to "groups.txt". Modify existing groups as needed
- Create environment variables as in "Sample .bashrc" above. Or run:
source ~/.bashrc
if you have added them to the bashrc file - From the hsds directory (
cd ~/hsds
), start the service./runall.sh <n>
where n is the number of containers desired (defaults to 1) - Run
docker ps
and verify that the containers are running: hsds_head, hsds_sn_1, hsds_dn_[1-n] - Run
curl $HSDS_ENDPOINT/about
where and verify that "cluster_state" is "READY" (might need to give it a minute or two) - Perform post install configuration. See: Post Install Configuration
To get the latest codes changes from the HSDS repo do the following:
- Shutdown the service:
./stopall.sh
- Get code changes:
git pull
- Rebuild the Docker image:
./build.sh
- Start the service:
./runall.sh