RubyConf 2024: Cloud Native Buildpack Hackday (and other Ruby deploy tools, too!)
11 Nov 2024I’ve spent the last decade+ working on Ruby deploy tooling, including (but not limited to) the Heroku classic and upcoming Cloud Native Buildpack. If you want to contribute to a Ruby deployment or packaging tool (even if it’s not one I maintain), I can help. If you want to learn more about Cloud Native Buildpacks (CNBs) and maybe get a green square on GitHub (or TWO!), keep reading for more resources.
Note: This post is for an in-person hackday event at RubyConf 2024 happening on Thursday, November 14th. If you found this but are away from the event, you can still follow along, but I won’t be available for in-person collaboration.
What is a buildpack?
If you’re new to Cloud Native Buildpacks, it’s a way to generate OCI images (like docker) without a Dockerfile. Buildpacks take your application code on disk as input and inspect it to determine that it’s a Ruby app and needs to install gems with a bundler.
Install before you go
Know before you go! Not strictly required, but will make your life better with iffy-wifi
$ pack config default-builder heroku/builder:24
- Run these commands to pre-fetch docker images:
$ docker pull "heroku/heroku:24"
$ docker pull "heroku/builder:24"
- Optional: If you’re going to want to modify the buildpack, you’ll need rust installed:
$ curl --proto '=https' --tlsv1.2 https://sh.rustup.rs -sSf | sh
And clone the repo and install dependencies:
$ git clone https://github.com/heroku/buildpacks-ruby
$ cd buildpacks-ruby
$ cargo build
$ cargo test
Getting started
If you’ve never heard of a buildpack, here are some getting-started guides you can try if you find a bug or run into questions. I can help.
- What is a CNB?
- Follow buildpacks.io tutorial https://buildpacks.io/docs/
- Using a CNB -
- RECOMMENDED:
heroku/Ruby
tutorial https://github.com/heroku/buildpacks/blob/main/docs/ruby/README.md - Tutorials for using CNBs with other languages (.NET, Go, Java (Gradle), Java (Maven), Node.JS, PHP, Python, Scala) are available here.
- Paketo Ruby tutorial https://paketo.io/docs/howto/ruby/
- RECOMMENDED:
Hacking ideas
Once you’ve played with a buildpack, you’re ready for prime-time. Below, you’ll find some sample things to hack on. You can tackle one by yourself, if you’re ready, or
heroku/ruby-buildpack issues
- Anything on https://github.com/heroku/buildpacks-ruby/issues. Look for the “help wanted” tag.
Deny unknown fields
A well-scoped-out task with a change example involves modifying code but requires minimal rust knowledge.
- Link: https://github.com/heroku/buildpacks-ruby/issues/272
- Effort: Low
- Impact: Medium
- Requires: Code editor, installing rust
Test drive Hanami with a Ruby CNB
Test drive Hanami with a Ruby CNB, document the experience and suggest changes or fixes.
- Effort: low
- Impact: low
- Requires: Ruby
Update error messages
https://github.com/heroku/buildpacks-ruby/issues/333
- Effort low
- Impact: low
- Requires: Code editor, installing rust
Warn when no bin/rails
file found
https://github.com/heroku/buildpacks-ruby/issues/298
- Effort: Medium
- Impact: Medium
- Requires: Writing Rust
Build a CNB with Rust, bash, or Ruby
No link. Write a Cloud Native Buildpack. Bash tutorial at https://buildpacks.io/docs/. For ideas of possible buildpack ideas, you can look at “classic” buildpacks existing Heroku “classic” buildpacks
- Effort: Medium
- Impact: Unknown
Add .ruby-version
support
- Link: https://github.com/heroku/buildpacks-ruby/issues/346
- Effort High
- Impact: High
- Requires: Rust proficiency