A Cloud Native Buildpack for configuring Nginx settings for PHP apps.
The buildpack generates the Nginx configuration file with the minimal set of
options to get Nginx to work with FPM (FastCGI Process Manager), and
incorporates configuration from users and environment variables. The final
Nginx configuration file is available at
/workspace/nginx.conf
, or locatable
through the buildpack-set $PHP_NGINX_PATH
environment variable at
launch-time.
The PHP Nginx CNB provides php-nginx-config
, which can be required by subsequent
buildpacks. In order to configure Nginx, the user must declare the intention to
use Nginx as the web-server by setting the $BP_PHP_SERVER
environment
variable to nginx
at build-time.
pack build my-nginx-app --env BP_PHP_SERVER="nginx"
The base configuration file generated in this buildpack includes some default configuration, FPM-specific configuration, and
has include
sections for user-included configuration.
This buildpack is written to provide Nginx configuration that should always be
used in conjunction with FPM. The Nginx configuration file is generated to
include FPM-specific configuration. This buildpack also sets up an FPM
configuration file with Nginx-specific socket settings and makes it available
in the /workspace
.
User-included configuration should be found in the application source directory
under <app-directory>/.nginx.conf.d/
. Server-specific configuration should be
inside a file named *-server.conf
, and HTTP configuration should be inside a
file with the naming structure *-http.conf
.
If files at these paths exist, it
will be included in include
sections at the appropriate places in the generated
Nginx configuration.
The following environment variables can be used to override default settings in the Nginx configuration file.
Variable | Default |
---|---|
BP_PHP_NGINX_ENABLE_HTTPS |
false |
BP_PHP_ENABLE_HTTPS_REDIRECT |
true |
BP_PHP_WEB_DIR |
htdocs |
BP_PHP_DISABLE_PHP_ROOT_LOCATION |
false |
Note that for HTTPS workloads, setting $BP_PHP_NGINX_ENABLE_HTTPS
sets all
connections to work in SSL mode. You may still need to add a user-included
config file to provide directives like ssl_certificate
, ssl_certificate_key
etc.
Frameworks like Wordpress, Laravel or Symfony need a specific nginx location directive,
which redirects all requested URIs to index.php
if they don't exist on the
filesystem. This specific directive is included by default:
location / {
try_files $uri $uri/ /index.php?$query_string;
}
If your application doesn't use one of those frameworks you can disable the
directive by setting BP_PHP_DISABLE_PHP_ROOT_LOCATION
to true
.
To package this buildpack for consumption:
$ ./scripts/package.sh
This builds the buildpack's Go source using GOOS=linux
by default. You can
supply another value as the first argument to package.sh
.
To run all unit tests, run:
./scripts/unit.sh
To run all integration tests, run:
./scripts/integration.sh
For extra debug logs from the image build process, set the $BP_LOG_LEVEL
environment variable to DEBUG
at build-time (ex. pack build my-app --env BP_LOG_LEVEL=DEBUG
or through a project.toml
file.