Configuration


In this section, you will learn how to create and manage configuration files for Pup.

To create a minimal configuration file for Pup manually, first create a new file named pup.json in your project's root directory. You can also name it pup.jsonc if you want to use jsonc-style comments.

Then, add the following basic configuration to the file:

{
  "name": "my-instance-name",
  "processes": [
    {
      "id": "my-process-id",
      "cmd": "deno run --allow-net app.ts",
      "autostart": true
    }
  ]
}

This defines a single process named example that runs a Deno script (app.ts) with the --allow-net flag. You can customize the configuration to suit your needs by adding more processes or updating the existing process definition.

Note: If you quickly want to scaffold a new configuration file, you can use the cli helpers pup init, append, and remove. More on this at Configuring using the cli.

Process configuration

Here's a list of available configuration options for each process:

General

  • id (required): A unique identifier for the process.
  • cmd (optional): A string containing the full command to run, supporting common shell features such as && for chaining through dax.
  • worker (optional): A string containing the worker script as first entry.
  • cwd (optional): The working directory for the process.
  • env (optional): An object containing extended environment variables for the process. This will override environment variables conflicting with existing ones, except PATH that will be appended.
  • path (optional): Extra paths that will be appended to PATH for this process, this is a shortcut for adding PATH to the env-option.
  • pidFile (optional): The path to the file where the process ID (PID) will be stored.
  • timeout (optional): A number specifying the maximum time (in seconds) that the process is allowed to run before it's terminated.
  • overrun (optional): A boolean indicating whether a new instance of the process is allowed to start if the previous instance is still running. Default: false.

Start policy

You need to specify one of these for each process, else the process will never start.

  • autostart (optional): A boolean indicating whether the process should start automatically when Pup starts. Default: false.
  • cron (optional): A cron expression specifying the schedule for the process to run.
  • watch (optional): An array of locations to watch for file changes. Process will start/restart when a file or directory changes.

Restart policy

  • restart (optional): A string specifying when the process should be restarted. Allowed values: "always" or "error".
  • restartDelayMs (optional): A number specifying the delay (in milliseconds) before restarting the process.
  • restartLimit (optional): A number specifying the maximum number of restarts allowed for the process.

Stop/restart policy

  • terminate (optional): A cron expression specifying when the process should terminate. Combined with restart: "always" this effectively restarts the process on a cron schedule.
  • terminateGracePeriod (optional): A number specifying how many seconds to wait for a process to finish by itself before actually asking it to terminate.
  • terminateTimeout (optional): A number specifying how many seconds to wait for a process to terminate before killing it.

Clustering

  • cluster (optional): An object specifying options to run this process in multiple instances, more on this at 6. Clusters and Load Balancer
    • instances: The number of instances to run using this configuration.
    • startPort (optional): A number specifying the port on which each instance should listen. This is incremented for each instance and passed by environment variable PUP_CLUSTER_PORT.
    • commonPort (optional): A number specifying a common port for all instances, opened by the built in load balancer.
    • strategy (optional): Load balancing strategy, should be set to "round-robin", "least-connections" or "ip-hash".

Global configuration

Global configuration are entirely optional.

You can define global configuration options that apply to all processes. In addition to processes: the global configuration keys are:

  • name: A string indicating the instance name, 1-64 characters in the range a-z 0-9 . _ -.
  • logger: An object containing global logger configuration options.
  • watcher: An object containing global watcher configuration options.
  • plugins: An array containing configurations for all plugins that should be enabled.

Logger

The global logger configuration allows you to control the logging settings for pup, and the defaults of each process. To use the global logger, include the following properties within your configuration file:

  • console (boolean): Set to true to enable logging to the console. Default is false.
  • stdout (string): The file path to write standard output logs.
  • stderr (string): The file path to write standard error logs. If omitted, stderr is written to the file specified by stdout.
  • decorateFiles (boolean): Set to true to enable decoration in the output files. Default is false.
  • decorate (boolean): Only available in global scope. Set to true to enable decoration in the logs. Default is false.
  • colors (boolean): Only available in global scope. Set to true to enable colored output. Default is false.
  • internalLogHours (number): Only available in global scope. Keep internal logs and metrics (used for pup logs and varius plugins for selected number of hours. Lowest value is 0 (disable interna logging) and highest valid value is 366 (two weeks).

Most options can be used in both the global scope logger, and for each process like:

{
  "logger": {
    "console": true,
    "stdout": "/path/to/stdout.log",
    "stderr": "/path/to/stderr.log",
    "colors": true,
    "decorateFiles": true,
    "decorate": true,
    "internalLogHours": 24
  },
  "processes": [
    {
      "id": "my-process",
      /* ... */
      "logger": {
        "console": true,
        "stdout": "/path/to/process.stdout.log",
        "stderr": "/path/to/process.stderr.log",
        "decorateFiles": true
      }
    }
  ]
}

Watcher

The global watcher configuration allows you to control file watching settings for the entire library.

Enable watcher in the process configuration using watch: ["paths","to","watch"].

To change default behavior of the global watcher, use the following properties within your configuration file:

  • interval (number): The interval (in milliseconds) at which the watcher checks for file changes. Default is 1000.
  • exts (array of strings): The file extensions to watch. Default is ["ts", "tsx", "js", "jsx", "json"].
  • match (array of strings): The patterns to match for watched files. Default is ["**/*.*"].
  • skip (array of strings): The patterns to exclude from watching. Default is ["**/.git/**"].
{
  /* This entire section is optional, the defaults are shown below */
  "watcher": {
    "interval": 100, // default
    "exts": ["ts", "tsx", "js", "jsx", "json"], // default
    "match": ["**/*.*"], // default
    "skip": ["**/.git/**"] // default
  },

  "processes": [
    {
      "id": "my-process",
      /* ... */
      "watch": ["src/"] // This will enable the watcher
    }
  ]
}

API

The API configuration object is optional, and is used to customize the Rest API used to interact with Pup. Here's a breakdown of the available properties:

Option Type Description Default
hostname string (Optional) The hostname the API server should bind to. "127.0.0.1"
port number (Optional) The port the API server should listen on. Random port
revoked array (Optional) A list of revoked API consumers. []

By default, the API is only exposed to localhost, and will listen on a random port.

If you want to use the API remotely, you can supply a specific port (one per instance) and set hostname to 0.0.0.0. It is highly recommended to use a proxy such as nginx, and applying additional security measures, if exposing the API to the internet.

Example, listening on port 9000 of all interfaces:

{
  "api": {
    "hostname": "0.0.0.0",
    "port": 9000,
    "revoked": ["my-consumer", "my-other-consumer"]
  }
}

Validating the Configuration

To ensure your configuration is valid, just run pup run (or pup run --config custom/path/to/config.json). If using pup as a library, you can use the validateConfiguration() function provided by the /lib/core/configuration.ts file. This function checks if the configuration adheres to the schema and will throw an error if it doesn't.

With a valid configuration in place, you're ready to use Pup to manage your processes.

VS Code Intellisense

If you want Intellisense and code completion for pup.json/pup.jsonc in VS Code, you have two options.

  1. Add $schema to your pup.json like this
{
  "$schema": "https://deno.land/x/pup/docs/pup.schema.json",
  "processes: [
    /*...*/
  ]
}
  1. Append the pup json schema to json.schemas in your user settings or project settings (.vscode/settings.json).

It should look something like this:

{
  "json.schemas": [
    {
      "fileMatch": [
        "/pup.json",
        "/pup.jsonc"
      ],
      "url": "https://deno.land/x/pup/docs/pup.schema.json"
    }
  ]
}