Version information
Start using this module
Add this module to your Puppetfile:
mod 'msopentech-microsoftazure', '1.2.3'
Learn more about managing modules with a PuppetfileDocumentation
Microsoft Azure Cloud Provisioner
Puppet Module to launch and manage Microsoft Microsoft Azure Services like Virtual Machines, Virtual Network and SQL Database services.
This module requires Puppet 2.7.2 or later.
Library Features
-
Virtual Machine Management
- Images
- list images
- Virtual Machines
- create linux based VMs and ssh with cert and key option enabled for ssh and WINRM (both http & https)enabled for windows based VMs
- Virtual Machines
- list, shut down, delete, find virtual machine deployments. While shutting down your VMs the provisioning state would be deallocated and this VM will not be included in the billing cycle.
* Create VM for a specific virtual network
-
Virtual Network Management
- List VNet
- Create VNet
- via parameters
- via xml file
-
SQL Database Server Management
- list, create, list sqldb servers & password reset for a sqldb server
- list, set, delete firewall rules for a sqldb server
-
Storage Account Management
- create, delete, update and list storage accounts.
-
Cloud Service Management
- create, delete, upload_certificate and list cloud services
-
Service Bus Management
- create_queue, create_topic, list_topics, list_queues, delete_topic and delete_queue
Getting Started
Required Gems
- azure (0.6.4)
- net-ssh (>= 2.1.4)
- net-scp (>= 1.0.4)
- winrm (>= 1.1.3)
- highline
Manage Virtual machine
You may launch a new instance and install puppet agent with this module installed using the following single command:
$puppet azure_vm create --management-certificate pem-or-pfx-file-path --azure-subscription-id=your-subscription-id \
--image b39f27a8b8c64d52b05eac6a62ebad85__Ubuntu-13_04-amd64-server-20130501-en-us-30GB --location 'west us'
--vm-name vmname --vm-user username --password ComplexPassword --puppet-master-ip 198.62.195.5
Once launched, you should be able to SSH to the new system using the username and password.
Other avaliable actions are
bootstrap Install puppet node on Microsoft Azure VM
create Create Microsoft Azure VM
delete Delete Microsoft Azure node instances
images List Microsoft Azure images
locations List Microsoft Azure locations
servers List Microsoft Azure node instances
shutdown Shutdown Microsoft Azure node instances
start Starts Microsoft Azure node instances
update_endpoint update existing endpoint of a virtual machine
delete_endpoint Delete endpoint of virtual machine.
add_disk Adds a data disk to a virtual machine.
add_role Create multiple roles under the same cloud service
To list all options for any action
$puppet help azure_vm ACTION-NAME
Manage Virtual Network
Creating virtual network
$puppet azure_vnet set --management-certificate pem-or-pfx-file-path --azure-subscription-id=your-subscription-id
--virtual-network-name vnetname --affinity-group-name ag-name --address-space '172.16.0.0/12,192.168.0.0/16'
--dns-servers 'dns-1:10.10.8.8,dns-2:172.8.4.4' --subnets 'subnet-1:172.16.0.0:12,subnet-2:192.168.0.0:29'
Other avaliable actions are
list List virtual networks.
set Set Network configures the virtual network
set_xml_schema set_xml_schema Network configures the virtual network using xml schema
Manage SQL database server
Creating SQL database server
$puppet azure_sqldb create --management-certificate pem-or-pfx-file-path --azure-subscription-id=your-subscription-id \
--management-endpoint=https://management.database.windows.net:8443/ --login loginname --password ComplexPassword --location 'West Us'
Other avaliable actions are
create Create SQL database server.
create_firewall Create SQL database firewall rule on a server.
delete Delete Microsoft Azure sql database server
delete_firewall Delete Microsoft Azure sql database firewall rule on a server.
list List SQL database servers.
list_firewall List firewall of SQL database servers.
reset_password Reset password of sql database server.
Manage Cloud service
Creating cloud service
$ puppet azure_cloudservice create --label aglabel --azure-subscription-id your-subscription-id
--location 'West Us' --affinity-group-name agname --description 'Some Description' \
--management-certificate path-to-azure-certificate --cloud-service-name cloudservice1
Other avaliable actions are
delete Delete cloud service.
delete_deployment deletes the specified deployment of hosted service.
list List cloud services.
upload_certificate adds a certificate to a hosted service.
create Create cloud service.
Manage Storage account
Creating storage account
$ puppet azure_storage create --azure-subscription-id=your-subscription-id
--management-certificate path-to-azure-certificate --storage-account-name storageaccount
--location 'west us' --extended-properties 'key-1:value-1,key-2:value-2'
Other avaliable actions are
create Create storage service.
delete Delete storage account.
list List storage accounts.
update Update storage service.
Manage Service Bus
Creating queue using service bus
$ puppet azure_servicebus create_queue --sb-namespace busname
--queue-name queuename --sb-access-key dnD/E49P4SJG8UVEpABOeZRc=
Other avaliable actions are
create_queue Creates queue with service bus object.
create_topic Create topic with service bus object.
delete_queue Delete a queue using service bus object.
delete_topic Delete a topic using service bus object.
list_queues List queues.
list_topics List topics.
Certificate Management
-
Currently the sdk supports .pem or .pfx (passwordless pfx) for service management operations. Following are the steps discussed on various cert operations.
-
To create pfx, simply download the publishsettings file for your subscription, copy the contents of Management Certificate from the publishsettings and save it in a file and name the file as your cert.pfx. This pfx will be a passwordless pfx which can be supplied as a cert parameter for Service Management Commands
-
Using the following openssl commands to extract the pem file and pass the pem file as management cert parameter.
-
To get only private key from pfx use Openssl.exe pkcs12 -in cert.pfx -nocerts -out cert.pem
-
To remove passphrase from the above private key use Openssl.exe rsa -in cert.pem -out certprivnopassword.pem
-
To extract both public & private keys from pfx use Openssl.exe pkcs12 -in cert.pfx -out certprivpub.pem
-
To extract only public key from pem use Openssl x509 -inform pem -in certprivpub.pem -pubkey -out certpub.pem -outform pem
-
Finally copy the public key & private key to a file *.pem and pass that pem file to management cert parameter.
-
-
To extract pem from custom certificate, export the pfx, follow the above steps to convert to pem and pass that pem file to management cert parameter.
-
Reporting Issues
Please report any problems you have with the Microsoft Azure Cloud Provisioner module in issue tracker at
Puppet Installation
http://docs.puppetlabs.com/guides/installation.html#installing-puppet-1
Fri June 6 2014 MSOpenTech 1.2.3
- Implemented azure_servicebus action. Fri May 30 2014 MSOpenTech 1.2.2
- Text changes from 'Windows Azure' to 'Microsoft Azure' Fri May 16 2014 MSOpenTech 1.2.1
- Text changes from windowsazure to microsoftazure
- Added License text Fri May 2 2014 MSOpenTech 1.2.0
- Implemented azure_cloudservice action to manage cloud services
- Implemented azure_storage action to manage storage accounts.
- Implemented add_disk action for virtual machine.
- Implemented add_role action for virtual machine. Fri Dec 20 2013 MSOpenTech 1.1.1
- updated example for puppet command
- Updated reporting issues url in readme
- updated readme for SQL database server
- Implement bootstrapping of nodes without subscription_id and management_certificate Wed Dec 11 2013 MSOpenTech 1.1.0
- added manifests
- updated readme