(Almost) Free Google Drive backup (part 1)
I started with the boring question: what happens if Google Drive data disappears?

I searched for a reliable, out-of-the-box solution. Google’s suggestions didn’t land, so I built my own. Lego backup: assemble the necessary components.
# Backup building blocks
- Access to Google Cloud Console
- rclone.org: A powerful tool that provides rsync-like CLI functionality for managing filesystems and cloud storage. It’s well-documented; I focus on the short path
# Google Cloud Console: create the service account
I started with the most crucial step: credentials to interact with the Google API. (Remember to enable the Google Drive API if needed) This involves creating a Service Account and generating a JSON private key.
Here’s an example of what it looks like:
{
"type": "service_account",
"project_id": "<project name>",
"private_key_id": "<hash>",
"private_key": "-----BEGIN PRIVATE KEY-----\n<some base64 encoded stuff>\n-----END PRIVATE KEY-----\n",
"client_email": "<service account name>@<project name>.iam.gserviceaccount.com",
"client_id": "<another one id>",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/<service account name>%40<project name>.iam.gserviceaccount.com",
"universe_domain": "googleapis.com"
}
# rclone: copy Drive to local storage
Almost there. The next step is to set up rclone for automated execution using Cron on a host. I’ll skip the details of acquiring a hosting environment.
Here’s prepared rclone.conf:
[google-drive]
type = drive
service_account_file = /config/rclone/sa.json # <- The key
And here’s how to use it with Docker:
docker run --rm -it \
-v ./config:/config/rclone \
-v ./data:/data \
rclone/rclone --drive-shared-with-me \
copy google-drive:<SHARED FOLDER> /data/$(date +"%Y-%m-%d")
# rclone: restore the backup
To restore the backup, reverse the source and destination paths in the
rclone copy command:
docker run --rm -it \
-v ./config:/config/rclone \
-v ./data:/data \
rclone/rclone --drive-shared-with-me \
copy /data/$(date +"%Y-%m-%d") google-drive:<SHARED FOLDER>
If I recover data, the original permissions will be lost, and the Service Account will become the owner of all recovered data.
# Service-account ownership trap
A Service Account is an account with its own folder and permissions within
Google Drive. I have to share the desired folders with it. The <SHARED FOLDER>
in the bash command refers to the exact name of the shared folder.
# Next: encryption and offsite storage
This provides a solid foundation for Google Drive backup. Next step: add encryption and robust, cost-effective storage.
Stay tuned, I’m gonna talk about that next.