debian-mirror-gitlab/doc/install/azure/index.md

437 lines
20 KiB
Markdown
Raw Normal View History

2018-11-08 19:23:39 +05:30
---
2019-09-04 21:01:54 +05:30
description: 'Learn how to spin up a pre-configured GitLab VM on Microsoft Azure.'
type: howto
2018-11-08 19:23:39 +05:30
---
2018-03-17 18:26:18 +05:30
# Install GitLab on Microsoft Azure
2019-07-07 11:18:12 +05:30
Azure is Microsoft's business cloud and GitLab is a pre-configured offering on the Azure Marketplace.
Hopefully, you aren't surprised to hear that Microsoft and Azure have embraced open source software
like Ubuntu, Red Hat Enterprise Linux, and of course - GitLab! This means that you can spin up a
pre-configured GitLab VM and have your very own private GitLab up and running in around 30 minutes.
2018-03-17 18:26:18 +05:30
Let's get started.
## Getting started
First, you'll need an account on Azure. There are three ways to do this:
- If your company (or you) already has an account, then you are ready to go!
2019-07-07 11:18:12 +05:30
- You can also open your own Azure account for free. _At time of writing_, you get $200
of credit to spend on Azure services for 30 days. You can use this credit to try out paid Azure
services, exploring Microsoft's cloud for free. Even after the first 30 days, you never have to pay
anything unless you decide to transition to paid services with a Pay-As-You-Go Azure subscription.
This is a great way to try out Azure and cloud computing, and you can
2020-05-24 23:13:21 +05:30
[read more in their comprehensive FAQ](https://azure.microsoft.com/en-us/free/free-account-faq/).
2019-07-07 11:18:12 +05:30
- If you have an MSDN subscription, you can activate your Azure subscriber benefits. Your MSDN
subscription gives you recurring Azure credits every month, so why not put those credits to use and
try out GitLab right now?
2018-03-17 18:26:18 +05:30
## Working with Azure
2019-12-21 20:55:43 +05:30
Once you have an Azure account, you can get started. [Log in to Azure](https://portal.azure.com)
and the first thing you will see is the Dashboard:
2018-03-17 18:26:18 +05:30
![Azure Dashboard](img/azure-dashboard.png)
2019-07-07 11:18:12 +05:30
The Dashboard gives you a quick overview of Azure resources, and from here you can build VMs,
2018-03-17 18:26:18 +05:30
create SQL Databases, author websites, and perform lots of other cloud tasks.
## Create New VM
2019-12-21 20:55:43 +05:30
The [Azure Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/) is an online store for pre-configured applications and
2018-03-17 18:26:18 +05:30
services which have been optimized for the cloud by software vendors like GitLab,
available on the Azure Marketplace as pre-configured solutions. In this tutorial
we will install GitLab Community Edition, but for GitLab Enterprise Edition you
can follow the same process.
2019-07-07 11:18:12 +05:30
To begin creating a new GitLab VM, click on the **+ New** icon, type "GitLab" into the search
2018-03-17 18:26:18 +05:30
box, and then click the **"GitLab Community Edition"** search result:
![Azure - New - Search for 'GitLab'](img/azure-new-search-gitlab.png)
2019-07-07 11:18:12 +05:30
A new "blade" window will pop-out, where you can read more about the **"GitLab Community Edition"**
2018-03-17 18:26:18 +05:30
offering which is freely available under the MIT Expat License:
![Azure - New - Select 'GitLab Community Edition'](img/azure-new-gitlab-ce.png)
Click **"Create"** and you will be presented with the "Create virtual machine" blade:
![Azure - Create Virtual Machine - Basics](img/azure-create-virtual-machine-basics.png)
## Basics
The first items we need to configure are the basic settings of the underlying virtual machine:
1. Enter a `Name` for the VM - e.g. **"GitLab-CE"**
1. Select a `VM disk type` - either **HDD** _(slower, lower cost)_ or **SSD** _(faster, higher cost)_
2019-12-21 20:55:43 +05:30
1. Enter a `User name` - e.g. `gitlab-admin`
2018-03-17 18:26:18 +05:30
1. Select an `Authentication type`, either **SSH public key** or **Password**:
2019-07-07 11:18:12 +05:30
2019-09-30 21:07:59 +05:30
> **Note:** if you're unsure which authentication type to use, select **Password**
1. If you chose **SSH public key** - enter your `SSH public key` into the field provided
2019-10-12 21:52:04 +05:30
_(read the [SSH documentation](../../ssh/README.md) to learn more about how to set up SSH
2019-09-30 21:07:59 +05:30
public keys)_
1. If you chose **Password** - enter the password you wish to use _(this is the password that you
2020-05-24 23:13:21 +05:30
will use later in this tutorial to [SSH](https://en.wikipedia.org/wiki/Secure_Shell) into the VM, so make sure it's a strong password/passphrase)_
2018-03-17 18:26:18 +05:30
1. Choose the appropriate `Subscription` tier for your Azure account
1. Choose an existing `Resource Group` or create a new one - e.g. **"GitLab-CE-Azure"**
2018-11-20 20:47:30 +05:30
2019-09-30 21:07:59 +05:30
> **Note:** a "Resource group" is a way to group related resources together for easier administration.
> We chose "GitLab-CE-Azure", but your resource group can have the same name as your VM.
2018-11-20 20:47:30 +05:30
2018-03-17 18:26:18 +05:30
1. Choose a `Location` - if you're unsure, select the default location
Here are the settings we've used:
![Azure - Create Virtual Machine - Basics Completed](img/azure-create-virtual-machine-basics-password.png)
Check the settings you have entered, and then click **"OK"** when you're ready to proceed.
## Size
2019-07-07 11:18:12 +05:30
Next, you need to choose the size of your VM - selecting features such as the number of CPU cores,
2018-03-17 18:26:18 +05:30
the amount of RAM, the size of storage (and its speed), etc.
2019-07-07 11:18:12 +05:30
> **Note:** in common with other cloud vendors, Azure operates a resource/usage pricing model, i.e.
the more resources your VM consumes the more it will cost you to run, so make your selection
2018-03-17 18:26:18 +05:30
carefully. You'll see that Azure provides an _estimated_ monthly cost beneath each VM Size to help
guide your selection.
2019-07-07 11:18:12 +05:30
The default size - the lowest cost **"DS1_V2 Standard"** VM - meets the minimum system requirements
to run a small GitLab environment for testing and evaluation purposes, and so we're going to go
2018-03-17 18:26:18 +05:30
ahead and select this one, but please choose the size which best meets your own requirements:
![Azure - Create Virtual Machine - Size](img/azure-create-virtual-machine-size.png)
2020-03-13 15:44:24 +05:30
> **Note:** be aware that while your VM is active (known as "allocated"), it will incur
2019-07-07 11:18:12 +05:30
"compute charges" which, ultimately, you will be billed for. So, even if you're using the
free trial credits, you'll likely want to learn
2020-04-22 19:07:51 +05:30
[how to properly shutdown an Azure VM to save money](https://build5nines.com/properly-shutdown-azure-vm-to-save-money/).
2018-03-17 18:26:18 +05:30
Go ahead and click your chosen size, then click **"Select"** when you're ready to proceed to the
next step.
## Settings
2019-07-07 11:18:12 +05:30
On the next blade, you're asked to configure the Storage, Network and Extension settings.
We've gone with the default settings as they're sufficient for test-driving GitLab, but please
2018-03-17 18:26:18 +05:30
choose the settings which best meet your own requirements:
![Azure - Create Virtual Machine - Settings](img/azure-create-virtual-machine-settings.png)
Review the settings and then click **"OK"** when you're ready to proceed to the last step.
## Purchase
2019-07-07 11:18:12 +05:30
The Purchase page is the last step and here you will be presented with the price per hour for your
new VM. You'll be billed only for the VM itself (e.g. "Standard DS1 v2") because the
2018-03-17 18:26:18 +05:30
**"GitLab Community Edition"** marketplace solution is free to use at 0 USD/hr:
![Azure - Create Virtual Machine - Purchase](img/azure-create-virtual-machine-purchase.png)
2019-07-07 11:18:12 +05:30
> **Note:** at this stage, you can review and modify the any of the settings you have made during all
2018-03-17 18:26:18 +05:30
previous steps, just click on any of the four steps to re-open them.
When you have read and agreed to the terms of use and are ready to proceed, click **"Purchase"**.
## Deployment
2019-07-07 11:18:12 +05:30
At this point, Azure will begin deploying your new VM. The deployment process will take a few
2018-03-17 18:26:18 +05:30
minutes to complete, with progress displayed on the **"Deployment"** blade:
![Azure - Create Virtual Machine - Deployment](img/azure-create-virtual-machine-deployment.png)
2019-07-07 11:18:12 +05:30
Once the deployment process is complete, the new VM and its associated resources will be displayed
2018-03-17 18:26:18 +05:30
on the Azure Dashboard (you may need to refresh the page):
![Azure - Dashboard - All resources](img/azure-dashboard-running-resources.png)
2019-07-07 11:18:12 +05:30
The new VM can also be accessed by clicking the `All resources` or `Virtual machines` icons in the
2018-03-17 18:26:18 +05:30
Azure Portal sidebar navigation menu.
2018-12-05 23:21:45 +05:30
## Set up a domain name
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
The VM will have a public IP address (static by default), but Azure allows us to assign a friendly
2018-03-17 18:26:18 +05:30
DNS name to the VM, so let's go ahead and do that.
2019-07-07 11:18:12 +05:30
From the Dashboard, click on the **"GitLab-CE"** tile to open the management blade for the new VM.
2018-03-17 18:26:18 +05:30
The public IP address that the VM uses is shown in the 'Essentials' section:
![Azure - VM - Management - Public IP Address](img/azure-vm-management-public-ip.png)
2019-07-07 11:18:12 +05:30
Click on the public IP address - which should open the **"Public IP address - Configuration"** blade,
then click on **"Configuration"** (under "Settings"). Now enter a friendly DNS name for your instance
2018-03-17 18:26:18 +05:30
in the `DNS name label` field:
![Azure - VM - Domain Name](img/azure-vm-domain-name.png)
2019-12-21 20:55:43 +05:30
In the screenshot above, you'll see that we've set the `DNS name label` to `gitlab-ce-test`.
2019-07-07 11:18:12 +05:30
This will make our VM accessible at `gitlab-ce-test.centralus.cloudapp.azure.com`
_(the full domain name of your own VM will be different, of course)_.
2018-03-17 18:26:18 +05:30
Click **"Save"** for the changes to take effect.
2019-07-07 11:18:12 +05:30
> **Note:** if you want to use your own domain name, you will need to add a DNS `A` record at your
domain registrar which points to the public IP address of your Azure VM. If you do this, you'll need
to make sure your VM is configured to use a _static_ public IP address (i.e. not a _dynamic_ one)
or you will have to reconfigure the DNS `A` record each time Azure reassigns your VM a new public IP
2020-06-23 00:09:42 +05:30
address. Read [Public IP addresses](https://docs.microsoft.com/en-us/azure/virtual-network/public-ip-addresses) to learn more.
2018-03-17 18:26:18 +05:30
2019-12-04 20:38:33 +05:30
## Let's open some ports
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
At this stage you should have a running and fully operational VM. However, none of the services on
your VM (e.g. GitLab) will be publicly accessible via the internet until you have opened up the
2018-03-17 18:26:18 +05:30
necessary ports to enable access to those services.
2019-07-07 11:18:12 +05:30
Ports are opened by adding _security rules_ to the **"Network security group"** (NSG) which our VM
has been assigned to. If you followed the process above, then Azure will have automatically created
an NSG named `GitLab-CE-nsg` and assigned the `GitLab-CE` VM to it.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
> **Note:** if you gave your VM a different name then the NSG automatically created by Azure will
2018-03-17 18:26:18 +05:30
also have a different name - the name you have your VM, with `-nsg` appended to it.
2019-07-07 11:18:12 +05:30
You can navigate to the NSG settings via many different routes in the Azure Portal, but one of the
simplest ways is to go to the Azure Dashboard, and then click on the Network Security Group listed
2018-03-17 18:26:18 +05:30
in the **"All resources"** tile:
![Azure - Dashboard - All resources - Network security group](img/azure-dashboard-highlight-nsg.png)
2019-07-07 11:18:12 +05:30
With the **"Network security group"** blade open, click on **"Inbound security rules"** under
2018-03-17 18:26:18 +05:30
**"Settings"**:
![Azure - Network security group - Inbound security rules](img/azure-nsg-inbound-sec-rules-highlight.png)
Next, click **"Add"**:
![Azure - Network security group - Inbound security rules - Add](img/azure-nsg-inbound-sec-rules-add-highlight.png)
### Which ports to open?
2019-07-07 11:18:12 +05:30
Like all servers, our VM will be running many services. However, we want to open up the correct
2018-03-17 18:26:18 +05:30
ports to enable public internet access to two services in particular:
2019-07-07 11:18:12 +05:30
1. **HTTP** (port 80) - opening port 80 will enable our VM to respond to HTTP requests, allowing
public access to the instance of GitLab running on our VM.
1. **SSH** (port 22) - opening port 22 will enable our VM to respond to SSH connection requests,
allowing public access (with authentication) to remote terminal sessions
2020-05-24 23:13:21 +05:30
_(you'll see why we need [SSH](https://en.wikipedia.org/wiki/Secure_Shell) access to our VM [later on in this tutorial](#maintaining-your-gitlab-instance))_
2018-03-17 18:26:18 +05:30
### Open HTTP on Port 80
2019-07-07 11:18:12 +05:30
In the **"Add inbound security rule"** blade, let's open port 80 so that our VM will accept HTTP
2018-03-17 18:26:18 +05:30
connections:
![Azure - Add inbound security rules - HTTP](img/azure-add-inbound-sec-rule-http.png)
1. Enter **"HTTP"** in the `Name` field
2020-03-13 15:44:24 +05:30
1. Select **HTTP** from the options in the `Service` dropdown list
2018-03-17 18:26:18 +05:30
1. Make sure the `Action` is set to **Allow**
1. Click **"OK"**
### Open SSH on Port 22
2019-07-07 11:18:12 +05:30
Repeat the above process, adding a second Inbound security rule to open port 22, enabling our VM to
2020-05-24 23:13:21 +05:30
accept [SSH](https://en.wikipedia.org/wiki/Secure_Shell) connections:
2018-03-17 18:26:18 +05:30
![Azure - Add inbound security rules - SSH](img/azure-add-inbound-sec-rule-ssh.png)
1. Enter **"SSH"** in the `Name` field
2020-03-13 15:44:24 +05:30
1. Select **SSH** from the options in the `Service` dropdown list
2018-03-17 18:26:18 +05:30
1. Make sure the `Action` is set to **Allow**
1. Click **"OK"**
2019-07-07 11:18:12 +05:30
It will take a moment for Azure to add each new Inbound Security Rule (and you may need to click on
**"Inbound security rules"** to refresh the list), but once completed, you should see the two new
2018-03-17 18:26:18 +05:30
rules in the list:
![Azure - Inbound security rules - List](img/azure-inbound-sec-rules-list.png)
## Connecting to GitLab
2019-09-30 21:07:59 +05:30
2019-07-07 11:18:12 +05:30
Use the domain name you set up earlier (or the public IP address) to visit your new GitLab instance
in your browser. If everything has gone according to plan you should be presented with the
2018-03-17 18:26:18 +05:30
following page, asking you to set a _new_ password for the administrator account automatically
created by GitLab:
![GitLab - Change Password](img/gitlab-change-password.png)
Enter your _new_ password into both form fields, and then click **"Change your password"**.
2019-07-07 11:18:12 +05:30
Once you have changed the password you will be redirected to the GitLab login page. Use `root` as
2018-03-17 18:26:18 +05:30
the username, enter the new password you set in the previous step, and then click **"Sign in"**:
![GitLab - Login](img/gitlab-login.png)
### Success?
2019-07-07 11:18:12 +05:30
After signing in successfully, you should see the GitLab Projects page displaying a
2018-03-17 18:26:18 +05:30
**"Welcome to GitLab!"** message:
![GitLab - Projects Page](img/gitlab-home.png)
2019-07-07 11:18:12 +05:30
If so, you now have a working GitLab instance on your own private Azure VM. **Congratulations!**
2018-03-17 18:26:18 +05:30
## Creating your first GitLab project
2019-07-07 11:18:12 +05:30
You can skip this section if you are familiar with Git and GitLab. Otherwise, let's create our first
2018-03-17 18:26:18 +05:30
project. From the Welcome page, click **"New Project"**.
2019-07-07 11:18:12 +05:30
Let's give our project a name and a description, and then accept the default values for everything
2018-03-17 18:26:18 +05:30
else:
1. Enter **"demo"** into the `Project path` project name field
1. Enter a `description`, e.g. **"My awesome demo project!"**
1. Click **"Create project"**
![GitLab - New Project](img/gitlab-new-project.png)
2019-07-07 11:18:12 +05:30
Once the new project has been created (which should only take a moment), you'll be redirected to
2018-03-17 18:26:18 +05:30
homepage for the project:
![GitLab - Empty Project](img/gitlab-project-home-empty.png)
2019-07-07 11:18:12 +05:30
If you scroll further down the project's home page, you'll see some basic instructions on how to
2018-12-05 23:21:45 +05:30
set up a local clone of your new repository and push and pull from it:
2018-03-17 18:26:18 +05:30
![GitLab - Empty Project - Basic Instructions](img/gitlab-project-home-instructions.png)
**That's it! You now have your own private GitLab environment installed and running in the cloud!**
## Maintaining your GitLab instance
2019-07-07 11:18:12 +05:30
It's important to keep your GitLab environment up-to-date. The GitLab team is constantly making
enhancements and occasionally you may need to update for security reasons. So let's review how to
update GitLab.
2018-03-17 18:26:18 +05:30
### Checking our current version
To check which version of GitLab we're currently running, click on the "Admin Area" link - it's the
2019-07-07 11:18:12 +05:30
the wrench icon displayed in the top-right, next to the search box.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
In the following screenshot you can see an **"update asap"** notification message in the top-right.
This particular message indicates that there is a newer version of GitLab available which contains
2018-03-17 18:26:18 +05:30
one or more security fixes:
![GitLab - update asap](img/gitlab-admin-area.png)
2019-07-07 11:18:12 +05:30
Under the **"Components"** section, we can see that our VM is currently running version `8.6.5` of
GitLab. This is the version of GitLab which was contained in the Azure Marketplace
**"GitLab Community Edition"** offering we used to build the VM when we wrote this tutorial.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
> **Note:** The version of GitLab in your own VM instance may well be different, but the update
2018-03-17 18:26:18 +05:30
process will still be the same.
### Connect via SSH
2019-07-07 11:18:12 +05:30
To perform an update, we need to connect directly to our Azure VM instance and run some commands
from the terminal. Our Azure VM is actually a server running Linux (Ubuntu), so we'll need to
2020-05-24 23:13:21 +05:30
connect to it using SSH ([Secure Shell](https://en.wikipedia.org/wiki/Secure_Shell)).
2018-03-17 18:26:18 +05:30
2019-12-21 20:55:43 +05:30
If you're running Windows, you'll need to connect using [PuTTY](https://www.putty.org) or an equivalent Windows SSH client.
2019-07-07 11:18:12 +05:30
If you're running Linux or macOS, then you already have an SSH client installed.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
> **Note:**
2019-12-04 20:38:33 +05:30
>
2019-07-07 11:18:12 +05:30
> - Remember that you will need to login with the username and password you specified
2018-11-20 20:47:30 +05:30
> [when you created](#basics) your Azure VM
2019-07-07 11:18:12 +05:30
> - If you need to reset your VM password, read
2019-12-21 20:55:43 +05:30
> [how to reset SSH credentials for a user on an Azure VM](https://docs.microsoft.com/en-us/azure/virtual-machines/troubleshooting/troubleshoot-ssh-connection).
2018-03-17 18:26:18 +05:30
#### SSH from the command-line
2020-05-24 23:13:21 +05:30
If you're running [SSH](https://en.wikipedia.org/wiki/Secure_Shell) from the command-line (terminal), then type in the following command to
2019-07-07 11:18:12 +05:30
connect to your VM, substituting `username` and `your-azure-domain-name.com` for the correct values.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
Again, remember that your Azure VM domain name will be the one you
[set up previously in the tutorial](#set-up-a-domain-name). If you didn't set up a domain name for
2018-03-17 18:26:18 +05:30
your VM, you can use the IP address in its place in the following command:
2020-03-13 15:44:24 +05:30
```shell
2018-03-17 18:26:18 +05:30
ssh username@your-azure-domain-name.com
```
2019-09-30 21:07:59 +05:30
2018-03-17 18:26:18 +05:30
Provide your password at the prompt to authenticate.
#### SSH from Windows (PuTTY)
2020-05-24 23:13:21 +05:30
If you're using [PuTTY](https://www.putty.org) in Windows as your [SSH](https://en.wikipedia.org/wiki/Secure_Shell) client, then you might want to take a quick
read on [using PuTTY in Windows](https://mediatemple.net/community/products/dv/204404604/using-ssh-in-putty-).
2018-03-17 18:26:18 +05:30
### Updating GitLab
Once you've logged in via SSH, enter the following command to update GitLab to the latest
version:
2020-03-13 15:44:24 +05:30
```shell
2018-03-17 18:26:18 +05:30
sudo apt-get update && sudo apt-get install gitlab-ce
```
2019-07-07 11:18:12 +05:30
This command will update GitLab and its associated components to the latest versions, so it will
take a little time to complete. You'll see various update tasks being completed in your SSH
2018-03-17 18:26:18 +05:30
terminal window:
![GitLab updating](img/gitlab-ssh-update-in-progress.png)
Once the update process has completed, you'll see a message like this:
2020-04-22 19:07:51 +05:30
```plaintext
2018-03-17 18:26:18 +05:30
Upgrade complete! If your GitLab server is misbehaving try running
sudo gitlab-ctl restart
before anything else.
```
#### Check out your updated GitLab
2019-07-07 11:18:12 +05:30
Refresh your GitLab instance in the browser and navigate to the Admin Area. You should now have an
up-to-date GitLab instance.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
When we wrote this tutorial our Azure VM GitLab instance was updated to the latest version at time
of writing (`9.4.0`). You can see that the message which was previously displaying **"update asap"**
2018-03-17 18:26:18 +05:30
is now showing **"up-to-date"**:
![GitLab up to date](img/gitlab-admin-area-9.4.0.png)
## Conclusion
2019-12-21 20:55:43 +05:30
Naturally, we believe that GitLab is a great Git repository tool. However, GitLab is a whole lot
2019-07-07 11:18:12 +05:30
more than that too. GitLab unifies issues, code review, CI and CD into a single UI, helping you to
move faster from idea to production, and in this tutorial we showed you how quick and easy it is to
set up and run your own instance of GitLab on Azure, Microsoft's cloud service.
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
Azure is a great way to experiment with GitLab, and if you decide (as we hope) that GitLab is for
2018-03-17 18:26:18 +05:30
you, you can continue to use Azure as your secure, scalable cloud provider or of course run GitLab
on any cloud service you choose.
## Where to next?
2019-12-04 20:38:33 +05:30
Check out our other [Technical Articles](../../articles/index.md) or browse the [GitLab Documentation](../../README.md) to learn more about GitLab.
2018-03-17 18:26:18 +05:30
### Useful links
2020-05-24 23:13:21 +05:30
- [GitLab Community Edition](https://about.gitlab.com/features/)
- [GitLab Enterprise Edition](https://about.gitlab.com/features/#ee-starter)
- [Microsoft Azure](https://azure.microsoft.com/en-us/)
- [Azure - Free Account FAQ](https://azure.microsoft.com/en-us/free/free-account-faq/)
2019-12-21 20:55:43 +05:30
- [Azure - Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/)
2020-05-24 23:13:21 +05:30
- [Azure Portal](https://portal.azure.com)
- [Azure - Pricing Calculator](https://azure.microsoft.com/en-us/pricing/calculator/)
2019-12-21 20:55:43 +05:30
- [Azure - Troubleshoot SSH Connections to an Azure Linux VM](https://docs.microsoft.com/en-us/azure/virtual-machines/troubleshooting/troubleshoot-ssh-connection)
2020-04-22 19:07:51 +05:30
- [Azure - Properly Shutdown an Azure VM](https://build5nines.com/properly-shutdown-azure-vm-to-save-money/)
2020-05-24 23:13:21 +05:30
- [SSH](https://en.wikipedia.org/wiki/Secure_Shell), [PuTTY](https://www.putty.org) and [Using SSH in PuTTY](https://mediatemple.net/community/products/dv/204404604/using-ssh-in-putty-)
2019-09-04 21:01:54 +05:30
<!-- ## Troubleshooting
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
one might have when setting this up, or when something is changed, or on upgrading, it's
important to describe those, too. Think of things that may go wrong and include them here.
This is important to minimize requests for support and to avoid doc comments with
questions that you know someone might ask.
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
If you have none to add when creating a doc, leave this section in place
but commented out to help encourage others to add to it in the future. -->