Puppet Class: solr::config

Defined in:
manifests/config.pp

Summary

Full description of class solr here.

Overview



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
95
96
97
98
99
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
# File 'manifests/config.pp', line 3

class solr::config {

  if $::osfamily == 'debian' {
    file { '/usr/java':
      ensure  => directory,
    }

    # setup a sym link for java home (TODO: FIX to not be hard coded)
    file { '/usr/java/default':
      ensure  => 'link',
      target  => '/usr/lib/jvm/java-8-openjdk-amd64',
      require => File['/usr/java'],
      before  => File[$::solr::solr_logs],
    }
  }

  # create the directories
  file { $::solr::solr_logs:
    ensure => directory,
    owner  => $solr::solr_user,
    group  => $solr::solr_user,
  }

  if versioncmp($solr::version, '6.0.0') >= 0 {
    # create empty solr log file
    file { "${::solr::solr_logs}/solr.log":
      ensure => present,
      owner  => $solr::solr_user,
      group  => $solr::solr_user,
    }
  }

  # for cores to work without this module
  file { $::solr::solr_core_home:
    ensure => directory,
    owner  => $solr::solr_user,
    group  => $solr::solr_user,
  }

  # After solr v 7.4.0 SOLR now uses log4j2.xml
  if versioncmp($solr::version, '7.4.0') >= 0 {
    # setup log4j2 configuration file.
    $logger_config_file = 'log4j2.xml'
    file { "${::solr::var_dir}/log4j2.xml":
      ensure  => file,
      owner   => $solr::solr_user,
      group   => $solr::solr_user,
      content => epp('solr/log4j2.xml.epp',{
        log4j_rootlogger_loglevel => $solr::log4j_rootlogger_loglevel,
        log4j_maxfilesize         => $solr::log4j_maxfilesize,
        log4j_maxbackupindex      => $solr::log4j_maxbackupindex,
      }),
    }
  } else {
    # setup log4j configuration file.
    $logger_config_file = 'log4j.properties'
    file { "${::solr::var_dir}/log4j.properties":
      ensure  => file,
      owner   => $solr::solr_user,
      group   => $solr::solr_user,
      content => epp('solr/log4j.properties.epp',{
        log4j_rootlogger_loglevel => $solr::log4j_rootlogger_loglevel,
        log4j_maxfilesize         => $solr::log4j_maxfilesize,
        log4j_maxbackupindex      => $solr::log4j_maxbackupindex,
      }),
    }
  }

  # setup default jetty configuration file.
  file { $::solr::solr_env:
    ensure  => file,
    content => epp('solr/solr.in.sh.epp',{
      java_home                       => $solr::java_home,
      solr_heap                       => $solr::solr_heap,
      solr_java_mem                   => $solr::solr_java_mem,
      zk_hosts                        => $solr::zk_hosts,
      solr_pid_dir                    => $solr::solr_pid_dir,
      solr_home                       => $solr::solr_home,
      var_dir                         => $solr::var_dir,
      solr_logs                       => $solr::solr_logs,
      solr_host                       => $solr::solr_host,
      solr_port                       => $solr::solr_port,
      solr_timezone                   => $solr::solr_timezone,
      logger_config_file              => $logger_config_file,
      solr_environment                => $solr::solr_environment,
      ssl_key_store                   => $solr::ssl_key_store,
      ssl_key_store_password          => $solr::ssl_key_store_password,
      ssl_trust_store                 => $solr::ssl_trust_store,
      ssl_trust_store_password        => $solr::ssl_trust_store_password,
      ssl_need_client_auth            => $solr::ssl_need_client_auth,
      ssl_want_client_auth            => $solr::ssl_want_client_auth,
      ssl_client_key_store            => $solr::ssl_client_key_store,
      ssl_client_key_store_password   => $solr::ssl_client_key_store_password,
      ssl_client_trust_store          => $solr::ssl_client_trust_store,
      ssl_client_trust_store_password => $solr::ssl_client_trust_store_password,
      solr_options                    => $solr::solr_options,
    }),
    require => File[$::solr::solr_logs],
  }

  # setup the service level entry
  if $::solr::params::is_systemd {
    include '::systemd'
    ::systemd::unit_file { 'solr.service':
      content => epp('solr/solr.service.epp',{
        solr_pid_dir => $solr::solr_pid_dir,
        solr_port    => $solr::solr_port,
        solr_bin     => $solr::solr_bin,
        solr_env     => $solr::solr_env,
        solr_user    => $solr::solr_user,
        zk_service   => $solr::zk_service,
        limit_nofile => $solr::limit_nofile,
        limit_nproc  => $solr::limit_nproc,
      }),
      require => File[$::solr::solr_env],
    }

    # prevents confusion
    file { '/etc/init.d/solr':
      ensure => absent,
    }
  } else {
    file { '/etc/init.d/solr':
      ensure  => file,
      mode    => '0755',
      content => epp('solr/solr.sh.epp',{
        solr_bin  => $solr::solr_bin,
        solr_user => $solr::solr_user,
        solr_env  => $solr::solr_env,
      }),
      require => File[$::solr::solr_env],
    }
  }
}