From AzureRM to AZ

The Az PowerShell module has been for a while the recommended PowerShell module for interacting with Azure. Here is the quick guide how to install AZ on Windows 10.

Powershell script to un-install Azure/AzureRM and install AZ

# Remove base modules:
uninstall-module Azure
uninstall-module AzureRM

# Remove the rest
$Modules = Get-Module -ListAvailable | Where {$_.Name -like 'AzureRM.*'}
Foreach ($Module in $Modules) {Uninstall-Module $Module}

# Install AZ
if ($PSVersionTable.PSEdition -eq 'Desktop' -and (Get-Module -Name AzureRM -ListAvailable)) {
    Write-Warning -Message ('Az module not installed. Having both the AzureRM and ' +
      'Az modules installed at the same time is not supported.')
} else {
    Install-Module -Name Az -AllowClobber -Scope AllUsers -Force

# Connect to Azure with a browser sign in token

Further reading

Build your skills with Microsoft Learn

Other Azure PowerShell modules

Computers Windows

Tip of today: Windows Server restart on given time

How to Schedule a Reboot. This should work also on workstation.

This will restart in 6 hours

Invoke-Command -ComputerName NameOfServer {shutdown /r /t 21600}

This will restart in 1 hour

Invoke-Command -ComputerName NameOfServer {shutdown /r /t 3600}

This will restart in 19th of October 2025 at 12:00 hour

schtasks /create /tn “Scheduled Reboot” /tr “shutdown /r /t 0” /sc once /st 12:00:00 /sd 19/10/2025 /ru “System”


Reset IIS Application Pool Remotely in PowerShell

$password = “yourpassword”
$username = “yourusername”
Write-Host “Start reset”

$SecurePassword = $password | ConvertTo-SecureString -AsPlainText -Force
$cred = New-Object System.Management.Automation.PSCredential -ArgumentList $username, $SecurePassword
$Session = New-PSSession -ComputerName $server -Credential $cred

Invoke-Command -Session $Session -ScriptBlock {
Restart-WebAppPool YourAppPoolName
Write-EventLog -LogName Application -Source MyScript -EventId 3001 -Message “AppPool restart was called from remote”

Write-Host “Reset done”

Uncategorized Windows

Umbraco Continuous Deployment with Jenkins

I haven’t seen many posts about Continuous Integration. Perhaps this is because Umbraco Cloud option offers this feature off the shelf but I have some customers that require customizations (custom databases) that would be costly on the Umbraco Cloud setup. Therefore I decided to spin up Jenkins that connects to Github repo and does automatic deployment from the main branch whenever there is push to it.

Here are few quick steps that gets you started.

1. Setup Github

Wheater you use Github or Gitlab or your own Git repo these steps do not matter. You just need a branching stradegy where the master branch matches what is in your live site.

image of release branch workflows

Merge feature branches into the master branch using pull requests.

Install Jenkins

I have root server Windows 2019 running on Hetzner but I hear OVHCloud is good as well. So, I installed Jenkins instances directly on my test server and live server. I could do the setup with PowerShell remote but Jenkins is quick to install and requires very little maintainance and resources so I just have them running isolated on the given server.

In the Jenkins server you also need Microsoft Build Tools and Nuget installed on globally available.

Configure Jenkins for Umbraco

You need some plugins in order to build .NET projects and Frontend projects. Try these:

  • MBBuild
  • Global Slack Notifier Plugin (for notifying build success/failures)
  • NodeJS Plugin (control npm builds)
  • Nuget Plugin
  • PowerShell plugin (for scripting)
  • ThinBackup (for moving Jenkins configs between instances

Here is my sample configuration on Freestyle Jenkins project.

Node version

Nuget restore command and Injection to Assembly

Run MSBuild

Copy files from Jenkins build folder to Webroot

Notice that running IISReset here is probably not the best idea. I have done same thing on Sitecore projects where instead I stop/start Application Pool. Stop-WebAppPool -Name "DefaultAppPool" you may make restarting of the application few seconds faster that way. But you need to stop AppPool or IIS because sometiimes artificats are locked and if that happens things goes south.

Post Build actions

You can also setup here Email notification or if you use Teams , RocketChat etc. there is plugins for sending notification when build completes or fails.
If you work on bigger team you can also send email for whoever pushed bad code on the success/failure.

That’s it. Minimail Jenkins setup for Umbraco projects that I use. This same setup works for any .NET projects as I did not include any actions on uSync or anything other Umbraco specific.

I have done few DevOps Setups on Jenkins, TeamCity, Azure Devops and Github Actions. Which ever CI/CD tool you are using I recommend to create your scriptinigs on Node and/or PowerShell so you can easily jump between as they all work essentially same way.


Prevent IIS indexing test enviroment

Sometimes you may have publicly facing website, which you don’t want it indexed by the major search engines. Easy way is to add robots.txt or meta tags on html but more global setting can be set on IIS settings from ‘Administrative Tools’ open ‘Internet Information Services (IIS) Manager’ > Select the Server > ‘HTTP Response Headers’.

‘Administrative Tools’ open ‘Internet Information Services (IIS) Manager’ > Select the Server > ‘HTTP Response Headers’.

Once dialog for HTTP Response Header is open

Add  > Name = X-Robots-Tag > Value = noindex > and press OK.

General info about X-Robots-Tag HTTP header

The X-Robots-Tag can be used as an element of the HTTP header response for a given URL. Any directive that can be used in a robots meta tag can also be specified as an X-Robots-Tag. Here’s an example of an HTTP response with an X-Robots-Tag instructing crawlers not to index a page:

About Robots Tag

A meta robots tag can include the following values:

  • Index: Allows search engines to add the page to their index.
  • Noindex: Disallows search engines from adding a page to their index and disallows it from appearing in search results for that specific search engine.
  • Follow: Instructs search engines to follow links on a page, so that the crawl can find other pages
  • Nofollow: Instructs search engines to not follow links on a page.
  • None: This is a shortcut for noindex, nofollow.
  • All: This is a shortcut for index, follow.
  • Noimageindex: Disallows search engines from indexing images on a page (images can still be indexed using the meta robots tag, though, if they are to linked to from another site).
  • Noarchive: Tells search engines to not show a cached version of a page.
  • Nocache: This is the same as noarchive tag, but specific to the Bingbot/MSNbot.
  • Nosnippet: Instructs search engines to not display text or video snippets.
  • Notranslate: Instructs search engines to not show translations of a page in SERPs.
  • Unavailable_after: Tells search engines a specific day and time that they should not display a result in their index.
  • Noyaca: Instructs Yandex crawler bots to not use page descriptions in results.

Read more at Google Robots meta tag, data-nosnippet, and X-Robots-Tag specifications