Mac OS X

Sensu on Mac OS X

Install Sensu Core

IMPORTANT: Sensu Core reached end-of-life (EOL) on December 31, 2019, and we permanently removed the Sensu EOL repository on February 1, 2021.

This means the packages specified in the instructions below are no longer available. To migrate to Sensu Go, read the Sensu Core migration guide.

Sensu Core is installed on Mac OS X systems via a native system installer package (i.e. a .pkg file).

WARNING: Mac OS X packages are currently as a “beta” release. Support for running Sensu on Mac OS X will be provided on a best-effort basis until further notice.

Download and install Sensu using the Sensu Universal .pkg file

  1. Download the Sensu Mac OS X package. NOTE: the Universal .pkg file supports OS X “Mavericks” (10.9) and newer. Mountain Lion users: please use this installer.

  2. Install the package using the installer utility

    sudo installer -pkg sensu-1.4.1-1.pkg -target /

  3. Configure the Sensu client. No “default” configuration is provided with Sensu, so the Sensu Client will not start without the corresponding configuration. Please refer to the “Configure Sensu” section (below) for more information on configuring Sensu. At minimum, the Sensu client will need a working transport definition and client definition.

Configure Sensu

By default, all of the Sensu services on Mac OS X systems will load configuration from the following locations:

  • /etc/sensu/config.json
  • /etc/sensu/conf.d/

NOTE: additional or alternative configuration file and directory locations may be used by modifying Sensu’s launchd daemon configuration XML and/or by starting the Sensu services with the corresponding CLI arguments. For more information, please see the configure the Sensu client launchd daemon section, below.

The following Sensu configuration files are provided as examples. Please review the Sensu configuration reference documentation for additional information on how Sensu is configured.

Create the Sensu configuration directory

In some cases, the default Sensu configuration directory (i.e. /etc/sensu/conf.d/) is not created by the Sensu installer, in which case it is necessary to create this directory manually.

mkdir /etc/sensu/conf.d

Example client configuration

  1. Copy the following contents to a configuration file located at /etc/sensu/conf.d/client.json:
    {
      "client": {
        "name": "macosx-client",
        "address": "127.0.0.1",
        "environment": "development",
        "subscriptions": [
          "dev",
          "macosx-hosts"
        ],
        "socket": {
          "bind": "127.0.0.1",
          "port": 3030
        }
      }
    }

Example Transport Configuration

At minimum, the Sensu client process requires configuration to tell it how to connect to the configured Sensu Transport.

  1. Copy the following contents to a configuration file located at /etc/sensu/conf.d/transport.json:

    {
      "transport": {
        "name": "rabbitmq",
        "reconnect_on_error": true
      }
    }
    NOTE: if you are using Redis as your transport, please use "name": "redis" for your transport configuration. For more information, please visit the transport definition specification.

  2. If the transport being used is running on a different host, additional configuration is required to tell the sensu client how to connect to the transport. Please see Redis or RabbitMQ reference documentation for examples.

Configure the Sensu client launchd daemon

The Sensu Core .pkg package includes a Sensu client daemon configuration, allowing Sensu to be run as a launchd job, or daemon. The OS X launchd service and launchctl utility use a “plist” file (an XML-based configuration file) to configure the sensu-client daemon run arguments (e.g. --log /var/log/sensu/sensu-client.log).

  1. To configure the Sensu client service wrapper, copy the default service definition file entitled org.sensuapp.sensu-client.plist to /Library/LaunchDaemons/org.sensuapp.sensu-client.plist and edit it with your favorite text editor.

    sudo cp /opt/sensu/embedded/Cellar/sensu/1.4.1/Library/LaunchDaemons/org.sensuapp.sensu-client.plist /Library/LaunchDaemons/org.sensuapp.sensu-client.plist

  2. This XML configuration file allows you to set Sensu client CLI arguments. The following example configuration file sets the Sensu client primary configuration file path to /etc/sensu/config.json, the Sensu configuration directory to /etc/sensu/conf.d, and the log file path to /etc/sensu/sensu-client.log.

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE plist PUBLIC -//Apple//DTD PLIST 1.0//EN http://www.apple.com/DTDs/PropertyList-1.0.dtd>
    <plist version="1.0">
     <dict>
       <key>Label</key><string>org.sensuapp.sensu-client</string>
       <key>ProgramArguments</key>
       <array>
         <string>/opt/sensu/bin/sensu-client</string>
         <string>-c/etc/sensu/config.json</string>
         <string>-d/etc/sensu/conf.d</string>
         <string>-l/var/log/sensu/sensu-client.log</string>
       </array>
       <key>UserName</key><string>_sensu</string>
       <key>GroupName</key><string>_sensu</string>
       <key>RunAtLoad</key><true/>
       <key>KeepAlive</key><true/>
       <key>StandardOutPath</key><string>/var/log/sensu/sensu-client.log</string>
       <key>StandardErrorPath</key><string>/var/log/sensu/sensu-client.log</string>
     </dict>
    </plist>

Operating Sensu

Managing the Sensu client process with launchctl

Start or stop the Sensu client using the launchctl utility:

sudo launchctl load -w /Library/LaunchDaemons/org.sensuapp.sensu-client.plist
sudo launchctl unload -w /Library/LaunchDaemons/org.sensuapp.sensu-client.plist

Interacting with Sensu via CLI

Interacting with the any of the installed Sensu processes (e.g. sensu-client) via CLI on Mac OS X requires running the processes as the _sensu user, which is installed by the Sensu OS X installer package.

EXAMPLE

$ sudo -u _sensu /opt/sensu/bin/sensu-client -V
1.4.1