Forge Home

passenger

Configures and manages Passenger.

102,901 downloads

102,901 latest version

3.1 quality score

We run a couple of automated
scans to help you access a
module's quality. Each module is
given a score based on how well
the author has formatted their
code and documentation and
modules are also checked for
malware using VirusTotal.

Please note, the information below
is for guidance only and neither of
these methods should be considered
an endorsement by Puppet.

Version information

  • 0.5.0 (latest)
released Mar 2nd 2016
This version is compatible with:
  • Puppet Enterprise 3.x
  • Puppet >= 2.7.0 <= 4.3.2
  • , , ,

Start using this module

  • r10k or Code Manager
  • Bolt
  • Manual installation
  • Direct download

Add this module to your Puppetfile:

mod 'marcel-passenger', '0.5.0'
Learn more about managing modules with a Puppetfile

Add this module to your Bolt project:

bolt module add marcel-passenger
Learn more about using this module with an existing project

Manually install this module globally with Puppet module tool:

puppet module install marcel-passenger --version 0.5.0

Direct download is not typically how you would use a Puppet module to manage your infrastructure, but you may want to download the module in order to inspect the code.

Download

Documentation

marcel/passenger — version 0.5.0 Mar 2nd 2016

passenger

Overview

The Passenger module allows easy configuration and management of Phusion Passenger.

Fork

This repository is a fork from puppetlabs/puppetlabs-passenger, created to merge a stagnating pull request for Puppet 4.x support.

Module Description

The Passenger module lets you run Rails or Rack inside Apache with ease. Utilizing Passenger, an application server for Ruby (Rack) and Python (WSGI) apps, the Passenger module enables quick configuration of Passenger for Apache.

Setup

What Passenger affects:

  • Apache
  • installs packages on chosen nodes
  • package/service/configuration files for Passenger

Beginning with Passenger

Install and begin managing Passenger on a node by declaring the class in your node definition:

node default {
  class {'passenger': }
}

This will establish Passenger on your node with sane default values. However, you can manually set the parameter values:

node default {
  class {'passenger':
    passenger_version      => '2.2.11',
    passenger_provider     => 'gem',
    passenger_package      => 'passenger',
    gem_path               => '/var/lib/gems/1.8/gems',
    gem_binary_path        => '/var/lib/gems/1.8/bin',
    passenger_root         => '/var/lib/gems/1.8/gems/passenger-2.2.11'
    mod_passenger_location => '/var/lib/gems/1.8/gems/passenger-2.2.11/ext/apache2/mod_passenger.so',
    include_build_tools    => true,
  }
}

Usage

The passenger class has a set of configurable parameters that allow you to control aspects of Passenger's installation.

Parameters within passenger

####gem_binary_path

Path to Rubygems binaries on your system

####gem_path

The path to rubygems on your system

####include_build_tools

Boolean to require gcc and make classes. Default is false.

####mod_passenger_location

Path to Passenger's mod_passenger.so file

####package_ensure

Ensure the state of the passenger package

####package_provider

Provider to use to install passenger

####passenger_package

The name of the Passenger package

####passenger_provider

The package provider to use for the system

####passenger_root

Root directory for passenger

####passenger_ruby

Allows you to customize what ruby binary is used

####passenger_version

The Version of Passenger to be installed

####compile_passenger

Whether or not to include the passenger::compile class. Defaults to true.

Implementation

This module operates by compiling Ruby gems on the system being managed.

Limitations

This module was developed and tested against RHEL and Debian based systems (Centos, Fedora, Redhat, Debian, Ubuntu). This module may require you to specify default parameter values to accommodate other distributions.

Development

Puppet Labs modules on the Puppet Forge are open projects, and community contributions are essential for keeping them great. We can’t access the huge number of platforms and myriad of hardware, software, and deployment configurations that Puppet is intended to serve.

We want to keep it as easy as possible to contribute changes so that our modules work in your environment. There are a few guidelines that we need contributors to follow so that we can have a chance of keeping on top of things.

You can read the complete module contribution guide on the Puppet Labs wiki.

Release Notes

0.0.4 Release

  • Remove puppetlabs-gcc dependency
  • Add package dependencies for Passenger 3.0
  • Re-order resources (removing chaining syntax)