Add Apache WSGI logging parameters for pipe/syslog

Add parameters for advanced logging configurations in Apache to
support piped logging and support for syslog (via mod_syslog
available in Apache >= 2.5.0)

Co-Authored-By: Andy Botting <andy@andybotting.com>
Change-Id: If07cac9bc41d173baeadbefb4dad3612c32ee369
This commit is contained in:
Takashi Kajinami 2022-08-26 16:53:21 +09:00
parent db397318f7
commit d34f26c319
3 changed files with 102 additions and 9 deletions

View File

@ -70,6 +70,14 @@
# The log file name for the virtualhost. # The log file name for the virtualhost.
# Optional. Defaults to undef. # Optional. Defaults to undef.
# #
# [*access_log_pipe*]
# Specifies a pipe where Apache sends access logs for the virtualhost.
# Optional. Defaults to undef.
#
# [*access_log_syslog*]
# Sends the virtualhost access log messages to syslog.
# Optional. Defaults to undef.
#
# [*access_log_format*] # [*access_log_format*]
# The log format for the virtualhost. # The log format for the virtualhost.
# Optional. Defaults to undef. # Optional. Defaults to undef.
@ -78,6 +86,14 @@
# The error log file name for the virtualhost. # The error log file name for the virtualhost.
# Optional. Defaults to undef. # Optional. Defaults to undef.
# #
# [*error_log_pipe*]
# Specifies a pipe where Apache sends error logs for the virtualhost.
# Optional. Defaults to undef.
#
# [*error_log_syslog*]
# Sends the virtualhost error log messages to syslog.
# Optional. Defaults to undef.
#
# [*custom_wsgi_process_options*] # [*custom_wsgi_process_options*]
# (optional) gives you the oportunity to add custom process options or to # (optional) gives you the oportunity to add custom process options or to
# overwrite the default options for the WSGI main process. # overwrite the default options for the WSGI main process.
@ -122,8 +138,12 @@ class zaqar::wsgi::apache (
$threads = 1, $threads = 1,
$priority = 10, $priority = 10,
$access_log_file = undef, $access_log_file = undef,
$access_log_pipe = undef,
$access_log_syslog = undef,
$access_log_format = undef, $access_log_format = undef,
$error_log_file = undef, $error_log_file = undef,
$error_log_pipe = undef,
$error_log_syslog = undef,
$custom_wsgi_process_options = {}, $custom_wsgi_process_options = {},
$headers = undef, $headers = undef,
$request_headers = undef, $request_headers = undef,
@ -161,9 +181,13 @@ class zaqar::wsgi::apache (
headers => $headers, headers => $headers,
request_headers => $request_headers, request_headers => $request_headers,
vhost_custom_fragment => 'WSGICallableObject app', vhost_custom_fragment => 'WSGICallableObject app',
custom_wsgi_process_options => $custom_wsgi_process_options,
access_log_file => $access_log_file, access_log_file => $access_log_file,
access_log_pipe => $access_log_pipe,
access_log_syslog => $access_log_syslog,
access_log_format => $access_log_format, access_log_format => $access_log_format,
error_log_file => $error_log_file, error_log_file => $error_log_file,
custom_wsgi_process_options => $custom_wsgi_process_options, error_log_pipe => $error_log_pipe,
error_log_syslog => $error_log_syslog,
} }
} }

View File

@ -0,0 +1,6 @@
---
features:
- |
Added parameters for advanced configuration of httpd access and error log
destinations including piped logging and syslog (see `mod_syslog`). Note
that mod_syslog requires Apache2 >= 2.5.0.

View File

@ -20,9 +20,14 @@ describe 'zaqar::wsgi::apache' do
:wsgi_script_dir => platform_params[:wsgi_script_path], :wsgi_script_dir => platform_params[:wsgi_script_path],
:wsgi_script_file => 'zaqar-server', :wsgi_script_file => 'zaqar-server',
:wsgi_script_source => platform_params[:wsgi_script_source], :wsgi_script_source => platform_params[:wsgi_script_source],
:access_log_file => nil,
:access_log_format => nil,
:custom_wsgi_process_options => {}, :custom_wsgi_process_options => {},
:access_log_file => nil,
:access_log_pipe => nil,
:access_log_syslog => nil,
:access_log_format => nil,
:error_log_file => nil,
:error_log_pipe => nil,
:error_log_syslog => nil,
)} )}
end end
@ -35,9 +40,6 @@ describe 'zaqar::wsgi::apache' do
:ssl => true, :ssl => true,
:wsgi_process_display_name => 'zaqar-server', :wsgi_process_display_name => 'zaqar-server',
:workers => 37, :workers => 37,
:access_log_file => '/var/log/httpd/access_log',
:access_log_format => 'some format',
:error_log_file => '/var/log/httpd/error_log',
:custom_wsgi_process_options => { :custom_wsgi_process_options => {
'python_path' => '/my/python/path', 'python_path' => '/my/python/path',
}, },
@ -67,9 +69,70 @@ describe 'zaqar::wsgi::apache' do
:custom_wsgi_process_options => { :custom_wsgi_process_options => {
'python_path' => '/my/python/path', 'python_path' => '/my/python/path',
}, },
:access_log_file => '/var/log/httpd/access_log', )}
:access_log_format => 'some format', end
:error_log_file => '/var/log/httpd/error_log',
context 'with custom access logging' do
let :params do
{
:access_log_format => 'foo',
:access_log_syslog => 'syslog:local0',
:error_log_syslog => 'syslog:local1',
}
end
it { should contain_openstacklib__wsgi__apache('zaqar_wsgi').with(
:access_log_format => params[:access_log_format],
:access_log_syslog => params[:access_log_syslog],
:error_log_syslog => params[:error_log_syslog],
)}
end
context 'with access_log_file' do
let :params do
{
:access_log_file => '/path/to/file',
}
end
it { should contain_openstacklib__wsgi__apache('zaqar_wsgi').with(
:access_log_file => params[:access_log_file],
)}
end
context 'with access_log_pipe' do
let :params do
{
:access_log_pipe => 'pipe',
}
end
it { should contain_openstacklib__wsgi__apache('zaqar_wsgi').with(
:access_log_pipe => params[:access_log_pipe],
)}
end
context 'with error_log_file' do
let :params do
{
:error_log_file => '/path/to/file',
}
end
it { should contain_openstacklib__wsgi__apache('zaqar_wsgi').with(
:error_log_file => params[:error_log_file],
)}
end
context 'with error_log_pipe' do
let :params do
{
:error_log_pipe => 'pipe',
}
end
it { should contain_openstacklib__wsgi__apache('zaqar_wsgi').with(
:error_log_pipe => params[:error_log_pipe],
)} )}
end end
end end