The Azure Code Samples are currently available in English

Manage Azure DNS with Ruby

Última actualización: 27/09/2016
Editar en GitHub

This sample demonstrates how to manage your Azure DNS using a ruby client.

On this page

1. If you don't already have it, install Ruby and the Ruby DevKit.

  1. If you don't have bundler, install it.

    gem install bundler
  2. Clone the repository.

    git clone
  3. Install the dependencies using bundle.

    cd dns-ruby-zones-and-recordsets
    bundle install
  4. Create an Azure service principal either through Azure CLI, PowerShell or the portal.

  5. Set the following environment variables using the information from the service principle that you created.

    export AZURE_TENANT_ID={your tenant id}
    export AZURE_CLIENT_ID={your client id}
    export AZURE_CLIENT_SECRET={your client secret}
    export AZURE_SUBSCRIPTION_ID={your subscription id}

    [AZURE.NOTE] On Windows, use set instead of export.

  6. Run the sample.

    bundle exec ruby example.rb

What does example.rb do?

The sample creates a DNS Management client and creates a DNS zone. It starts by setting up a ResourceManagementClient object using your subscription and credentials.

subscription_id = ENV['AZURE_SUBSCRIPTION_ID'] || '11111111-1111-1111-1111-111111111111' # your Azure Subscription Id
provider =
credentials =

resource_client =
resource_client.subscription_id = web_client.subscription_id = subscription_id

The sample then sets up a resource group.

resource_group_params = do |rg|
  rg.location = WEST_US


resource_client.resource_groups.create_or_update(GROUP_NAME, resource_group_params)

Create a DNS record

record = do |r|
    arecord1 = do |a|
        a.ipv4address = ""
    arecord2 = do |a|
        a.ipv4address = ""
    r.arecords = [arecord1 , arecord2]
record_params = do |r|
    r.record_set = record

dns_client.record_sets.create_or_update(GROUP_NAME, ZONE_NAME, "www", Azure::ARM::Dns::Models::RecordType::A, record_params)

Delete a zone

dns_client.zones.delete(GROUP_NAME, ZONE_NAME)

More information

Please refer to Azure SDK for Ruby for more information.

Más ejemplos por Veronica Giaudrone