Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Existing resource example #18

Merged
merged 1 commit into from
May 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ If you find this repository useful, please save the repository by hitting the
- Install [AzureCLI](https://learn.microsoft.com/en-us/cli/azure/install-azure-cli-windows?tabs=azure-cli) **[recommended method]** or
- [Azure PowerShell](https://learn.microsoft.com/en-us/powershell/azure/install-azure-powershell?view=azps-10.3.0) (must install [Bicep manually](https://learn.microsoft.com/en-us/azure/azure-resource-manager/bicep/install#install-manually) if you want to use with PowerShell)

4. [Fork](https://github.com/riosengineer/Bicepify/fork) this repository so you have a copy to lab with our examples
4. [Fork](https://github.com/riosengineer/Bicepify/fork) this repository so you have a copy to lab with the examples

5. In your forked repository, click the green Code and Open with VisualStudio for a quick start

Expand Down
82 changes: 82 additions & 0 deletions bicep-examples/existing/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
# Azure Bicep - Existing references

## Introduction

Referencing existing Azure resources in your Bicep templates is a useful way to cut down on repeating parameter values that may already be known because the resource already exists. In addition to getting properties from existing resources.

Using the `existing` keyword you can reference an existing Azure resource to call into your properties for deployments.

You can read more from the official Microsoft Learn documentation on existing resources in Bicep [here](https://learn.microsoft.com/en-us/azure/azure-resource-manager/bicep/existing-resource?WT.mc_id=MVP_319025).

## 📃 Benefits of existing references

1. ✅ (DRY) Reduce parameter or variable repetition by using existing to pull in existing Azure resources. E.g. instead of defining a parameter for a Log Analytics workspace name or resourceId that already exists you can leverage `existing`

2. ✅ Access. Allows access to existing resource properties easily e.g. ResourceId of existing resource.

3. ✅ Scope. Allows for scope flexibility. You can reference a resource in a different resource group for example.

## Azure Bicep existing examples

In this example, we are referencing two existing Azure resources:

- Resource Group
- Log Analytics Workspace

Both of these resources are likely to already existing in your Azure environment. If you're deploying a new resource you may want to put this into an existing resource group, using an existing log analytics workspace that is centralised for all metrics to ingest into. In this example within the `main.bicep` file:

We are defining the existing resources to be used in a newly deploy Storage Account.

```javascript
module storageAccount 'br/public:avm/res/storage/storage-account:0.8.3' = {
name: 'storageAccount-${uniqueString(subscription().subscriptionId)}'
scope: rg
params: {
name: 'st${uniqueString(deployment().name)}'
location: location
diagnosticSettings:[
{
workspaceResourceId: law.id
metricCategories: [
{
category: 'AllMetrics'
}
]
}
]
}
}
```

`scope: rg` which is leveraging the existing symbolic name of the existing Resource Group where we have specified the existing `name:` of the Resource Group in the `main.bicep` file.

`workspaceResourceId: law.id` which is referencing the existing Log Analytics Workspace resource to retrieve the `resourceId` property.

Combining these enables a new Storage Account to be created in an existing Resource Group and diagnostic settings to send all metrics to an existing Log Analytics Workspace.

## 🚀 Deployment

> [!NOTE]
> The deployment commands will create the existing resources first before leveraging the Bicep template to utilise these.

In VisualStudio Code open a terminal and run:

CLI

```bash
az login
az account set --subscription 'subscription name or id'
az group create -l uksouth -n existing-rg
az monitor log-analytics workspace create -n 'existing-law' -g 'existing-rg'
az deployment sub create -l 'uksouth' --confirm-with-what-if -f '.\main.bicep'
```

or PowerShell

```powershell
Connect-AzAccount
Set-AzContext -Subscription "subscription name or id"
New-AzResourceGroup -Location "UKSouth" -Name "existing-rg"
New-AzOperationalInsightsWorkspace -Location "UKSouth" -Name "existing-law" -ResourceGroupName "existing-rg"
New-AzSubscriptionDeployment -Confirm -Location "UKSouth" -TemplateFile ".\main.bicep"
```
45 changes: 45 additions & 0 deletions bicep-examples/existing/main.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
targetScope = 'subscription'

metadata name = 'Existing examples'
metadata description = 'Showcasing Azure Bicep existing resources'
metadata owner = '[email protected]'

@description('Azure region for deployments.')
param location string = 'uksouth'

// Defining existing resource group named 'existing-rg'
resource rg 'Microsoft.Resources/resourceGroups@2021-04-01' existing = {
name: 'existing-rg'
}

// Defining existing log analytics workspace named 'existing-law' from the existing resource group above 'scope: rg`
resource law 'Microsoft.OperationalInsights/workspaces@2023-09-01' existing = {
scope: rg
name: 'existing-law'
}

// Deploying Storage Account to existing resource group & log analytics workspace
module storageAccount 'br/public:avm/res/storage/storage-account:0.8.3' = {
name: 'storageAccount-${uniqueString(subscription().subscriptionId)}'
scope: rg
params: {
name: 'st${uniqueString(deployment().name)}'
location: location
diagnosticSettings:[
{
workspaceResourceId: law.id
metricCategories: [
{
category: 'AllMetrics'
}
]
}
]
}
}

@description('Storage Account name output string.')
output storageAccountName string = storageAccount.outputs.name

@description('Log Analytics Workspace Id.')
output lawName string = law.id
Loading