Skip to main content

AKS PowerShell Tip - Add Authorized Ip

Welcome file

Background 🐼

Recently, I found out that there is no sane way to perform adding a public IP address to

the authorized IP address ranges using either the Az CLI or Az.Aks PowerShell (no cmdlets available yet) module.

From the official docs it says to use something like below format with Az CLI.


az aks update \

	--resource-group myResourceGroup \

	--name myAKSCluster \

	--api-server-authorized-ip-ranges 73.140.245.0/24

But it doesn’t tell you how to append the IP to the range, instead you need to

supply a comma separated value of public IP addresses.

Challenge ☁️

Well, this is can be done by using Az CLI with PowerShell or Bash and parsing

output then generating a comma separated string and passing it back to Az CLI

😞

Solution ⚡️

Often, when I am hit with such limitations with cmdlets or Az CLI making life

hard. I go back to using simply the 2 cmdlets provided by Az.Resources module.

Behold mighty!

  • Get-AzResource - Gets the Az resource

  • Set-AzResource - Modifies the Az resource

I ended up doing the below and creating a utility function out of it.

First, get the AKS Cluster resource. Make sure to specify the -ExpandProperties

switch to get back full fledged resource otherwise it returns a shallow instance.


$ResourceGroup = "test-aks-rg"

$Name = "aksCluster001"

$IP = "110.91.234.43"

$AksCluster = Get-AzResource -ResourceGroupName $ResourceGroup -Name $Name -ExpandProperties -ErrorAction Stop

Once you have the resource, walk-through the properties and append the IP (+=

operator in PowerShell) to the local copy of the resource.


$orgClusterInfo.Properties.apiServerAccessProfile.authorizedIpRanges += $Ip

  

Finally, perform a Set operation by piping the modified local resource copy to

Set-AzResource cmdlet.


$orgClusterInfo | Set-AzResource -ErrorAction Stop

Takeaway 🔥

Even, when there are certain utility functions not available in the Az PowerShell

module. We can rely on the `-Resource* cmdlets to work our way through.

Popular posts from this blog

Azure DevOps Tips & Tricks - Find private REST APIs

Original source -  Azure DevOps Tip - Find private APIs Often working with Azure DevOps, I hit a wall trying to automate some tasks but there are no REST API's made public yet. It was one of those task of automating creation of Environments in multi-stage YAML based pipelines in AzDO. Quick research reveals that this has been requested in uservoice  (please upvote). Let's see one of the very simple ways to discover some of these APIs.

Test connectivity via a specific network interface

Recently while working on a Private cloud implementation, I came across a scenario where I needed to test connectivity of a node to the AD/DNS via multiple network adapters.  Many of us would know that having multiple network routes is usually done to take care of redundancy. So that if a network adapter goes down, one can use the other network interface to reach out to the node. In order to make it easy for everyone to follow along, below is an analogy for the above scenario: My laptop has multiple network adapters (say Wi-Fi and Ethernet) connected to the same network. Now how do I test connectivity to a Server on the network only over say Wi-Fi network adapter?

PowerShell + SCCM : Run CM cmdlets remotely

Today I saw a tweet about using implicit remoting to load the Configuration Manager on my machine by Justin Mathews . It caught my eye as I have never really tried it, but theoretically it can be done. Note - The second tweet says "Cannot find a provider with the name CMSite", resolution to which is in the Troubleshooting section at the end.