- Upgrading the Firmware on a Tulip
- Learning Code Through the Advent of Code Challenge
- Common Loki Misconfigurations
- Iterating Through a List in Ink
- Debugging Misconfigured Container Networks
- Minimum Viable EC2 in Terraform
- Storylets in Ink
- Interactive Fiction Tooling Overview
- In-Place Resizing for Digitalocean Droplets
- Unity Demonstrates the Importance of FOSS
- Target Labels in Prometheus
- My View of AI is the Same
- Verify DNS Ownership with TXT Records
- Sane Droplet Defaults
- Editing Made Easy with Vim
- Gatsby Gotchas
- Concatinating Default AWS Tags in Terraform
- Easily Updating the Default Github Branch
- Lifetimes in Rust
- Checking for Bad Links
- Maybe TypeScript and React is Bad
- Static Asset Management in React
- Bundler Down Time
- Using React Context for Localization
- JS Implementation of a Sticky Footer
- Custom Aliases
- Trying Out the 7drl Challenge
- Trash Opinions
- Building Your First Program in Rust
- Fixing mongod reports errors related to opening a socket
- Improving Open Source Maintenance
- Technical Interviewing Tips
- Housekeeping Note
- Dynamic Programming Basics
- The Oddity of Naming Conventions in Programming Languages
- An Experiment Using Machine Learning, Part 3
- Debugging with grep
- An Experiment Using Machine Learning, Part 2
- An Experiment Using Machine Learning, Part 1
- The Value of while
- National Day of Civic Hacking
- OpenAI and the Future of Humanity
- Creating a Whiteboard App in Django
- Creating Meaningful, Organized Information
- Towards A Critique of Social Media Feeds
- Setting up Routes in Django
- Developing a Messaging Component for Code for SF
- Dream Stream 2.0
- Keyed Collections in Javascript: Maps and Sets
- Blog Soft Relaunch
- Scraping with Puppeteer
- Looking Ahead to Dream Stream 2.0
- Solving West of Loathing's Soupstock Lode Puzzle
- Installing Ubuntu
- Interview with David Jickling Evaluation
- Compare Text Evaluation
- Dream Stream Evaluation
In-Place Resizing for Digitalocean Droplets
Terraform is great for maintaining inventory, but I haven’t always had the best luck with using Terraform to maintain existing state of a VM while upgrading to a more powerful instance. In cases like this, it can be more prudent to work with a cloud provider’s CLI tools to perform an in-place resizing, and then update the Terraform config, and run terraform plan
to confirm that the Terraform config matches existing state. For this example, I’ll be using Digitalocean as an example, although the process should be similar regardless of cloud provider.
To use Digitalocean’s CLI tools you’ll need to download doctl
, which you can find instructions for here.
Once you have doctl
installed, and have an API key with the authorization to perform the operations, the first thing you’ll want is an inventory of all the droplets you need to upgrade.
doctl compute droplet list --format ID,Name --no-header > inventory
This is going to create a list of every droplet in the account you are working with. It’s possible to limit this with the --region
flag, but otherwise I don’t know anyway to filter it, so unless you are planning to resize every single droplet, you need to go through the inventory and delete lines for droplets you aren’t planning to resize.
Now that you have the inventory you’re working with we’ll want to do the following:
- Power off the droplets
- Create a snapshot image (in case something goes wrong)
- Perform the resize operation
- power on the droplets
In a bash script you can create arrays with your droplet_ids
and droplet_names
fields from your inventory.
Then you have two approaches to these operations. You can either perform them all the operations in a loop sequentially by adding the --wait
flag to each doctl
operation. This makes a certain amount of sense because these operations do need to happen in a specific order. You want to power off your droplet before creating a snapshot, and you must do that before the resize operation. And you want the snapshot created before you resize in case something goes wrong. And only after all of that is done do you turn the droplet back on. This is probably a good approach if you’re just resizing a handful of droplets, but if you are upgrading a whole suite you’ll be waiting a really long time for your script to run because, with the exception of powering the droplets back on, all of these operations are time intensive. So it may make more sense to simply comment out the subsequent operations in the loop, and update them once you’ve confirmed that the previous operations have completed.
for i in $(seq 0 n) ; do
doctl compute droplet-action power-off "${droplet_ids[i]}"
# doctl compute droplet-action snapshot "${droplet_ids[i]}" --snapshot-name "${droplet_names[i]}-$(date +%Y%m%d%H%M%S)"
# doctl compute droplet-action resize "${droplet_ids[i]}" --size "$slug"
# doctl compute droplet-action power-on "${droplet_ids[i]}"
done
In this example you would replace n
with the number of droplets in your inventory - 1.
As you can see the first operation is to power everything off. The next time we run the script we comment off the power-off operation, and uncomment the snapshot option. The snapshot operation has a required flag of --snapshot-name
where we provide the name of the droplet and a basic timestamp.
Snapshots are one of the more time consuming operations here. Expect those to take at least ten minutes to complete, possibly much more depending on the disk size involved.
Next comment out the snapshot operation, and uncomment the resize. Note here we are using a variable for the slug value. You can retrieve a list of valid slug values with the doctl compute size list
command. Also note that by default in digitalocean resize operations do not increase disk by default. If you did want to resize the disk to the new slug’s value you can add the --resize-disk
flag, but make sure that’s something you actually want to do because that will make the resize operation non-reversible.
Finally, once the resize operations are complete, comment out the line, and uncomment the power-on line. After you run that you should have all your droplets working with their existing state, but with more powerful hardware. You can now check to confirm that your droplets are working as intended. If not you have the snapshots which you can reload from.