Scott's Weblog The weblog of an IT pro specializing in virtualization, networking, open source, and cloud computing

Changing Passwords with cloud-init

Generally speaking, when launching instances in a cloud environment (such as AWS or an OpenStack-based cloud), the preferred/default way of accessing that instance is via SSH using an injected SSH key pair. There are times, though, when—for whatever reason—this approach won’t work. (I’ll describe one such situation below.) In such instances, it’s possible to configure cloud-init, the same tool used to inject SSH keys, to change passwords for user accounts. Here’s how.

Please note that this is a total hack. (Do NOT use this for any sort of production workload!) That being said, sometimes things like this are necessary to complete preliminary evaluations of a new technology, new product, or new architecture. In my case, I had a demo environment (using DevStack) that I needed to get up and running, and the instances would not have any external connectivity. This meant I was limited to console access only—hence, SSH keys are useless. The only means of access would be via password login through the console. So, I found this snippet of cloud-init code:

  list: |
  expire: False

For this particular use case, I needed to change the default user on the Ubuntu cloud images (which is the “ubuntu” user), so I modified the above code to change only the password for the “ubuntu” user, and placed the code in the “Post-Creation” section of the Launch Instance dialog box in OpenStack. When the instance was launched, cloud-init dutifully changed the password for the specified user, and I was able to log in to the instance’s console using username and password.

Be social and share this post!