GitPedia

Terraform raspberrypi bootstrap

Terraform Provisioner for bootstrapping a Raspberry Pi (Stretch) base configuration.

From clayshek·Updated November 10, 2025·View on GitHub·

NOTE: Though still functional, I've replaced this functionality with Ansible and a better provisioning model IMO: https://github.com/clayshek/raspi-ubuntu-ansible The project is written primarily in HCL, distributed under the MIT License license, first published in 2018. Key topics include: raspberry-pi, raspberry-pi-3, raspberrypi, raspbian, raspi.

terraform-raspberrypi-bootstrap

NOTE: Though still functional, I've replaced this functionality with Ansible and a better provisioning model IMO: https://github.com/clayshek/raspi-ubuntu-ansible

Summary

<a href="https://www.terraform.io/">Terraform</a> Provisioner for bootstrapping a <a href="https://www.raspberrypi.org">Raspberry Pi</a> base configuration. This is meant to be a run-once bootstrap Terraform <a href="https://www.terraform.io/docs/provisioners/index.html">provisioner</a> for a vanilla Raspberry Pi. Provisioners by default run only at resource creation, additional runs without cleanup may introduce problems.

In addtion to bootstrapping, this provisioner also:

  • Installs Prometheus Node Exporter for Prometheus metrics collection
  • Copies the k8s_prep.sh script from this repository to /home/pi/ to optionally install & configure prerequisites for latest ARM release of Kubernetes, including Docker, based off of https://gist.github.com/alexellis/fdbc90de7691a1b9edb545c17da2d975.
  • Copies the helm/install-helm-tiller.sh script from this repo which downloads Helm client, configures Kubernetes RBAC prerequisites, and initiates Helm with an ARM compatible <a href="https://cloud.docker.com/repository/docker/clayshek/tiller-arm">Tiller Docker image</a>.

Requirements

  • <a href="https://www.terraform.io/downloads.html">Terraform</a> (written with v0.11.3, tested working up to 0.11.11)
  • A newly flashed Raspberry Pi (tested with Raspbian Stretch Lite through 2018-11-13 release, should work with prior version Jessie)
  • SSH access to Pi, See <a href="https://www.raspberrypi.org/documentation/remote-access/ssh/">Enable SSH on a headless Raspberry Pi</a>

Usage

  • Clone the repository
  • Customize the parameters in the terraform.tfvars file as applicable for provisioning.
  • Run <code>terraform init</code> (required for first run).
  • Apply the configuration:
terraform apply
  • Optional, run <code>./k8s_prep.sh</code> to install Kubernetes and prerequisites, including Docker.

  • Optional, once Kubernetes cluster online and functional, run <code>./helm/install-helm-tiller.sh</code> to install <a href="https://docs.helm.sh/">Helm/Tiller</a>.

To-Do

  • Add Prometheus Node Exporter install.
  • Add Helm & Tiller init scripts
  • Possibly add functionality for multiple Raspberry Pi deployments from a single run, using <a href="https://www.terraform.io/docs/configuration/resources.html#using-variables-with-count">variables with count</a>.
  • Implement tests.

License

This is open-sourced software licensed under the MIT license.

Contributors

Showing top 1 contributor by commit count.

View all contributors on GitHub →

This article is auto-generated from clayshek/terraform-raspberrypi-bootstrap via the GitHub API.Last fetched: 6/19/2026