-
Notifications
You must be signed in to change notification settings - Fork 654
Continuous deployment
The Azure portal makes it easy to set up continuous deployment from GitHub or Bitbucket.
This documents discusses what happens under the cover. In most cases you don't need to worry about this. It can be useful to set up continuous deployment from a git host that the portal doesn't directly support, like GitLab.
You can set up continuous deployment using Resource Explorer (https://resources.azure.com/), which works at the Azure REST API level. While more 'low level' than the portal, it is in practice very easy to do.
Use the following steps:
- First, create your Web App using the portal or any other technique
- Go to https://resources.azure.com/
- Find your site, either using the search UI or by expand the tree
- Under the site, open up the
sourcecontrols/web
node in the tree - Click on the Edit button (you may need to first set Explorer to Read/Write mode)
- In that json, you will see something that looks like this:
"properties": {
"repoUrl": null,
"branch": null,
"isManualIntegration": false,
"deploymentRollbackEnabled": false,
"isMercurial": false
}
-
Set the repoUrl property to your repo, e.g.
"repoUrl": "https://github.com/davidebbo-test/Hello_World_Demo",
-
(optional) if you want to use a non-default branch, set the
"branch"
property as well -
Click the PUT button to apply the change
-
You're done! Now if you go to the portal, you should see that the site is hooked up, and the initial commit will get deployed
Note: Unlike the Resource Explorer case above, the repoUrl property should not be changed when configuring manually. The webhook payload should already contain the remote repository URL.
Use your repo's URL when setting this up. This will allow the 'sync' button in the portal to work.
Note: this may not work with private GitHub repos (see issue). In that case, you may need to set it up as Local Git instead.
The hook URL is the /deploy
path on the Kudu service. So it looks like https://mysite.scm.azurewebsites.net/deploy
. But since the service uses basic auth, you need to pass the creds in the URL. Typically, you'll want to use the site-level credentials here and not the user credentials (see Deployment-credentials). So the full URL will look like https://$mysite:BigRandomPassword@mysite.scm.azurewebsites.net/deploy
The easiest way to get this URL is to directly copy it from the Azure Portal. You'll find it under the Properties page, in the Deployment Trigger Url field.
Once you have the URL, you can set it as a GitHub/Bitbucket/GitLab hook.
If the repo is private, you will also need to set up an SSH 'deploy key' on GitHub/Bitbucket/GitLab.
This can be done using the following steps:
- Take the full deploy URL above, and replace
/deploy
with/api/sshkey?ensurePublicKey=1
. So it'll look likehttps://$mysite:BigRandomPassword@mysite.scm.azurewebsites.net/api/sshkey?ensurePublicKey=1
- Run
curl
on this URL, which returns an SSH public key. It's returned as a JSON string, so you'll need to remove the quotes. It should look likessh-rsa AAAAB3NzaC1etc...
- Set this string as a 'deploy key' on your GitHub/Bitbucket/GitLab repository.
- To configure support for
ssh-dss
algorithm, addHostKeyAlgorithms ssh-dss
tod:\home\.ssh\config
.
HOST *
StrictHostKeyChecking no
HostKeyAlgorithms ssh-dss
The easiest way to test it is to got to GitHub/Bitbucket/GitLab and click 'test' on the Web Hook you set up. Or you can try simply pushing a change to your repo.