File: recovery.pp

package info (click to toggle)
puppet-module-puppetlabs-postgresql 10.5.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 940 kB
  • sloc: ruby: 731; sh: 66; makefile: 2
file content (94 lines) | stat: -rw-r--r-- 6,081 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
# @summary This resource manages the parameters that applies to the recovery.conf template.
#
# @note
#  Allows you to create the content for recovery.conf. For more details see the usage example and the PostgreSQL documentation.
#  Every parameter value is a string set in the template except recovery_target_inclusive, pause_at_recovery_target, standby_mode and
#  recovery_min_apply_delay.
#  A detailed description of all listed parameters can be found in the PostgreSQL documentation.
#  Only the specified parameters are recognized in the template. The recovery.conf is only created if at least one parameter is set and
#  manage_recovery_conf is set to true.
#
# @param restore_command The shell command to execute to retrieve an archived segment of the WAL file series.
# @param archive_cleanup_command This optional parameter specifies a shell command that will be executed at every restartpoint.
# @param recovery_end_command This parameter specifies a shell command that will be executed once only at the end of recovery.
# @param recovery_target_name
#   This parameter specifies the named restore point (created with pg_create_restore_point()) to which recovery will proceed.
# @param recovery_target_time This parameter specifies the time stamp up to which recovery will proceed.
# @param recovery_target_xid This parameter specifies the transaction ID up to which recovery will proceed.
# @param recovery_target_inclusive
#   Specifies whether to stop just after the specified recovery target (true), or just before the recovery target (false).
# @param recovery_target
#   This parameter specifies that recovery should end as soon as a consistent state is reached, i.e. as early as possible.
# @param recovery_target_timeline Specifies recovering into a particular timeline.
# @param pause_at_recovery_target Specifies whether recovery should pause when the recovery target is reached.
# @param standby_mode Specifies whether to start the PostgreSQL server as a standby.
# @param primary_conninfo  Specifies a connection string to be used for the standby server to connect with the primary.
# @param primary_slot_name
#   Optionally specifies an existing replication slot to be used when connecting to the primary via streaming replication to control
#   resource removal on the upstream node.
# @param trigger_file Specifies a trigger file whose presence ends recovery in the standby.
# @param recovery_min_apply_delay
#   This parameter allows you to delay recovery by a fixed period of time, measured in milliseconds if no unit is specified.
# @param target Provides the target for the rule, and is generally an internal only property. Use with caution.
define postgresql::server::recovery (
  Optional[String]    $restore_command           = undef,
  Optional[String[1]] $archive_cleanup_command   = undef,
  Optional[String[1]] $recovery_end_command      = undef,
  Optional[String[1]] $recovery_target_name      = undef,
  Optional[String[1]] $recovery_target_time      = undef,
  Optional[String[1]] $recovery_target_xid       = undef,
  Optional[Boolean]   $recovery_target_inclusive = undef,
  Optional[String[1]] $recovery_target           = undef,
  Optional[String[1]] $recovery_target_timeline  = undef,
  Optional[Boolean]   $pause_at_recovery_target  = undef,
  Optional[String[1]] $standby_mode              = undef,
  Optional[String[1]] $primary_conninfo          = undef,
  Optional[String[1]] $primary_slot_name         = undef,
  Optional[String[1]] $trigger_file              = undef,
  Optional[Integer]   $recovery_min_apply_delay  = undef,
  Stdlib::Absolutepath $target                   = $postgresql::server::recovery_conf_path
) {
  if $postgresql::server::manage_recovery_conf == false {
    fail('postgresql::server::manage_recovery_conf has been disabled, so this resource is now unused and redundant, either enable that option or remove this resource from your manifests') # lint:ignore:140chars
  } else {
    if($restore_command == undef and $archive_cleanup_command == undef and $recovery_end_command == undef
      and $recovery_target_name == undef and $recovery_target_time == undef and $recovery_target_xid == undef
      and $recovery_target_inclusive == undef and $recovery_target == undef and $recovery_target_timeline == undef
      and $pause_at_recovery_target == undef and $standby_mode == undef and $primary_conninfo == undef
    and $primary_slot_name == undef and $trigger_file == undef and $recovery_min_apply_delay == undef) {
      fail('postgresql::server::recovery use this resource but do not pass a parameter will avoid creating the recovery.conf, because it makes no sense.') # lint:ignore:140chars
    }

    concat { $target:
      owner  => $postgresql::server::user,
      group  => $postgresql::server::group,
      force  => true, # do not crash if there is no recovery conf file
      mode   => '0640',
      warn   => true,
      notify => Class['postgresql::server::reload'],
    }

    # Create the recovery.conf content
    concat::fragment { "${name}-recovery.conf":
      target  => $target,
      content => epp('postgresql/recovery.conf.epp', {
          restore_command           => $restore_command,
          archive_cleanup_command   => $archive_cleanup_command,
          recovery_end_command      => $recovery_end_command,
          recovery_target_name      => $recovery_target_name,
          recovery_target_time      => $recovery_target_time,
          recovery_target_xid       => $recovery_target_xid,
          recovery_target_inclusive => $recovery_target_inclusive,
          recovery_target           => $recovery_target,
          recovery_target_timeline  => $recovery_target_timeline,
          pause_at_recovery_target  => $pause_at_recovery_target,
          standby_mode              => $standby_mode,
          primary_conninfo          => $primary_conninfo,
          primary_slot_name         => $primary_slot_name,
          trigger_file              => $trigger_file,
          recovery_min_apply_delay  => $recovery_min_apply_delay,
        }
      ),
    }
  }
}