From 1de4345c4db92779d012dcd3676d2df410027ca3 Mon Sep 17 00:00:00 2001 From: Schneems Date: Sat, 23 Nov 2024 15:36:01 -0600 Subject: [PATCH 1/4] Change default process type host to IPv6 `::` IPv6 is the future. Here's some more context heroku/roadmap#40. Related https://github.com/heroku/ruby-getting-started/pull/165 --- buildpacks/ruby/CHANGELOG.md | 6 ++++++ buildpacks/ruby/src/steps/get_default_process.rs | 3 ++- docs/application_contract.md | 4 ++-- 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/buildpacks/ruby/CHANGELOG.md b/buildpacks/ruby/CHANGELOG.md index e7e2aebf..cfcf7747 100644 --- a/buildpacks/ruby/CHANGELOG.md +++ b/buildpacks/ruby/CHANGELOG.md @@ -7,6 +7,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +### Changed + +- Default process types defined by the Ruby buildpack now use IPv6 host `::` which is equivalent of IPv4 host `0.0.0.0`. This will only affect applications that do not define a `web` process type via the `Procfile` and [Procfile Cloud Native Buildpack](https://github.com/heroku/buildpacks-procfile). Those applications must make sure to update their configuration to bind to an IPv6 host. ([]()) + +### Added + - The buildpack now warns the user when environmental variables used in running the default process are not defined. ([#307](https://github.com/heroku/buildpacks-ruby/pull/307)) ## [3.0.0] - 2024-05-17 diff --git a/buildpacks/ruby/src/steps/get_default_process.rs b/buildpacks/ruby/src/steps/get_default_process.rs index 503ac958..08208c75 100644 --- a/buildpacks/ruby/src/steps/get_default_process.rs +++ b/buildpacks/ruby/src/steps/get_default_process.rs @@ -72,7 +72,7 @@ fn default_rack() -> Process { &[ "bundle exec rackup", "--port \"${PORT:?Error: PORT env var is not set!}\"", - "--host \"0.0.0.0\"", + "--host \"::\"", ] .join(" "), ]) @@ -88,6 +88,7 @@ fn default_rails() -> Process { "bin/rails server", "--port \"${PORT:?Error: PORT env var is not set!}\"", "--environment \"$RAILS_ENV\"", + "--binding \"::\"", ] .join(" "), ]) diff --git a/docs/application_contract.md b/docs/application_contract.md index df365d19..effac1da 100644 --- a/docs/application_contract.md +++ b/docs/application_contract.md @@ -61,9 +61,9 @@ Once an application has passed the detect phase, the build phase will execute to - We will delete the least recently used (LRU) files first. Detected via file mtime. - Process types: - Given an application with the `railties` gem: - - We will default the web process to `bin/rails server` while specifying `-p $PORT` and `-e $RAILS_ENV"`. Use the `Procfile` to override this default. + - We will default the web process to `bin/rails server` while specifying `--port $PORT`, `--environment $RAILS_ENV"` and an IPv6 host with `--binding "::"` (equivalent of IPv4 host `0.0.0.0`). Use the `Procfile` to override this default. - If `railties` gem is not found but `rack` gem is present and a `config.ru` file exists on root: - - We will default the web process to `rackup` while specifying `-p $PORT` and `-h 0.0.0.0`. Use the `Procfile` to override this default. . + - We will default the web process to `rackup` while specifying `--port $PORT` and IPv6 host with `--host "::"` (equivalent of IPv4 host `0.0.0.0`). Use the `Procfile` to override this default. . - Environment variable defaults - We will set a default for the following environment variables: - `JRUBY_OPTS="-Xcompile.invokedynamic=false"` - Invoke dynamic is a feature of the JVM intended to enhance support for dynamicaly typed languages (such as Ruby). This caused issues with Physion Passenger 4.0.16 and was disabled [details](https://github.com/heroku/heroku-buildpack-ruby/issues/145). You can override this value. - `RACK_ENV=${RACK_ENV:-"production"}` - An environment variable that may affect the behavior of Rack based webservers and webapps. You can override this value. From b07410017adfff5f0b1b82ddecfae8683aba43da Mon Sep 17 00:00:00 2001 From: Schneems Date: Mon, 25 Nov 2024 13:43:39 -0600 Subject: [PATCH 2/4] Update gems --- buildpacks/ruby/src/steps/get_default_process.rs | 4 ++-- buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/buildpacks/ruby/src/steps/get_default_process.rs b/buildpacks/ruby/src/steps/get_default_process.rs index 08208c75..90e70dae 100644 --- a/buildpacks/ruby/src/steps/get_default_process.rs +++ b/buildpacks/ruby/src/steps/get_default_process.rs @@ -71,8 +71,8 @@ fn default_rack() -> Process { "-c", &[ "bundle exec rackup", + "--host \"[::]\"", "--port \"${PORT:?Error: PORT env var is not set!}\"", - "--host \"::\"", ] .join(" "), ]) @@ -86,9 +86,9 @@ fn default_rails() -> Process { "-c", &[ "bin/rails server", + "--binding \"[::]\"", "--port \"${PORT:?Error: PORT env var is not set!}\"", "--environment \"$RAILS_ENV\"", - "--binding \"::\"", ] .join(" "), ]) diff --git a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock index 7219363d..7892126b 100644 --- a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock +++ b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock @@ -1,9 +1,9 @@ GEM remote: https://rubygems.org/ specs: - rack (2.2.3) - rake (13.0.6) - webrick (1.7.0) + rack (3.1.8) + rake (13.2.1) + webrick (1.9.0) PLATFORMS ruby From d539d9db712c1b1ce351ce47db6899f83ffc4060 Mon Sep 17 00:00:00 2001 From: Schneems Date: Mon, 25 Nov 2024 16:52:24 -0600 Subject: [PATCH 3/4] Use puma to support IPv6 and IPv4 in local tests --- buildpacks/ruby/tests/fixtures/default_ruby/Gemfile | 3 ++- .../ruby/tests/fixtures/default_ruby/Gemfile.lock | 12 ++++++++++-- buildpacks/ruby/tests/integration_test.rs | 11 ++++++----- 3 files changed, 18 insertions(+), 8 deletions(-) diff --git a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile index 237066dd..7fb164a0 100644 --- a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile +++ b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile @@ -2,4 +2,5 @@ source "https://rubygems.org" gem 'rack' gem 'rake' -gem 'webrick' +gem 'puma' +gem 'rackup' diff --git a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock index 7892126b..e12918dc 100644 --- a/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock +++ b/buildpacks/ruby/tests/fixtures/default_ruby/Gemfile.lock @@ -1,14 +1,22 @@ GEM remote: https://rubygems.org/ specs: + nio4r (2.7.4) + puma (6.5.0) + nio4r (~> 2.0) rack (3.1.8) + rackup (2.2.1) + rack (>= 3) rake (13.2.1) - webrick (1.9.0) PLATFORMS ruby DEPENDENCIES + puma rack + rackup rake - webrick + +BUNDLED WITH + 2.5.23 diff --git a/buildpacks/ruby/tests/integration_test.rs b/buildpacks/ruby/tests/integration_test.rs index f9bf6c7c..ece3ea13 100644 --- a/buildpacks/ruby/tests/integration_test.rs +++ b/buildpacks/ruby/tests/integration_test.rs @@ -55,7 +55,7 @@ fn test_default_app_ubuntu20() { context.pack_stdout, r#"`BUNDLE_BIN="/layers/heroku_ruby/gems/bin" BUNDLE_CLEAN="1" BUNDLE_DEPLOYMENT="1" BUNDLE_GEMFILE="/workspace/Gemfile" BUNDLE_PATH="/layers/heroku_ruby/gems" BUNDLE_WITHOUT="development:test" bundle install`"#); - assert_contains!(context.pack_stdout, "Installing webrick"); + assert_contains!(context.pack_stdout, "Installing puma"); }, ); } @@ -72,7 +72,7 @@ fn test_default_app_ubuntu22() { context.pack_stdout, r#"`BUNDLE_BIN="/layers/heroku_ruby/gems/bin" BUNDLE_CLEAN="1" BUNDLE_DEPLOYMENT="1" BUNDLE_GEMFILE="/workspace/Gemfile" BUNDLE_PATH="/layers/heroku_ruby/gems" BUNDLE_WITHOUT="development:test" bundle install`"#); - assert_contains!(context.pack_stdout, "Installing webrick"); + assert_contains!(context.pack_stdout, "Installing puma"); }, ); } @@ -91,7 +91,7 @@ fn test_default_app_latest_distro() { context.pack_stdout, r#"`BUNDLE_BIN="/layers/heroku_ruby/gems/bin" BUNDLE_CLEAN="1" BUNDLE_DEPLOYMENT="1" BUNDLE_GEMFILE="/workspace/Gemfile" BUNDLE_PATH="/layers/heroku_ruby/gems" BUNDLE_WITHOUT="development:test" bundle install`"#); - assert_contains!(context.pack_stdout, "Installing webrick"); + assert_contains!(context.pack_stdout, "Installing puma"); let config = context.config.clone(); context.rebuild(config, |rebuild_context| { @@ -107,8 +107,9 @@ fn test_default_app_latest_distro() { let body = response.into_string().unwrap(); let server_logs = container.logs_now(); - assert_contains!(server_logs.stderr, "WEBrick::HTTPServer#start"); - assert_empty!(server_logs.stdout); + + assert_contains!(server_logs.stdout, "Puma starting"); + assert_empty!(server_logs.stderr); assert_contains!(body, "ruby_version"); }, From 09a67ccb3816b3a6c7bbd80d51c47b7db52c30d9 Mon Sep 17 00:00:00 2001 From: Schneems Date: Mon, 25 Nov 2024 17:10:00 -0600 Subject: [PATCH 4/4] Changelog --- buildpacks/ruby/CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/buildpacks/ruby/CHANGELOG.md b/buildpacks/ruby/CHANGELOG.md index cfcf7747..ea799222 100644 --- a/buildpacks/ruby/CHANGELOG.md +++ b/buildpacks/ruby/CHANGELOG.md @@ -9,7 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Changed -- Default process types defined by the Ruby buildpack now use IPv6 host `::` which is equivalent of IPv4 host `0.0.0.0`. This will only affect applications that do not define a `web` process type via the `Procfile` and [Procfile Cloud Native Buildpack](https://github.com/heroku/buildpacks-procfile). Those applications must make sure to update their configuration to bind to an IPv6 host. ([]()) +- Default process types defined by the Ruby buildpack now use IPv6 host `::` which is equivalent of IPv4 host `0.0.0.0`. This will only affect applications that do not define a `web` process type via the `Procfile` and [Procfile Cloud Native Buildpack](https://github.com/heroku/buildpacks-procfile). Those applications must make sure to update their configuration to bind to an IPv6 host. ([#354](https://github.com/heroku/buildpacks-ruby/pull/354)) ### Added