The Node.js Extension for UBI allows builders to be created which build Node.js applications on top of Red Hat's Node.js ubi containers. For example ubi8/nodejs-20-minimal.
The ubi Node.js extension provides node and npm as dependencies. Downstream buildpacks, like Yarn Install CNB or NPM CNB, can require the node dependency by generating a Build Plan TOML file that requires node and or npm.
The extension integrates with the existing Paketo buildpacks so that building your application will have the same experience as building with non ubi stacks. The main difference is that node.js and npm will be provided by the extension instead of the node-engine build pack.
- Enable experimental features of
pack cli
by runningpack config experimental true
. This is needed because extensions are currently experimental.
Build your app where test-app
will be the name of the image built and app-dir
is the directory that contains your Node.js application.
pack build test-app-name --path ./app-dir --builder paketocommunity/builder-ubi-base
Run your application with docker run -p 8080:8080 test-app
replacing 8080:8080
with the port on which your application listens.
Access your running application and enjoy :)
Feel free to add more buildpacks; Although the majority of the buildpacks for nodejs are already included from the nodejs buildpack.
The build-ubi-base builder has a list of buildpacks and an extension participating during build. You can also use the buildpackless ubi builder which has no buildpacks or the extension participating during build and include only the ones you want as demonstrated on below example for a Node.js app.
pack build test-app \
--path ./app-dir \
--extension docker.io/paketobuildpacks/ubi-nodejs-extension \
--buildpack paketo-buildpacks/nodejs \
--builder paketocommunity/builder-ubi-buildpackless-base
UBI only supports the latest minor version of each Node.js stream currently available in the UBI version.
At the time of writing, ubi8 supports the Node.js 16, 18, and 20 streams. For example, if the latest Node.js version for the 16 stream in ubi8 is 16.10.1 then that is your only option when requesting the Node.js 16.x stream. Therefore we suggest that you request the Node.js version such that it will accept any version of the stream you want to use with something like ~16
.
The extension prioritizes the versions specified in each possible configuration location with the following precedence, from highest to lowest:
- Set the
$BP_NODE_VERSION
environment variable at build time
pack build test-app-name \
--path ./app-dir \
--builder paketocommunity/builder-ubi-base \
--env BP_NODE_VERSION="~20"
- Set the
$BP_NODE_VERSION
through aproject.toml
file.
[ _ ]
schema-version = "0.2"
[[io.buildpacks.build.env]]
name = 'BP_NODE_VERSION'
value = '~20'
-
Set the node version in
package.json
:"engines": { "node": "~16" },
-
Set the node version via an
.nvmrc
file located at the application root directory -
Set the node version via an
.node-version
file located at the application root directory
To specify a project subdirectory to be used as the root of the app, please use the BP_NODE_PROJECT_PATH
environment variable at build time either directly (ex. pack build my-app --env BP_NODE_PROJECT_PATH=./src/my-app
) or through a project.toml file. This could be useful if your app is a part of a monorepo.
With BP_UBI_RUN_IMAGE_OVERRIDE
environment variable, you are able to specify the run image of the built application, without changing the source code of the extension (specifically the extension.toml file) as shown on below example.
pack build test-app-name \
--path ./app-dir \
--builder paketocommunity/builder-ubi-base \
--env BP_UBI_RUN_IMAGE_OVERRIDE="localhost:5000/my-run-image"
To run all unit tests, run:
./scripts/unit.sh
To run all integration tests, run:
./scripts/integration.sh
To generate buildpackage.cnb
and buildpack.tgz
files
./scripts/package.sh --version 0.0.1