Puppet Class: placement::wsgi::apache

Defined in:
manifests/wsgi/apache.pp

Overview

Serving Placement API from apache is the recommended way to go for production because of limited performance for concurrent accesses.

Parameters

servername

(Optional) The servername for the virtualhost. Defaults to $::fqdn

api_port

(Optional) The port for Placement API service. Defaults to 80

bind_host

(Optional) The host/ip address Apache will listen on. Defaults to undef (listen on all ip addresses).

path

(Optional) The prefix for the endpoint. Defaults to ‘/placement’

ssl

(Optional) Use ssl ? (boolean) Defaults to true

workers

(Optional) Number of WSGI workers to spawn. Defaults to $::os_workers

priority

(Optional) The priority for the vhost. Defaults to ‘10’

threads

(Optional) The number of threads for the vhost. Defaults to 1

wsgi_process_display_name

(Optional) Name of the WSGI process display-name. Defaults to undef

ssl_cert
ssl_key
ssl_chain
ssl_ca
ssl_crl_path
ssl_crl
ssl_certs_dir

(Optional) apache::vhost ssl parameters. Default to apache::vhost ‘ssl_*’ defaults.

access_log_file

(Optional) The log file name for the virtualhost. Defaults to false

access_log_format

(Optional) The log format for the virtualhost. Defaults to false

error_log_file

(Optional) The error log file name for the virtualhost. Defaults to undef

vhost_custom_fragment

(optional) Passes a string of custom configuration directives to be placed at the end of the vhost configuration. Defaults to undef.

DEPRECATED PARAMETERS

ensure_package

(Optional) Control the ensure parameter for the Placement API package ressource. Defaults to undef

Examples

include apache

class { 'placement::wsgi::apache': }

Parameters:

  • servername (Any) (defaults to: $::fqdn)
  • api_port (Any) (defaults to: 80)
  • bind_host (Any) (defaults to: undef)
  • path (Any) (defaults to: '/placement')
  • ssl (Any) (defaults to: true)
  • workers (Any) (defaults to: $::os_workers)
  • priority (Any) (defaults to: '10')
  • threads (Any) (defaults to: 1)
  • wsgi_process_display_name (Any) (defaults to: undef)
  • ssl_cert (Any) (defaults to: undef)
  • ssl_key (Any) (defaults to: undef)
  • ssl_chain (Any) (defaults to: undef)
  • ssl_ca (Any) (defaults to: undef)
  • ssl_crl_path (Any) (defaults to: undef)
  • ssl_crl (Any) (defaults to: undef)
  • ssl_certs_dir (Any) (defaults to: undef)
  • access_log_file (Any) (defaults to: false)
  • access_log_format (Any) (defaults to: false)
  • error_log_file (Any) (defaults to: undef)
  • vhost_custom_fragment (Any) (defaults to: undef)
  • ensure_package (Any) (defaults to: undef)


100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
# File 'manifests/wsgi/apache.pp', line 100

class placement::wsgi::apache (
  $servername                = $::fqdn,
  $api_port                  = 80,
  $bind_host                 = undef,
  $path                      = '/placement',
  $ssl                       = true,
  $workers                   = $::os_workers,
  $priority                  = '10',
  $threads                   = 1,
  $wsgi_process_display_name = undef,
  $ssl_cert                  = undef,
  $ssl_key                   = undef,
  $ssl_chain                 = undef,
  $ssl_ca                    = undef,
  $ssl_crl_path              = undef,
  $ssl_crl                   = undef,
  $ssl_certs_dir             = undef,
  $access_log_file           = false,
  $access_log_format         = false,
  $error_log_file            = undef,
  $vhost_custom_fragment     = undef,
  # DEPRECATED PARAMETERS
  $ensure_package            = undef,
) {

  if $api_port == 80 {
    warning('The default api_port will be changed from 80 to 8778 in a future release.')
  }

  if $path == '/placement' {
    warning('The default path will be changed from /placement to / in a future release.')
  }

  include placement::params
  include apache
  include apache::mod::wsgi
  if $ssl {
    include apache::mod::ssl
  }

  if $ensure_package != undef {
    warning('The placement::wsgi::apache::ensure_package parameter is deprecated and has no effect')
  }

  file { $::placement::params::httpd_config_file:
    ensure  => present,
    content => "#
# This file has been cleaned by Puppet.
#
# OpenStack Placement API configuration has been moved to:
# - ${priority}-placement_wsgi.conf
#",
  }
  # Ubuntu requires placement-api to be installed before apache to find wsgi script
  Package<| title == 'placement-api'|> -> Package<| title == 'httpd'|>
  Package<| title == 'placement-api' |>
    -> File[$::placement::params::httpd_config_file]
    ~> Service['httpd']

  Service <| title == 'httpd' |> { tag +> 'placement-service' }

  ::openstacklib::wsgi::apache { 'placement_wsgi':
    bind_host                 => $bind_host,
    bind_port                 => $api_port,
    group                     => 'placement',
    path                      => $path,
    priority                  => $priority,
    servername                => $servername,
    ssl                       => $ssl,
    ssl_ca                    => $ssl_ca,
    ssl_cert                  => $ssl_cert,
    ssl_certs_dir             => $ssl_certs_dir,
    ssl_chain                 => $ssl_chain,
    ssl_crl                   => $ssl_crl,
    ssl_crl_path              => $ssl_crl_path,
    ssl_key                   => $ssl_key,
    threads                   => $threads,
    user                      => 'placement',
    vhost_custom_fragment     => $vhost_custom_fragment,
    workers                   => $workers,
    wsgi_daemon_process       => 'placement-api',
    wsgi_process_display_name => $wsgi_process_display_name,
    wsgi_process_group        => 'placement-api',
    wsgi_script_dir           => $::placement::params::wsgi_script_path,
    wsgi_script_file          => 'placement-api',
    wsgi_script_source        => $::placement::params::wsgi_script_source,
    access_log_file           => $access_log_file,
    access_log_format         => $access_log_format,
    error_log_file            => $error_log_file,
  }

}