Skip to content

Building binaries on FreeBSD

Marcin Cieślak edited this page Apr 22, 2015 · 27 revisions

FreeBSD binaries are built using Poudriere, a FreeBSD-specific tool to build binary packages using a clean-room environment. Poudriere:

  • Creates and manages lightweight virtual environments (jails) for i386 and amd64
  • Keeps virtual environments up to date
  • Manages the building process, logging and packaging. It can expose results via the HTTP interface.

Another tools being used is portshaker which helps to merge different FreeBSD port trees and keep them up to date. A FreeBSD port tree describes how applications should be built into binary packages and installed. This is the standard way of building third-party software on FreeBSD.

#Custom ports tree

Since node-sass and many npm packages are not yet part of the official FreeBSD ports tree, we maintain a custom ports tree which contains the necessary elements. That's why we need portshaker to combine the official tree (containing python, compilers, node) and the custom tree.

We currently have the following custom ports:

Port name Description
misc/node-gyp-headers Development headers for various node and iojs versions
www/iojs42 Old version of io.js 1.0.4 to build binaries for NODE_MODULE_VERSION == 42
www/npm npm port modified to support io.js 1.0.4 as well as to workaround segfault in i386 environment
textproc/libsass updated libsass FreeBSD port
textproc/sassc sassc to match the updated libsass
textproc/node-sass Instructions how to build node-sass (depends on the libsass port)

Challenges to using FreeBSD ports infrastructure

FreeBSD port building is split into certain well-defined phases, like fetch, depend, extract, building and stage and install. Every phase has its own restrictions - for example during extract/build and later we are not supposed to have network access. Ports working directories can be written during extraction phase and later. This is a much more strict model than that one used by the npm, where fetching of dependencies is mixed with the construction of the package. To work this around we try to fetch all dependencies in advance into a download directory that serves also as the npm package cache. NPM_CONFIG_CACHE is set to this directory (usually /usr/ports/distfiles/npm) to achieve this.

Also node development files (headers etc.) that are required by node-gyp are provided beforehand (by installing the misc/node-gyp-headers port and setting HOME enviroment variable is set to /usr/local//share/node-gyp which contains a .node-gyp subdirectory needed to feed node-gyp.

Since poudriere enforces the above restrictions (network access, etc.) during build the building machine fails at the npm install stage when trying to resolve DNS hostname. If all dependencies are provided in advance, npm proceeds with the installation using locally cached files and does not try to access the network.

Clone this wiki locally