# Compute This document explains how to get started using Azure Compute Service with Fog. With this gem you can create, update, list or delete availability sets and virtual machines. ## Usage First of all, you need to require the Fog library by executing: ```ruby require 'fog/azurerm' ``` ## Create Connection Next, create a connection to the Compute Service: ```ruby fog_compute_service = Fog::Compute::AzureRM.new( tenant_id: '', # Tenant Id of Azure Active Directory Application client_id: '', # Client Id of Azure Active Directory Application client_secret: '', # Client Secret of Azure Active Directory Application subscription_id: '', # Subscription Id of an Azure Account environment: '' # Azure cloud environment. Default is AzureCloud. ) ``` ## Check Server Existence ```ruby fog_compute_service.servers.check_vm_exists('', '') ``` ## Create Server **Info:** - Attribute **network_interface_card_ids** is an array of NICs Ids. The NIC Id at index zero will become primary NIC of this server (virtual machine) by default. - To create VM with managed OS disk, use the _managed_disk_storage_type_ argument - To create VM with unmanaged OS disk, use the _storage_account_name_ argument ### Virtual Machine (Managed OS Disk) ```ruby fog_compute_service.servers.create( name: '', location: '', resource_group: '', tags: { key1: 'value1', key2: 'value2', keyN: 'valueN' }, vm_size: '', username: '', disable_password_authentication: , network_interface_card_ids: ['/subscriptions//resourceGroups//providers/Microsoft.Network/networkInterfaces/'], publisher: '', # Not required if custom image is being used offer: '', # Not required if custom image is being used sku: '', # Not required if custom image is being used version: '', # Not required if custom image is being used platform: '', availability_set_id: '', # [Optional] password: '', # [Optional], if 'platform' partameter is 'Linux'. vhd_path: '', # [Optional], if you want to create the VM from a custom image. custom_data: '', # [Optional], if you want to add custom data in this VM. os_disk_caching: '', # [Optional], can be one of None, ReadOnly, ReadWrite managed_disk_storage_type: '', # [Optional], if storage_account_name is passed, can be StandardLRS or PremiumLRS os_disk_size: , # [Optional], size of the os disk in GB (upto 1023) os_disk_name: '' # [Optional], name of the os disk ) ``` **Info:** - To create VM from Image, pass in the Image ID in `image_ref` attribute **Limitation:** - Image should be in the same region - ONLY managed VM can be created from image ### Virtual Machine (Managed OS Disk from Image) ```ruby fog_compute_service.servers.create( name: '', location: '', resource_group: '', tags: { key1: 'value1', key2: 'value2', keyN: 'valueN' }, vm_size: '', username: '', disable_password_authentication: , network_interface_card_ids: ['/subscriptions//resourceGroups//providers/Microsoft.Network/networkInterfaces/'], publisher: '', # Not required if custom image is being used offer: '', # Not required if custom image is being used sku: '', # Not required if custom image is being used version: '', # Not required if custom image is being used platform: '', availability_set_id: '', # [Optional] password: '', # [Optional], if 'platform' partameter is 'Linux'. image_ref: '', # [Optional], if you want to create the VM from a custom image. custom_data: '', # [Optional], if you want to add custom data in this VM. os_disk_caching: '', # [Optional], can be one of None, ReadOnly, ReadWrite managed_disk_storage_type: '', # [Optional], if storage_account_name is passed, can be StandardLRS or PremiumLRS os_disk_size: , # [Optional], size of the os disk in GB (upto 1023) os_disk_name: '' # [Optional], name of the os disk ) ``` ### Virtual Machine (Unmanaged OS Disk) ```ruby fog_compute_service.servers.create( name: '', location: '', resource_group: '', tags: { key1: 'value1', key2: 'value2', keyN: 'valueN' }, vm_size: '', storage_account_name: '', username: '', password: '', disable_password_authentication: , network_interface_card_ids: ['/subscriptions//resourceGroups//providers/Microsoft.Network/networkInterfaces/'], publisher: '', # Not required if custom image is being used offer: '', # Not required if custom image is being used sku: '', # Not required if custom image is being used version: '', # Not required if custom image is being used platform: '', availability_set_id: '', # [Optional] vhd_path: '', # [Optional], if you want to create the VM from a custom image. custom_data: '', # [Optional], if you want to add custom data in this VM. os_disk_size: , # [Optional], size of the os disk in GB (upto 1023) os_disk_name: '' # [Optional], name of the os disk ) ``` ## Create Server Asynchronously Create a new linux server asynchronously ```ruby async_response = fog_compute_service.servers.create_async( name: '', location: '', resource_group: '', tags: { key1: 'value1', key2: 'value2', keyN: 'valueN' }, vm_size: '', storage_account_name: '', username: '', disable_password_authentication: , network_interface_card_ids: ['/subscriptions//resourceGroups//providers/Microsoft.Network/networkInterfaces/'], publisher: '', # Not required if custom image is being used offer: '', # Not required if custom image is being used sku: '', # Not required if custom image is being used version: '' , # Not required if custom image is being used platform: '', availability_set_id: '', # [Optional] password: '', # [Optional], if 'platform' partameter is 'Linux'. vhd_path: '', # [Optional], if you want to create the VM from a custom image. custom_data: '', # [Optional], if you want to add custom data in this VM. os_disk_caching: '', # [Optional], can be one of None, ReadOnly, ReadWrite managed_disk_storage_type: '', # [Optional], can be StandardLRS or PremiumLRS os_disk_size: , # [Optional], size of the os disk in GB (upto 1023) os_disk_name: '' # [Optional], name of the os disk ) ``` Following methods are available to handle async respoonse: - state - pending? - rejected? - reason - fulfilled? - value An example of handling async response is given below: ```ruby while 1 puts async_response.state if async_response.pending? sleep(2) end if async_response.fulfilled? puts async_response.value.inspect break end if async_response.rejected? puts async_response.reason.inspect break end end ``` For more information about custom_data, see link: https://msdn.microsoft.com/en-us/library/azure/mt163591.aspx ## List Servers List servers in a resource group ```ruby servers = fog_compute_service.servers(resource_group: '') servers.each do |server| puts "#{server.name}" puts "#{server.location}" end ``` ## Retrieve a single Server Get a single record of Server ```ruby server = fog_compute_service .servers(resource_group: '') .get('', 'Server Name>') puts "#{server.name}" ``` ## Get a Server's status Check the status of a Server ```ruby status = fog_compute_service .servers .get('', '') .vm_status puts status ``` ## Start a Server ```ruby server.start ``` ## Power Off a Server ```ruby server.power_off ``` ## Restart a Server ```ruby server.restart ``` ## Deallocate a Server ```ruby server.deallocate ``` ## Redeploy a Server ```ruby server.redeploy ``` ## Destroy a single Server Get a server object from the get method (described above) and then destroy that server. ```ruby server.destroy ``` ## Attach a Data Disk to Server Get the server object and attach a Data Disk to it. The data disk attached is blob based. ```ruby server.attach_data_disk('', , '') ``` ## Detach a Data Disk from Server Get the server object and detach a Data Disk from it. ```ruby server.detach_data_disk('') ``` ## Create Managed Disk Create a new Premium Managed Disk ```ruby fog_compute_service.managed_disks.create( name: '', location: '', resource_group_name: '', account_type: '', disk_size_gb: , creation_data: { create_option: '' } ) ``` Create a new Standard Managed Disk ```ruby fog_compute_service.managed_disks.create( name: '', location: '', resource_group_name: '', account_type: '', disk_size_gb: , creation_data: { create_option: '' } ) ``` ## Attach a Managed Data Disk to Server Get the server object and attach a Data Disk to it. ```ruby server.attach_managed_disk('', '') ``` ## Detach a Managed Data Disk from Server Get the server object and detach a Data Disk from it. ```ruby server.detach_managed_disk('') ``` ## List Managed Disks in a Resource Group List managed disks in a resource group ```ruby managed_disks = fog_compute_service.managed_disks(resource_group: '') mnaged_disks.each do |disk| puts "#{disk.name}" puts "#{disk.location}" end ``` ## List Managed Disks in a Subscription List managed disks in a subscription ```ruby fog_compute_service.managed_disks.each do |disk| puts "#{disk.name}" puts "#{disk.location}" end ``` ## Grant Access to a Managed Disk Grant access to a managed disk ```ruby access_sas = fog_compute_service.managed_disks.grant_access('', '', '', ) puts "Access SAS: #{access_sas}" ``` ## Revoke Access from a Managed Disk Revoke access from a managed disk ```ruby response = fog_compute_service.managed_disks.revoke_access('', '') puts "Revoke Access response status: #{response.status}" ``` ## Check Managed Disk Existence ```ruby fog_compute_service.managed_disks.check_managed_disk_exists('', '') ``` ## Retrieve a single Managed Disk Get a single record of managed disks ```ruby managed_disk = fog_compute_service .managed_disks .get('', '') puts "#{managed_disk.name}" ``` ## Destroy a single Managed Disk Get an managed disk object from the get method and then destroy that managed disk. ```ruby managed_disk.destroy ``` ## Check Availability Set Existence ```ruby fog_compute_service.availability_sets.check_availability_set_exists('', '') ``` ## Create Availability Set Create a new availability set ```ruby fog_compute_service.availability_sets.create( name: '', location: '', resource_group: '' platform_fault_domain_count: , # [Optional] Default => 2 platform_update_domain_count: , # [Optional] Default => 5 use_managed_disk: true # [Optional] Possible values true or false ) ``` ## List Availability Sets List availability sets in a resource group ```ruby availability_sets = fog_compute_service.availability_sets(resource_group: '') availability_sets.each do |availability_set| puts "#{availability_set.name}" puts "#{availability_set.location}" end ``` ## Retrieve a single Availability Set Get a single record of Availability Set ```ruby availability_set = fog_compute_service .availability_sets .get('','') puts "#{availability_set.name}" ``` ## Destroy a single Availability Set Get an availability set object from the get method and then destroy that availability set. ```ruby availability_set.destroy ``` ## Check Virtual Machine Extension Existence ```ruby fog_compute_service.virtual_machine_extensions.check_vm_extension_exists('', '', '') ``` ## Create Virtual Machine Extension Installs an extension to the specified virtual machine. ```ruby fog_compute_service.virtual_machine_extensions.create( name: '', resource_group: '', location: '', vm_name: '', # Extension will be installed on this VM publisher: '', type: '', type_handler_version: '', settings: {JSON object}, # Format: {"key": "value", "key": {"key": "value"}} protected_settings: {JSON object}, auto_upgrade_minor_version: , # Optional ) ``` ## Get Extension from Virtual Machine Retrieves the given extension from the virtual machine ```ruby vm_extension = fog_compute_service.virtual_machine_extensions.get( '', '', '' ) ``` ## Update Extension Update the given extension. The attributes that can be modified are - auto_upgrade_minor_version - settings - protected_settings ```ruby vm_extension.update( auto_upgrade_minor_version: , settings: {JSON object}, protected_settings: {JSON object} ) ``` ## Destroy Extension Destroy the given extension from the virtual machine ```ruby vm_extension.destroy ``` ## Support and Feedback Your feedback is appreciated! If you have specific issues with the fog ARM, you should file an issue via Github.