Docker image that builds and hosts a Gatsby site.
This image has two major tags:
-
latest
- will serve your assets on production using up an nginx server -
onbuild
- builds your project and creates a new docker image
- Create at the root of your project a
Dockerfile
and.dockerignore
, as below: Dockerfile.dockerignoreFROM gatsbyjs/gatsby:onbuild as build FROM gatsbyjs/gatsby COPY --from=build /app/public /pub
.cache/ node_modules/ public/
The first image is going to copy your project, install dependencies and build it.
- Build your project's docker image:
docker build -t myproject/website .
- Upload to the registry
docker push myproject/website
- Use it
docker run --rm -p 80:80 myproject/website # Open your browser at http://localhost
The way Nginx behaves can be configured using environment variables.
Please refer to the docker run command options for the --env-file flag where you can specify all required environment variables in a single file. This will save you from writing a potentially long docker run command. Alternatively you can use docker-compose.
Below is the complete list of available options that can be used to customize your Nginx configuration:
Environment variable | Default | Description |
---|---|---|
CACHE_IGNORE |
html |
Regular expression to specify which paths shouldn't be cacheable (header Cache-Control set to no-store ). |
CACHE_PUBLIC |
ico|jpg|jpeg|png|gif|svg|js|jsx|css|less|swf|eot|ttf|otf|woff|woff2 |
Regular expression to specify which paths should be cacheable (headers Cache-Control set to public and Expires set to the value of $CACHE_PUBLIC_EXPIRATION ). |
CACHE_PUBLIC_EXPIRATION |
1y |
Time to set for header Expires . See http://nginx.org/en/docs/http/ngx_http_headers_module.html#expires |
CHARSET |
utf-8 |
Charset being used in Content-Type response header field. See http://nginx.org/en/docs/http/ngx_http_charset_module.html |
CUSTOM_SERVER_CONFIG |
|
Need to add some advanced/custom nginx config? No problem, you can inject through this environment variable. NOTE: would be discarded if /etc/nginx/server.conf is present. |
CUSTOM_LOCATION_CACHE_IGNORE |
|
Need to add some advanced/custom nginx config to the location for html files? No problem, you can inject through this environment variable. NOTE: would be discarded if /etc/nginx/location_cache_ignore.conf is present. |
CUSTOM_LOCATION_CACHE_PUBLIC |
|
Need to add some advanced/custom nginx config to the location for cached files? No problem, you can inject through this environment variable. NOTE: would be discarded if /etc/nginx/location_cache_public.conf is present. |
DEBUG |
false |
If set to true the configuration is being printed before the server starts. |
GZIP_LEVEL |
6 |
Gzip compression level of a response. See http://nginx.org/en/docs/http/ngx_http_gzip_module.html#gzip_comp_level |
GZIP_TYPES |
application/javascript application/x-javascript application/rss+xml text/javascript text/css image/svg+xml |
MIME types in addition to text/html for which gzip compression should be enabled. See http://nginx.org/en/docs/http/ngx_http_gzip_module.html#gzip_types |
HTTP_PORT |
80 |
The address and / or port for IP, or the path for a UNIX-domain socket on which the server will accept requests. See http://nginx.org/en/docs/http/ngx_http_core_module.html#listen |
PUBLIC_PATH |
/pub |
The path to the directory from which files are being served. See http://nginx.org/en/docs/http/ngx_http_core_module.html#root |
TRAILING_SLASH |
true |
Specifies if paths should end with a trailing slash or not. Prevents duplicated content by redirecting requests to URLs ending with a slash to its non-trailing-slash equivalent if set to true and the other way around for false . |
WORKER_CONNECTIONS |
1024 |
The maximum number of simultaneous connections that can be opened by a worker process. See http://nginx.org/en/docs/ngx_core_module.html#worker_connections |
DISABLE_FILE_CACHE |
false |
Disables nginx's open file cache for when used with a network storage (NFS, SMB, etc) |
You can mount a file to /etc/nginx/server.conf
to extend the server block in nginx config. This could be useful if you have defined client-only routes in GatsbyJS. For example for client only rules on path /client-only
the content of your mounted file should be like:
rewrite ^/client-only/([^.]*?/)$ /client-only/index.html;
Alternatively you can use a custom Dockerfile and copy the file on build:
FROM gatsbyjs/gatsby:latest
COPY nginx-server-rules.conf /etc/nginx/server.conf
NOTE: By adding the file /etc/nginx/server.conf
, all the contents of the CUSTOM_SERVER_CONFIG
environment variable will be discarded.
You can also mount a file to /etc/nginx/location_cache_ignore.conf
or /etc/nginx/location_cache_public.conf
to add custom nginx configuration to our defined locations. For example this can be useful to add headers to avoid robots to crawl the content in a staging environemnt:
add_header x-robots-tag "noindex, follow" always;