Page MenuHomeSoftware Heritage

README.md
No OneTemporary

README.md

# Cassandra
[![Puppet Forge](http://img.shields.io/puppetforge/v/locp/cassandra.svg)](https://forge.puppetlabs.com/locp/cassandra)
[![Github Tag](https://img.shields.io/github/tag/locp/cassandra.svg)](https://github.com/locp/cassandra)
[![Build Status](https://travis-ci.org/locp/cassandra.png?branch=master)](https://travis-ci.org/locp/cassandra)
[![Coverage Status](https://coveralls.io/repos/locp/cassandra/badge.svg?branch=master&service=github)](https://coveralls.io/github/locp/cassandra?branch=master)
[![Join the chat at https://gitter.im/locp/cassandra](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/locp/cassandra?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
#### Table of Contents
1. [Overview](#overview)
2. [Setup - The basics of getting started with Cassandra](#setup)
* [What Cassandra affects](#what-cassandra-affects)
* [Beginning with Cassandra](#beginning-with-cassandra)
* [Upgrading](#upgrading)
3. [Usage - Configuration options and additional functionality](#usage)
* [Create a Cluster in a Single Data Center](#create-a-cluster-in-a-single-data-center)
* [Create a Cluster in Multiple Data Centers](#create-a-cluster-in-multiple-data-centers)
* [OpsCenter](#opscenter)
* [DataStax Enterprise](#datastax-enterprise)
4. [Reference - An under-the-hood peek at what the module is doing and how](#reference)
* [cassandra](#class-cassandra)
* [cassandra::datastax_agent](#class-cassandradatastax_agent)
* [cassandra::datastax_repo](#class-cassandradatastax_repo)
* [cassandra::firewall_ports](#class-cassandrafirewall_ports)
* [cassandra::java](#class-cassandrajava)
* [cassandra::opscenter](#class-cassandraopscenter)
* [cassandra::opscenter::cluster_name](#defined-type-cassandraopscentercluster_name)
* [cassandra::opscenter::pycrypto](#class-cassandraopscenterpycrypto)
* [cassandra::optutils](#class-cassandraoptutils)
5. [Limitations - OS compatibility, etc.](#limitations)
6. [Contributers](#contributers)
## Overview
A Puppet module to install and manage Cassandra, DataStax Agent & OpsCenter
## Setup
### What Cassandra affects
#### What the Cassandra class affects
* Installs the Cassandra package (default **cassandra22** on Red Hat and
**cassandra** on Debian).
* Configures settings in *${config_path}/cassandra.yaml*.
* On CentOS 7 if the `init` service provider is used, then cassandra
is added as a system service.
* Optionally ensures that the Cassandra service is enabled and running.
* On Ubuntu systems, optionally replace ```/etc/init.d/cassandra``` with a
workaround for
[CASSANDRA-9822](https://issues.apache.org/jira/browse/CASSANDRA-9822).
* Optionally creates a file /usr/lib/systemd/system/cassandra.service to
improve service interaction.
#### What the cassandra::datastax_agent class affects
* Optionally installs the DataStax agent.
* Optionally sets JAVA_HOME in **/etc/default/datastax-agent**.
#### What the cassandra::datastax_agent class affects
* Optionally configures a Yum repository to install the Cassandra packages
from (on Red Hat).
* Optionally configures an Apt repository to install the Cassandra packages
from (on Ubuntu).
#### What the cassandra::firewall_ports class affects
* Optionally configures the firewall for the Cassandra related network
ports.
#### What the cassandra::java class affects
* Optionally installs a JRE/JDK package (e.g. java-1.7.0-openjdk) and the
Java Native Access (JNA).
#### What the cassandra::opscenter class affects
* Installs the OpsCenter package.
* Manages the content of the configuration file
(/etc/opscenter/opscenterd.conf).
* Manages the opscenterd service.
#### What the cassandra::opscenter::cluster_name type affects
* An optional type that allows DataStax OpsCenter to connect to a remote
key space for metrics storage. These files will be created in
/etc/opscenter/clusters. The module also creates this directory if
required. This functionality is only valid in DataStax Enterprise.
#### What the cassandra::opscenter::pycrypto class affects
* On the Red Hat family it installs the pycrypto library and it's
pre-requisites (the python-devel and python-pip packages).
* Optionally installs the Extra Packages for Enterprise Linux (EPEL)
repository.
* As a workaround for
[PUP-3829](https://tickets.puppetlabs.com/browse/PUP-3829) a symbolic
link is created from ```/usr/bin/pip``` to
```/usr/bin/pip-python```. Hopefully this can be removed in the not
too distant future.
#### What the cassandra::optutils class affects
* Optionally installs the Cassandra support tools (e.g. cassandra22-tools).
### Beginning with Cassandra
A basic example is as follows:
```puppet
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
endpoint_snitch => 'GossipingPropertyFileSnitch',
listen_address => "${::ipaddress}",
seeds => '110.82.155.0,110.82.156.3'
}
```
### Upgrading
#### Changes in 1.9.2
Now that Cassandra 3 is available from the DataStax repositories, there is
a problem (especially on Debian) with the operating system package manager
attempting to install Cassandra 3. This can be mitigated against using
something similar to the code in this modules acceptance test. Please note
that the default Cassandra package name has now been changed from 'dsc'. See
the documentation for cassandra::package_name below for details.
```puppet
if $::osfamily == 'RedHat' {
$version = '2.2.4-1'
} else {
$version = '2.2.4'
}
class { 'cassandra':
package_ensure => $version,
}
```
#### Changes in 1.8.0
A somewhat embarrassing correction to the spelling of the
cassandra::fail_on_non_suppoted_os to cassandra::fail_on_non_supported_os.
#### Issues when Upgrading to 1.4.0
Unfortunately both releases 1.3.7 and 1.4.0 have subsequently been found to
call a refresh service even when no changes had been made to the underlying
configuration. In release 1.8.0 (somewhat belatedly) the service_refresh
flag has been introduced to mitigate against similar problems.
#### Issues When Upgrading to 1.3.7
* Please see the notes for 1.4.0.
#### Changes in 1.0.0
* cassandra::cassandra_package_ensure has been renamed to
cassandra::package_ensure.
* cassandra::cassandra_package_name has been renamed to
cassandra::package_name.
#### Changes in 0.4.0
There is now a cassandra::datastax_agent class, therefore:
* cassandra::datastax_agent_package_ensure has now been replaced with
cassandra::datastax_agent::package_ensure.
* cassandra::datastax_agent_service_enable has now been replaced with
cassandra::datastax_agent::service_enable.
* cassandra::datastax_agent_service_ensure has now been replaced with
cassandra::datastax_agent::service_ensure.
* cassandra::datastax_agent_package_name has now been replaced with
cassandra::datastax_agent::package_name.
* cassandra::datastax_agent_service_name has now been replaced with
cassandra::datastax_agent::service_name.
Likewise now there is a new class for handling the installation of Java:
* cassandra::java_package_ensure has now been replaced with
cassandra::java::ensure.
* cassandra::java_package_name has now been replaced with
cassandra::java::package_name.
Also there is now a class for installing the optional utilities:
* cassandra::cassandra_opt_package_ensure has now been replaced with
cassandra::optutils:ensure.
* cassandra::cassandra_opt_package_name has now been replaced with
cassandra::optutils:package_name.
#### Changes in 0.3.0
* cassandra_opt_package_ensure changed from 'present' to undef.
* The manage_service option has been replaced with service_enable and
service_ensure.
## Usage
### Create a Cluster in a Single Data Center
In the DataStax documentation _Initializing a multiple node cluster (single
data center)_
<http://docs.datastax.com/en/cassandra/2.2/cassandra/initialize/initSingleDS.html>
there is a basic example of a six node cluster with two seeds to be created in
a single data center spanning two racks. The nodes in the cluster are:
**Node Name** | **IP Address** |
---------------|----------------|
node0 (seed 1) | 110.82.155.0 |
node1 | 110.82.155.1 |
node2 | 110.82.155.2 |
node3 (seed 2) | 110.82.156.3 |
node4 | 110.82.156.4 |
node5 | 110.82.156.5 |
Each node is configured to use the GossipingPropertyFileSnitch and 256 virtual
nodes (vnodes). The name of the cluster is _MyCassandraCluster_. Also,
while building the initial cluster, we are setting the auto_bootstrap
to false.
In this initial example, we are going to expand the example by:
* Ensuring that the software is installed via the DataStax Community
repository by including `cassandra::datastax_repo`. This needs to be
executed before the Cassandra package is installed.
* That a suitable Java Runtime environment (JRE) is installed with Java Native
Access (JNA) by including `cassandra::java`. This need to be executed
before the Cassandra service is started.
```puppet
node /^node\d+$/ {
class { 'cassandra::datastax_repo':
before => Class['cassandra']
}
class { 'cassandra::java':
before => Class['cassandra']
}
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
endpoint_snitch => 'GossipingPropertyFileSnitch',
listen_interface => "eth1",
num_tokens => 256,
seeds => '110.82.155.0,110.82.156.3',
auto_bootstrap => false
}
}
```
The default value for the num_tokens is already 256, but it is
included in the example for clarity. Do not forget to either
set auto_bootstrap to true or not set the parameter at all
after initializing the cluster.
### Create a Cluster in Multiple Data Centers
To continue with the examples provided by DataStax, we look at the example
for a cluster across multiple data centers
<http://docs.datastax.com/en/cassandra/2.2/cassandra/initialize/initMultipleDS.html>.
**Node Name** | **IP Address** | **Data Center** | **Rack** |
---------------|----------------|-----------------|----------|
node0 (seed 1) | 10.168.66.41 | DC1 | RAC1 |
node1 | 10.176.43.66 | DC1 | RAC1 |
node2 | 10.168.247.41 | DC1 | RAC1 |
node3 (seed 2) | 10.176.170.59 | DC2 | RAC1 |
node4 | 10.169.61.170 | DC2 | RAC1 |
node5 | 10.169.30.138 | DC2 | RAC1 |
For the sake of simplicity, we will confine this example to the nodes:
```puppet
node /^node[012]$/ {
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
endpoint_snitch => 'GossipingPropertyFileSnitch',
listen_address => "${::ipaddress}",
num_tokens => 256,
seeds => '10.168.66.41,10.176.170.59',
dc => 'DC1',
auto_bootstrap => false
}
}
node /^node[345]$/ {
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
endpoint_snitch => 'GossipingPropertyFileSnitch',
listen_address => "${::ipaddress}",
num_tokens => 256,
seeds => '10.168.66.41,10.176.170.59',
dc => 'DC2',
auto_bootstrap => false
}
}
```
We don't need to specify the rack name (with the rack parameter) as RAC1 is
the default value. Again, do not forget to either set auto_bootstrap to
true or not set the parameter at all after initializing the cluster.
### OpsCenter
To continue with the original example within a single data center, say we
have an instance of OpsCenter running on a node called opscenter which has
an IP address of 110.82.157.6. We add the `cassandra::datastax_agent` to
the cassandra node to connect to OpsCenter:
```puppet
node /^node\d+$/ {
class { 'cassandra::datastax_repo':
before => Class['cassandra']
} ->
class { 'cassandra::java':
before => Class['cassandra']
} ->
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
endpoint_snitch => 'GossipingPropertyFileSnitch',
listen_address => "${::ipaddress}",
num_tokens => 256,
seeds => '110.82.155.0,110.82.156.3',
before => Class['cassandra::datastax_agent']
} ->
class { 'cassandra::datastax_agent':
stomp_interface => '110.82.157.6'
}
}
node /opscenter/ {
include '::cassandra::datastax_repo' ->
include '::cassandra' ->
include '::cassandra::opscenter'
}
```
We have also added the `cassandra::opscenter` class for the opscenter node.
### DataStax Enterprise
After configuring the relevant repository, the following snippet works on
CentOS 7 to install DSE Cassandra 4.7.0:
```puppet
class { 'cassandra::datastax_repo':
descr => 'DataStax Repo for DataStax Enterprise',
pkg_url => 'https://username:password@rpm.datastax.com/enterprise',
before => Class['cassandra'],
}
class { 'cassandra':
cluster_name => 'MyCassandraCluster',
config_path => '/etc/dse/cassandra',
package_ensure => '4.7.0-1',
package_name => 'dse-full',
service_name => 'dse',
service_systemd => true
}
```
Also with DSE, one can specify a remote keyspace for storing the metrics for
a cluster. An example is:
```puppet
cassandra::opscenter::cluster_name { 'Cluster1':
cassandra_seed_hosts => 'host1,host2',
storage_cassandra_username => 'opsusr',
storage_cassandra_password => 'opscenter',
storage_cassandra_api_port => 9160,
storage_cassandra_cql_port => 9042,
storage_cassandra_keyspace => 'OpsCenter_Cluster1'
}
```
## Reference
### Public Classes
* [cassandra](#class-cassandra)
* [cassandra::datastax_agent](#class-cassandradatastax_agent)
* [cassandra::datastax_repo](#class-cassandradatastax_repo)
* [cassandra::firewall_ports](#class-cassandrafirewall_ports)
* [cassandra::java](#class-cassandrajava)
* [cassandra::opscenter](#class-cassandraopscenter)
* [cassandra::opscenter::pycrypto](#class-cassandraopscenterpycrypto)
* [cassandra::optutils](#class-cassandraoptutils)
### Public Defined Types
* [cassandra::opscenter::cluster_name](#defined-type-cassandraopscentercluster_name)
### Private Defined Types
* cassandra::private::data_directory
* cassandra::private::firewall_ports::rule
* cassandra::private::opscenter::setting
### Class: cassandra
A class for installing the Cassandra package and manipulate settings in the
configuration file.
#### Parameters
##### `authenticator`
Authentication backend, implementing IAuthenticator; used to identify users.
Out of the box, Cassandra provides
org.apache.cassandra.auth.{AllowAllAuthenticator, PasswordAuthenticator}.
* AllowAllAuthenticator performs no checks - set it to disable authentication.
* PasswordAuthenticator relies on username/password pairs to authenticate
users. It keeps usernames and hashed passwords in system_auth.credentials
table. Please increase system_auth keyspace replication factor if you use
this authenticator.
Default value: 'AllowAllAuthenticator.
##### `authorizer`
Authorization backend, implementing IAuthorizer; used to limit access/provide
permissions. Out of the box, Cassandra provides
org.apache.cassandra.auth.{AllowAllAuthorizer, CassandraAuthorizer}.
- AllowAllAuthorizer allows any action to any user - set it to disable
authorization.
- CassandraAuthorizer stores permissions in system_auth.permissions table.
Please increase system_auth keyspace replication factor if you use this
authorizer.
Default value: 'AllowAllAuthorizer'
##### `auto_bootstrap`
This setting if set to true makes new (non-seed) nodes automatically migrate
the right data to themselves. When initializing a fresh cluster without data,
set this value to false. If left at the default value of *undef* then the
entry in the configuration file is absent or commented out. If a value is
set, then the parameter and variable are placed into the configuration file.
Default value: *undef*
##### `auto_snapshot`
Whether or not a snapshot is taken of the data before keyspace truncation
or dropping of column families. The STRONGLY advised default of true
should be used to provide data safety. If you set this flag to false, you will
lose data on truncation or drop.
Default value **true**
##### `batchlog_replay_throttle_in_kb`
Maximum throttle in KBs per second, total. This will be reduced proportionally
to the number of nodes in the cluster.
Default value: '1024'
##### `batch_size_warn_threshold_in_kb`
Log WARN on any batch size exceeding this value. 5kb per batch by default.
Caution should be taken on increasing the size of this threshold as it can
lead to node instability.
Default value 5
##### `broadcast_address`
Address to broadcast to other Cassandra nodes. Leaving this value as the
default will set it to the same value as `listen_address`.
Default value: *undef*
##### `broadcast_rpc_address`
RPC address to broadcast to drivers and other Cassandra nodes. This cannot
be set to 0.0.0.0. If left as the default value it will be set to the value
of `rpc_address`. If `rpc_address` is set to 0.0.0.0, broadcast_rpc_address
must be set.
Default value: *undef*
##### `cas_contention_timeout_in_ms`
How long a coordinator should continue to retry a CAS operation
that contends with other proposals for the same row.
Default value: '1000'
##### `cassandra_9822`
If set to true, this will apply a patch to the init file for the Cassandra
service as a workaround for
[CASSANDRA-9822](https://issues.apache.org/jira/browse/CASSANDRA-9822). This
option is silently ignored on the Red Hat family of operating systems as
this bug only affects Ubuntu systems.
Default value 'false'
##### `cassandra_yaml_tmpl`
The path to the Puppet template for the Cassandra configuration file. This
allows the user to supply their own customized template. A Cassandra 1.X
compatible template called cassandra1.yaml.erb has been provided by @Spredzy.
Default value 'cassandra/cassandra.yaml.erb'
##### `client_encryption_algorithm`
Sets `client_encryption_options -> algorithm`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_cipher_suites`
Sets `client_encryption_options -> cipher_suites`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`.
##### `client_encryption_enabled`
Sets `client_encryption_options -> enabled`.
Default value 'false'
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_keystore`
Sets `client_encryption_options -> keystore`.
Default value 'conf/.keystore'
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_keystore_password`
Sets `client_encryption_options -> keystore_password`.
Default value 'cassandra'
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_protocol`
Sets `client_encryption_options -> protocol`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_require_client_auth`
Sets `client_encryption_options -> require_client_auth`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_store_type`
Sets `client_encryption_options -> store_type`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_cipher_suites`.
##### `client_encryption_truststore`
Sets `client_encryption_options -> truststore`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore_password`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `client_encryption_truststore_password`
Sets `client_encryption_options -> truststore_password`.
Default value: *undef*
Part of the client encryption options. See also
`client_encryption_algorithm`,
`client_encryption_enabled`,
`client_encryption_keystore`,
`client_encryption_keystore_password`,
`client_encryption_require_client_auth`,
`client_encryption_truststore`,
`client_encryption_protocol`,
`client_encryption_store_type`,
`client_encryption_cipher_suites`.
##### `cluster_name`
The name of the cluster. This is mainly used to prevent machines in one
logical cluster from joining another.
Default value 'Test Cluster'
##### `column_index_size_in_kb`
Granularity of the collation index of rows within a partition.
Increase if your rows are large, or if you have a very large
number of rows per partition. The competing goals are these:
1. a smaller granularity means more index entries are generated
and looking up rows withing the partition by collation column
is faster
2. but, Cassandra will keep the collation index in memory for hot
rows (as part of the key cache), so a larger granularity means
you can cache more hot rows
Default value: '64'
##### `commit_failure_policy`
Policy for commit disk failures:
* die: shut down gossip and Thrift and kill the JVM, so the node can be replaced.
* stop: shut down gossip and Thrift, leaving the node effectively dead, but
can still be inspected via JMX.
* stop_commit: shutdown the commit log, letting writes collect but
continuing to service reads, as in pre-2.0.5 Cassandra
* ignore: ignore fatal errors and let the batches fail
Default value: 'stop'
##### `commitlog_directory`
When running on magnetic HDD, this should be a separate spindle than the data
directories.
Default value '/var/lib/cassandra/commitlog'
See also `data_file_directories` and `saved_caches_directory`.
##### `commitlog_directory_mode`
The mode for the directory specified in `commitlog_directory`.
Default value '0750'
##### `commitlog_segment_size_in_mb`
The size of the individual commitlog file segments. A commitlog
segment may be archived, deleted, or recycled once all the data
in it (potentially from each columnfamily in the system) has been
flushed to sstables.
The default size is 32, which is almost always fine, but if you are
archiving commitlog segments (see commitlog_archiving.properties),
then you probably want a finer granularity of archiving; 8 or 16 MB
is reasonable.
Default value: 32
##### `commitlog_sync`
May be either "periodic" or "batch." When in batch mode, Cassandra won't ack
writes until the commit log has been fsynced to disk. It will wait up to
commitlog_sync_batch_window_in_ms milliseconds for other writes, before
performing the sync.
Default value: 'periodic'
See also `commitlog_sync_batch_window_in_ms` and `commitlog_sync_period_in_ms`.
##### `commitlog_sync_batch_window_in_ms`
If `commitlog_sync` is set to 'batch' then this value should be set.
Otherwise it should be set to *undef*.
Default value: *undef*
##### `commitlog_sync_period_in_ms`
If `commitlog_sync` is set to 'periodic' then this value should be set.
Otherwise it should be set to *undef*.
Default value: 10000
##### `commitlog_total_space_in_mb`
Total space to use for commitlogs. Since commitlog segments are
mmapped, and hence use up address space, the default size is 32
on 32-bit JVMs, and 8192 on 64-bit JVMs (calculated automatically by
cassandra if the module setting is left at *undef*).
If space gets above this value (it will round up to the next nearest
segment multiple), Cassandra will flush every dirty CF in the oldest
segment and remove it. So a small total commitlog space will tend
to cause more flush activity on less-active columnfamilies.
Default value: *undef*
##### `compaction_throughput_mb_per_sec`
Throttles compaction to the given total throughput across the entire
system. The faster you insert data, the faster you need to compact in
order to keep the sstable count down, but in general, setting this to
16 to 32 times the rate you are inserting data is more than sufficient.
Setting this to 0 disables throttling. Note that this accounts for all types
of compaction, including validation compaction.
Default value: '16'
##### `concurrent_counter_writes`
For workloads with more data than can fit in memory, Cassandra's
bottleneck will be reads that need to fetch data from
disk. `concurrent_reads` should be set to (16 * number_of_drives) in
order to allow the operations to enqueue low enough in the stack
that the OS and drives can reorder them. Same applies to
`concurrent_counter_writes`, since counter writes read the current
values before incrementing and writing them back.
On the other hand, since writes are almost never IO bound, the ideal
number of `concurrent_writes` is dependent on the number of cores in
your system; (8 * number_of_cores) is a good rule of thumb.
Default value '32'
##### `concurrent_reads`
See `concurrent_counter_writes`.
Default value '32'
##### `concurrent_writes`
See `concurrent_counter_writes`.
Default value '32'
##### `config_file_mode`
The permissions mode of the cassandra configuration file.
Default value '0644'
##### `config_path`
The path to the cassandra configuration file. If this is undef, it will be
changed to **/etc/cassandra/default.conf** on the Red Hat family of operating
systems or **/etc/cassandra** on Ubuntu. Otherwise the user can specify the
path name.
Default value *undef*
##### `concurrent_compactors`
Number of simultaneous compactions to allow, NOT including
validation "compactions" for anti-entropy repair. Simultaneous
compactions can help preserve read performance in a mixed read/write
workload, by mitigating the tendency of small sstables to accumulate
during a single long running compactions. The default (*undef*) is usually
fine and if you experience problems with compaction running too
slowly or too fast, you should look at
`compaction_throughput_mb_per_sec` first.
`concurrent_compactors` defaults to the smaller of (number of disks,
number of cores), with a minimum of 2 and a maximum of 8.
If your data directories are backed by SSD, you should increase this
to the number of cores.
Default value: *undef*
##### `counter_cache_save_period`
Duration in seconds after which Cassandra should save the counter cache (keys
only). Caches are saved to saved_caches_directory as specified in this
configuration file.
Default value: '7200' (2 hours)
##### `counter_cache_keys_to_save`
Number of keys from the counter cache to save. Disabled by default
(*undef*), meaning all keys are going to be saved.
Default value: *undef*
##### `counter_cache_size_in_mb`
Maximum size of the counter cache in memory.
Counter cache helps to reduce counter locks' contention for hot counter cells.
In case of RF = 1 a counter cache hit will cause Cassandra to skip the read
before write entirely. With RF > 1 a counter cache hit will still help to
reduce the duration of the lock hold, helping with hot counter cell updates,
but will not allow skipping the read entirely. Only the local (clock, count)
tuple of a counter cell is kept in memory, not the whole counter, so it's
relatively cheap.
NOTE: if you reduce the size, you may not get you hottest keys loaded on
startup.
Default value is empty to make it "auto" (min(2.5% of Heap (in MB), 50MB)).
Set to 0 to disable counter cache. NOTE: if you perform counter deletes and
rely on low gcgs, you should disable the counter cache.
Default value: ''
##### `counter_write_request_timeout_in_ms`
How long the coordinator should wait for counter writes to complete.
Default value: '5000'
##### `cross_node_timeout`
Enable operation timeout information exchange between nodes to accurately
measure request timeouts. If disabled, replicas will assume that requests
were forwarded to them instantly by the coordinator, which means that
under overload conditions we will waste that much extra time processing
already-timed-out requests.
Warning: before enabling this property make sure that ntp is installed
and the times are synchronized between the nodes.
Default value: 'false'
##### `data_file_directories`
Directories where Cassandra should store data on disk. Cassandra
will spread data evenly across them, subject to the granularity of
the configured compaction strategy.
Default value '['/var/lib/cassandra/data']'
See also `commitlog_directory` and `saved_caches_directory`.
##### `data_file_directories_mode`
The mode for the directories specified in `data_file_directories`.
Default value '0750'
##### `dc`
Sets the value for dc in *config_path*/*snitch_properties_file* see
http://docs.datastax.com/en/cassandra/2.1/cassandra/architecture/architectureSnitchesAbout_c.html
for more details.
Default value 'DC1'
##### `dc_suffix`
Sets the value for dc_suffix in *config_path*/*snitch_properties_file* see
http://docs.datastax.com/en/cassandra/2.1/cassandra/architecture/architectureSnitchesAbout_c.html
for more details. If the value is *undef* then change will be made to the
snitch properties file for this setting.
Default value *undef*
##### `disk_failure_policy`
Policy for data disk failures:
* die: shut down gossip and Thrift and kill the JVM for any fs errors or
single-sstable errors, so the node can be replaced.
* stop_paranoid: shut down gossip and Thrift even for single-sstable errors.
* stop: shut down gossip and Thrift, leaving the node effectively dead, but
can still be inspected via JMX.
* best_effort: stop using the failed disk and respond to requests based on
remaining available sstables. This means you WILL see obsolete
data at CL.ONE!
* ignore: ignore fatal errors and let requests fail, as in pre-1.2 Cassandra
Default value 'stop'
##### `dynamic_snitch_badness_threshold`
if set greater than zero and read_repair_chance is < 1.0, this will allow
'pinning' of replicas to hosts in order to increase cache capacity.
The badness threshold will control how much worse the pinned host has to be
before the dynamic snitch will prefer other replicas over it. This is
expressed as a double which represents a percentage. Thus, a value of
0.2 means Cassandra would continue to prefer the static snitch values
until the pinned host was 20% worse than the fastest.
Default value: '0.1'
##### `dynamic_snitch_reset_interval_in_ms`
Controls how often to reset all host scores, allowing a bad host to
possibly recover.
Default value: '600000'
##### `dynamic_snitch_update_interval_in_ms`
Controls how often to perform the more expensive part of host score calculation.
Default value: '100'
##### `endpoint_snitch`
Set this to a class that implements IEndpointSnitch. The snitch has two functions:
1. It teaches Cassandra enough about your network topology to route requests
efficiently.
2. It allows Cassandra to spread replicas around your cluster to avoid
correlated failures. It does this by grouping machines into
"datacenters" and "racks." Cassandra will do its best not to have
more than one replica on the same "rack" (which may not actually
be a physical location)
IF YOU CHANGE THE SNITCH AFTER DATA IS INSERTED INTO THE CLUSTER,
YOU MUST RUN A FULL REPAIR, SINCE THE SNITCH AFFECTS WHERE REPLICAS
ARE PLACED.
Out of the box, Cassandra provides:
* SimpleSnitch:
Treats Strategy order as proximity. This can improve cache
locality when disabling read repair. Only appropriate for
single-datacenter deployments.
* GossipingPropertyFileSnitch:
This should be your go-to snitch for production use. The rack
and datacenter for the local node are defined in
cassandra-rackdc.properties and propagated to other nodes via
gossip. If cassandra-topology.properties exists, it is used as a
fallback, allowing migration from the PropertyFileSnitch.
* PropertyFileSnitch:
Proximity is determined by rack and data center, which are
explicitly configured in cassandra-topology.properties.
* Ec2Snitch:
Appropriate for EC2 deployments in a single Region. Loads Region
and Availability Zone information from the EC2 API. The Region is
treated as the datacenter, and the Availability Zone as the rack.
Only private IPs are used, so this will not work across multiple
Regions.
* Ec2MultiRegionSnitch:
Uses public IPs as broadcast_address to allow cross-region
connectivity. (Thus, you should set seed addresses to the public
IP as well.) You will need to open the storage_port or
ssl_storage_port on the public IP firewall. (For intra-Region
traffic, Cassandra will switch to the private IP after
establishing a connection.)
* RackInferringSnitch:
Proximity is determined by rack and data center, which are
assumed to correspond to the 3rd and 2nd octet of each node's IP
address, respectively. Unless this happens to match your
deployment conventions, this is best used as an example of
writing a custom Snitch class and is provided in that spirit.
You can use a custom Snitch by setting this to the full class name
of the snitch, which will be assumed to be on your classpath.
Default value 'SimpleSnitch'
##### `fail_on_non_supported_os`
A flag that dictates if the module should fail if it is not RedHat or Debian.
If you set this option to false then you must also at least set the
`config_path` parameter as well.
Default value 'true'
##### `file_cache_size_in_mb`
Total memory to use for sstable-reading buffers. If omitted defaults to
the smaller of 1/4 of heap or 512MB.
Default value: *undef*
##### `hinted_handoff_enabled`
See http://wiki.apache.org/cassandra/HintedHandoff
May either be "true" or "false" to enable globally, or contain a list
of data centers to enable per-datacenter (e.g. DC1,DC2).
Default value 'true'
##### `hinted_handoff_throttle_in_kb`
Maximum throttle in KBs per second, per delivery thread. This will be
reduced proportionally to the number of nodes in the cluster. (If there
are two nodes in the cluster, each delivery thread will use the maximum
rate; if there are three, each will throttle to half of the maximum,
since we expect two nodes to be delivering hints simultaneously.)
Default value: '1024'
##### `index_summary_capacity_in_mb`
A fixed memory pool size in MB for for SSTable index summaries. If left
empty, this will default to 5% of the heap size. If the memory usage of
all index summaries exceeds this limit, SSTables with low read rates will
shrink their index summaries in order to meet this limit. However, this
is a best-effort process. In extreme conditions Cassandra may need to use
more than this amount of memory.
Default value: ''
##### `index_summary_resize_interval_in_minutes`
How frequently index summaries should be resampled. This is done
periodically to redistribute memory from the fixed-size pool to sstables
proportional their recent read rates. Setting to -1 will disable this
process, leaving existing index summaries at their current sampling level.
Default value: '60'
##### `incremental_backups`
Set to true to have Cassandra create a hard link to each sstable
flushed or streamed locally in a backups/ subdirectory of the
keyspace data. Removing these links is the operator's
responsibility.
Default value 'false'
##### `initial_token`
Allows you to specify tokens manually. While you can use
it with vnodes (num_tokens > 1, above) - in which case you should provide a
comma-separated list - it's primarily used when adding nodes
to legacy clusters that do not have vnodes enabled.
Default value: *undef*
##### `inter_dc_tcp_nodelay`
Enable or disable tcp_nodelay for inter-dc communication.
Disabling it will result in larger (but fewer) network packets being sent,
reducing overhead from the TCP protocol itself, at the cost of increasing
latency if you block for cross-datacenter responses.
Default value: 'false'
##### `internode_authenticator`
Internode authentication backend, implementing IInternodeAuthenticator;
used to allow/disallow connections from peer nodes.
Default value: *undef*
##### `internode_compression`
Controls whether traffic between nodes is compressed. Can be:
* all - all traffic is compressed
* dc - traffic between different datacenters is compressed
* none - nothing is compressed.
Default value 'all'
##### `internode_recv_buff_size_in_bytes`
Change from the default to set socket buffer size for internode communication
Note that when setting this, the buffer size is limited by net.core.wmem_max
and when not setting it it is defined by net.ipv4.tcp_wmem
See:
* /proc/sys/net/core/wmem_max
* /proc/sys/net/core/rmem_max
* /proc/sys/net/ipv4/tcp_wmem
* /proc/sys/net/ipv4/tcp_wmem
and: man tcp
Default value: *undef*
##### `internode_send_buff_size_in_bytes`
See `internode_recv_buff_size_in_bytes`.
Default value: *undef*
##### `key_cache_save_period`
Duration in seconds after which Cassandra should
save the key cache. Caches are saved to saved_caches_directory as
specified in this configuration file.
Saved caches greatly improve cold-start speeds, and is relatively cheap in
terms of I/O for the key cache. Row cache saving is much more expensive and
has limited use.
Default value: 14400 (4 hours)
##### `key_cache_size_in_mb`
Default value is empty to make it "auto" (min(5% of Heap (in MB), 100MB)). Set
to 0 to disable key cache.
Default value: ''
##### `key_cache_keys_to_save`
Number of keys from the key cache to save. Disabled by default, meaning all
keys are going to be saved.
Default value: *undef*
##### `listen_address`
Address or interface to bind to and tell other Cassandra nodes to connect to.
You **MUST** change this if you want multiple nodes to be able to communicate!
Set `listen_address` OR `listen_interface`, not both. Interfaces must correspond
to a single address, IP aliasing is not supported.
Leaving it blank leaves it up to InetAddress.getLocalHost(). This
will always do the Right Thing _if_ the node is properly configured
(hostname, name resolution, etc), and the Right Thing is to use the
address associated with the hostname (it might not be).
Setting listen_address to 0.0.0.0 is always wrong.
Default value 'localhost'
##### `listen_interface`
Setting this to any value effectively means that `listen_address` address
is ignored.
Default value *undef*
##### `manage_dsc_repo`
DEPRECATION WARNING: This option is deprecated. Please include the
the ::cassandra::datastax_repo instead.
If set to true then a repository will be setup so that packages can be
downloaded from DataStax community.
Default value 'false'
##### `max_hints_delivery_threads`
Number of threads with which to deliver hints; Consider increasing this number
when you have multi-dc deployments, since cross-dc handoff tends to be slower.
Default value: '2'
##### `max_hint_window_in_ms`
Defines the maximum amount of time a dead host will have hints
generated. After it has been dead this long, new hints for it will not be
created until it has been seen alive and gone down again.
Default value: '10800000'
##### `memory_allocator`
The off-heap memory allocator. Affects storage engine metadata as
well as caches. Experiments show that JEMAlloc saves some memory
than the native GCC allocator (i.e., JEMalloc is more
fragmentation-resistant).
Supported values are:
* NativeAllocator
* JEMallocAllocator
If you intend to use JEMallocAllocator you have to install JEMalloc as library and
modify cassandra-env.sh as directed in the file.
If left as the default, NativeAllocator is assumed.
Default value: *undef*
##### `memtable_cleanup_threshold`
Ratio of occupied non-flushing memtable size to total permitted size
that will trigger a flush of the largest memtable. Lager mct will
mean larger flushes and hence less compaction, but also less concurrent
flush activity which can make it difficult to keep your disks fed
under heavy write load.
If not set, `memtable_cleanup_threshold` defaults to 1 / (`memtable_flush_writers` + 1)
Default value: *undef*
##### `memtable_flush_writers`
This sets the amount of memtable flush writer threads. These will
be blocked by disk io, and each one will hold a memtable in memory
while blocked.
If omitted is to set to the smaller of (number of disks,
number of cores), with a minimum of 2 and a maximum of 8.
If your data directories are backed by SSD, you should increase this
to the number of cores.
Default value: *undef*
##### `memtable_heap_space_in_mb`
Total permitted memory to use for memtables. Cassandra will stop
accepting writes when the limit is exceeded until a flush completes,
and will trigger a flush based on `memtable_cleanup_threshold`
If omitted, Cassandra will set both to 1/4 the size of the heap.
Default value: *undef*
##### `memtable_offheap_space_in_mb`
If omitted defaults to 1/4 heap. See `memtable_heap_space_in_mb`.
Default value: *undef*
##### `native_transport_max_concurrent_connections`
The maximum number of concurrent client connections. The assumed default is -1
when omitted, which means unlimited.
Default value: *undef*
##### `native_transport_max_concurrent_connections_per_ip`
The maximum number of concurrent client connections per source ip.
The assumed default is -1 when omitted, which means unlimited.
Default value: *undef*
##### `native_transport_max_frame_size_in_mb`
The maximum size of allowed frame. Frame (requests) larger than this will
be rejected as invalid. The assumed default is 256MB when omitted.
Default value: *undef*
##### `native_transport_max_threads`
The maximum threads for handling requests when the native transport is used.
This is similar to `rpc_max_threads` though the default differs slightly (and
there is no native_transport_min_threads, idle threads will always be stopped
after 30 seconds).
Default value: *undef*
##### `native_transport_port`
Port for the CQL native transport to listen for clients on. For security
reasons, you should not expose this port to the internet. Firewall it if needed.
Default value '9042'
##### `num_tokens`
This defines the number of tokens randomly assigned to this node on the ring
The more tokens, relative to other nodes, the larger the proportion of data
that this node will store. You probably want all nodes to have the same number
of tokens assuming they have equal hardware capability.
If you leave this unspecified, Cassandra will use the default of 1 token for legacy compatibility,
and will use the `initial_token` as described below.
Specifying `initial_token` will override this setting on the node's initial start,
on subsequent starts, this setting will apply even if initial token is set.
If you already have a cluster with 1 token per node, and wish to migrate to
multiple tokens per node, see http://wiki.apache.org/cassandra/Operations
Default value '256'
##### `package_ensure`
The status of the package specified in **package_name**. Can be
*present*, *latest* or a specific version number.
Default value 'present'
##### `package_name`
The name of the Cassandra package which must be available from a repository.
If this is *undef*, it will be changed to **cassandra22** on the Red Hat family
of operating systems or **cassandra** on Debian. Otherwise the user can
specify the package name.
Default value *undef*
##### `partitioner`
The partitioner is responsible for distributing groups of rows (by
partition key) across nodes in the cluster. You should leave this
alone for new clusters. The partitioner can NOT be changed without
reloading all data, so when upgrading you should set this to the
same partitioner you were already using.
Besides Murmur3Partitioner, partitioners included for backwards
compatibility include RandomPartitioner, ByteOrderedPartitioner, and
OrderPreservingPartitioner.
Default value 'org.apache.cassandra.dht.Murmur3Partitioner'
##### `permissions_update_interval_in_ms`
Refresh interval for permissions cache (if enabled).
After this interval, cache entries become eligible for refresh. Upon next
access, an async reload is scheduled and the old value returned until it
completes. If `permissions_validity_in_ms` is non-zero, then this must be
also.
If omitted defaults to the same value as `permissions_validity_in_ms`.
Default value: *undef*
##### `permissions_validity_in_ms`
Validity period for permissions cache (fetching permissions can be an
expensive operation depending on the authorizer, CassandraAuthorizer is
one example). Defaults to 2000, set to 0 to disable.
Will be disabled automatically for AllowAllAuthorizer.
Default value: '2000'
##### `phi_convict_threshold`
Phi value that must be reached for a host to be marked down.
Most users should never need to adjust this.
Default value: *undef*
##### `prefer_local`
Sets the value for prefer_local in *config_path*/*snitch_properties_file* see
http://docs.datastax.com/en/cassandra/2.1/cassandra/architecture/architectureSnitchesAbout_c.html
for more details. Valid values are true, false or *undef*. If the value is
*undef* then change will be made to the snitch properties file for this
setting.
Default value *undef*
##### `rack`
Sets the value for rack in *config_path*/*snitch_properties_file* see
http://docs.datastax.com/en/cassandra/2.1/cassandra/architecture/architectureSnitchesAbout_c.html
for more details.
Default value 'RAC1'
##### `range_request_timeout_in_ms`
How long the coordinator should wait for seq or index scans to complete.
Default value: '10000'
##### `read_request_timeout_in_ms`
How long the coordinator should wait for read operations to complete.
Default value: '5000'
##### `request_scheduler`
Set this to a class that implements RequestScheduler, which will schedule
incoming client requests according to the specific policy. This is useful for
multi-tenancy with a single Cassandra cluster.
NOTE: This is specifically for requests from the client and does not affect
inter node communication.
* org.apache.cassandra.scheduler.NoScheduler - No scheduling takes place
* org.apache.cassandra.scheduler.RoundRobinScheduler - Round robin of
client requests to a node with a separate queue for each
request_scheduler_id.
The scheduler is further customized by request_scheduler_options:
* NoScheduler - Has no options
* RoundRobin
* throttle_limit - The throttle_limit is the number of in-flight requests
per client. Requests beyond that limit are queued up until running requests
can complete. The value of 80 here is twice the number of
concurrent_reads + concurrent_writes.
* default_weight - default_weight is optional and allows for overriding the
default which is 1.
* weights - Weights are optional and will default to 1 or the overridden
default_weight. The weight translates into how many requests are handled
during each turn of the RoundRobin, based on the scheduler id.
Default value: 'org.apache.cassandra.scheduler.NoScheduler'
##### `request_scheduler_options_default_weight`
See `request_scheduler`.
Default value: *undef*
##### `request_scheduler_options_throttle_limit`
See `request_scheduler`.
Default value: *undef*
##### `request_timeout_in_ms`
How long the coordinator should wait for read operations to complete.
Default value: '10000'
##### `row_cache_keys_to_save`
Number of keys from the row cache to save. Disabled by default, meaning all
keys are going to be saved.
Default value: *undef*
##### `row_cache_save_period`
Duration in seconds after which Cassandra should
save the row cache. Caches are saved to saved_caches_directory as specified
in this configuration file.
Saved caches greatly improve cold-start speeds, and is relatively cheap in
terms of I/O for the key cache. Row cache saving is much more expensive and
has limited use.
Default value: '0' (disable saving the row cache)
##### `row_cache_size_in_mb`
Maximum size of the row cache in memory.
NOTE: if you reduce the size, you may not get you hottest keys loaded on startup.
Default value: '0' (disable row caching)
##### `rpc_address`
The address bind the Thrift RPC service and native transport server to.
Set rpc_address OR rpc_interface, not both. Interfaces must correspond
to a single address, IP aliasing is not supported.
Leaving rpc_address blank has the same effect as on listen_address
(i.e. it will be based on the configured hostname of the node).
Note that unlike listen_address, you can specify 0.0.0.0, but you must also
set broadcast_rpc_address to a value other than 0.0.0.0.
For security reasons, you should not expose this port to the internet. Firewall it if needed.
Default value 'localhost'
##### `rpc_interface`
Setting this to any value effectively means that `rpc_address` address
is ignored.
Default value: *undef*
##### `rpc_max_threads`
Set rpc_min|max_thread to set request pool size limits.
Regardless of your choice of RPC server (see `rpc_server_type`), the number of
maximum requests in the RPC thread pool dictates how many concurrent requests
are possible (but if you are using the sync RPC server, it also dictates the
number of clients that can be connected at all).
The default is unlimited and thus provides no protection against clients
overwhelming the server. You are encouraged to set a maximum that makes sense
for you in production, but do keep in mind that rpc_max_threads represents the
maximum number of client requests this server may execute concurrently.
Default value: *undef*
##### `rpc_min_threads`
See `rpc_max_threads`.
Default value: *undef*
##### `rpc_port`
Port for Thrift to listen for clients on.
Default value '9160'
##### `rpc_recv_buff_size_in_bytes`
Change from *undef* to set socket buffer sizes on rpc connections.
Default value: *undef*
##### `rpc_send_buff_size_in_bytes`
Change from *undef* to set socket buffer sizes on rpc connections.
Default value: *undef*
##### `rpc_server_type`
Cassandra provides two out-of-the-box options for the RPC Server:
* sync -> One thread per thrift connection. For a very large number of clients, memory
will be your limiting factor. On a 64 bit JVM, 180KB is the minimum stack size
per thread, and that will correspond to your use of virtual memory (but physical memory
may be limited depending on use of stack space).
* hsha -> Stands for "half synchronous, half asynchronous." All thrift clients are handled
asynchronously using a small number of threads that does not vary with the amount
of thrift clients (and thus scales well to many clients). The rpc requests are still
synchronous (one thread per active request). If hsha is selected then it is essential
that rpc_max_threads is changed from the default value of unlimited.
The default is sync because on Windows hsha is about 30% slower. On Linux,
sync/hsha performance is about the same, with hsha of course using less memory.
Alternatively, provide your own RPC server by providing the fully-qualified class name
of an o.a.c.t.TServerFactory that can create an instance of it.
Default value 'sync'
##### `saved_caches_directory`
Default value '/var/lib/cassandra/saved_caches'
See also `commitlog_directory` and `data_file_directories`.
##### `saved_caches_directory_mode`
The mode for the directory specified in `saved_caches_directory`.
Default value '0750'
##### `seeds`
The field being set is `seed_provider -> parameters -> seeds`.
Addresses of hosts that are deemed contact points. Cassandra nodes use this list
of hosts to find each other and learn the topology of the ring. You must change
this if you are running multiple nodes!
seeds is actually a comma-delimited list of addresses. Ex: "ip1,ip2,ip3"
See also `seed_provider_class_name`.
Default value '127.0.0.1'
##### `seed_provider_class_name`
The field being set is `seed_provider -> class_name`.
Any class that implements the SeedProvider interface and has a constructor
that takes a Map(String, String) of parameters will do.
See also `seeds`.
Default value 'org.apache.cassandra.locator.SimpleSeedProvider'
##### `server_encryption_algorithm`
The field being set is `server_encryption_options -> algorithm`.
This is part of the server encryption options. See also:
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value: *undef*
##### `server_encryption_cipher_suites`
The field being set is `server_encryption_options -> cipher_suites`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value: *undef*
##### `server_encryption_internode`
The field being set is `server_encryption_options -> internode_encryption`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value 'none'
##### `server_encryption_keystore`
The field being set is `server_encryption_options -> keystore`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value 'conf/.keystore'
##### `server_encryption_keystore_password`
The field being set is `server_encryption_options -> keystore_password`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value 'cassandra'
##### `server_encryption_protocol`
The field being set is `server_encryption_options -> protocol`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value: *undef*
##### `server_encryption_require_client_auth`
The field being set is `server_encryption_options -> require_client_auth`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_store_type`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value: *undef*
##### `server_encryption_store_type`
The field being set is `server_encryption_options -> store_type`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_truststore`,
`server_encryption_truststore_password`.
Default value: *undef*
##### `server_encryption_truststore`
The field being set is `server_encryption_options -> truststore`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore_password`.
Default value 'conf/.truststore'
##### `server_encryption_truststore_password`
This is passed to the
[cassandra.yaml](http://docs.datastax.com/en/cassandra/2.1/cassandra/configuration/configCassandra_yaml_r.html) file.
The field being set is `server_encryption_options -> truststore_password`.
This is part of the server encryption options. See also:
`server_encryption_algorithm`,
`server_encryption_cipher_suites`,
`server_encryption_internode`,
`server_encryption_keystore`,
`server_encryption_keystore_password`,
`server_encryption_protocol`,
`server_encryption_require_client_auth`,
`server_encryption_store_type`,
`server_encryption_truststore`.
Default value 'cassandra'
##### `service_enable`
Enable the Cassandra service to start at boot time. Valid values are true
or false.
Default value 'true'
##### `service_ensure`
Ensure the Cassandra service is running. Valid values are running or stopped.
Default value 'running'
##### `service_name`
The name of the service that runs the Cassandra software.
Default value 'cassandra'
##### `service_provider`
The name of the provider that runs the service. If left as *undef* then the OS family specific default will
be used, otherwise the specified value will be used instead.
Default value *undef*
##### `service_refresh`
If set to true, changes to the Cassandra config file or the data directories
will ensure that Cassandra service is refreshed after the changes. Setting
this flag to false will disable this behaviour, therefore allowing the changes
to be made but allow the user to control when the service is restarted.
Default value true
##### `service_systemd`
If set to true then a systemd service file called
/usr/lib/systemd/system/${*service_name*}.service will be added to the node with
basic settings to ensure that the Cassandra service interacts with systemd
better.
Default value false
##### `snapshot_before_compaction`
Whether or not to take a snapshot before each compaction. Be
careful using this option, since Cassandra won't clean up the
snapshots for you. Mostly useful if you're paranoid when there
is a data format change.
Default value 'false'
##### `snitch_properties_file`
The name of the snitch properties file. The full path name would be
*config_path*/*snitch_properties_file*.
Default value 'cassandra-rackdc.properties'
##### `ssl_storage_port`
SSL port, for encrypted communication. Unused unless enabled in
encryption_options For security reasons, you should not expose this port to
the internet. Firewall it if needed.
Default value '7001'
##### `sstable_preemptive_open_interval_in_mb`
When compacting, the replacement sstable(s) can be opened before they
are completely written, and used in place of the prior sstables for
any range that has been written. This helps to smoothly transfer reads
between the sstables, reducing page cache churn and keeping hot rows hot
Default value: '50'
##### `start_native_transport`
Whether to start the native transport server.
Please note that the address on which the native transport is bound is the
same as the rpc_address. The port however is different and specified below.
Default value 'true'
##### `start_rpc`
Whether to start the thrift rpc server.
Default value 'true'
##### `storage_port`
TCP port, for commands and data. For security reasons, you should not expose
this port to the internet. Firewall it if needed.
Default value '7000'
##### `streaming_socket_timeout_in_ms`
Enable socket timeout for streaming operation.
When a timeout occurs during streaming, streaming is retried from the start
of the current file. This _can_ involve re-streaming an important amount of
data, so you should avoid setting the value too low.
If omitted value is 0 is assumed, which never timeout streams.
Default value: *undef*
##### `tombstone_failure_threshold`
When executing a scan, within or across a partition, we need to keep the
tombstones seen in memory so we can return them to the coordinator, which
will use them to make sure other replicas also know about the deleted rows.
With workloads that generate a lot of tombstones, this can cause performance
problems and even exaust the server heap.
(http://www.datastax.com/dev/blog/cassandra-anti-patterns-queues-and-queue-like-datasets)
Adjust the thresholds here if you understand the dangers and want to
scan more tombstones anyway. These thresholds may also be adjusted at runtime
using the StorageService mbean.
See also `tombstone_warn_threshold`.
Default value: '100000'
##### `tombstone_warn_threshold`
See `tombstone_failure_threshold`.
Default value: '1000'
##### `trickle_fsync`
Whether to, when doing sequential writing, fsync() at intervals in
order to force the operating system to flush the dirty
buffers. Enable this to avoid sudden dirty buffer flushing from
impacting read latencies. Almost always a good idea on SSDs; not
necessarily on platters.
See also `trickle_fsync_interval_in_kb`
Default value: 'false'
##### `trickle_fsync_interval_in_kb`
See `trickle_fsync`.
Default value: '10240'
##### `truncate_request_timeout_in_ms`
How long the coordinator should wait for truncates to complete
(This can be much longer, because unless auto_snapshot is disabled
we need to flush first so we can snapshot before removing the data.)
Default value: '60000'
##### `write_request_timeout_in_ms`
How long the coordinator should wait for writes to complete.
Default value: '2000'
### Class: cassandra::datastax_agent
A class for installing the DataStax Agent and to point it at an OpsCenter
instance.
#### Parameters
##### `agent_alias`
If the value is changed from the default of *undef* then this is what is
set as the alias setting in
**/var/lib/datastax-agent/conf/address.yaml**
which is the name the agent announces itself to OpsCenter as.
Default value *undef*
##### `defaults_file`
The full path name to the file where `java_home` is set.
Default value '/etc/default/datastax-agent'
##### `java_home`
If the value of this variable is left as *undef*, no action is taken.
Otherwise the value is set as JAVA_HOME in `defaults_file`.
Default value *undef*
##### `package_ensure`
Is passed to the package reference. Valid values are **present** or a version
number.
Default value 'present'
##### `package_name`
Is passed to the package reference.
Default value 'datastax-agent'
##### `service_ensure`
Is passed to the service reference.
Default value 'running'
##### `service_enable`
Is passed to the service reference.
Default value 'true'
##### `service_name`
Is passed to the service reference.
Default value 'datastax-agent'
##### `service_provider`
The name of the provider that runs the service. If left as *undef* then the OS family specific default will
be used, otherwise the specified value will be used instead.
Default value *undef*
##### `stomp_interface`
If the value is changed from the default of *undef* then this is what is
set as the stomp_interface setting in
**/var/lib/datastax-agent/conf/address.yaml**
which connects the agent to an OpsCenter instance.
Default value *undef*
##### `local_interface`
If the value is changed from the default of *undef* then this is what is
set as the local_interface setting in
**/var/lib/datastax-agent/conf/address.yaml**
which is the address there the local cassandra will be contacted.
Default value *undef*
### Class: cassandra::datastax_repo
An optional class that will allow a suitable repository to be configured
from which packages for DataStax Community can be downloaded. Changing
the defaults will allow any Debian Apt or Red Hat Yum repository to be
configured.
#### Parameters
##### `descr`
On the Red Hat family, this is passed as the `descr` parameter to a
`yumrepo` resource. On the Debian family, it is passed as the `comment`
parameter to an `apt::source` resource.
Default value 'DataStax Repo for Apache Cassandra'
##### `key_id`
On the Debian family, this is passed as the `id` parameter to an `apt::key`
resource. On the Red Hat family, it is ignored.
Default value '7E41C00F85BFC1706C4FFFB3350200F2B999A372'
##### `key_url`
On the Debian family, this is passed as the `source` parameter to an
`apt::key` resource. On the Red Hat family, it is ignored.
Default value 'http://debian.datastax.com/debian/repo_key'
##### `pkg_url`
If left as the default, this will set the `baseurl` to
'http://rpm.datastax.com/community' on a `yumrepo` resource
on the Red Hat family. On the Debian family, leaving this as the default
will set the `location` parameter on an `apt::source` to
'http://debian.datastax.com/community'. Default value *undef*
##### `release`
On the Debian family, this is passed as the `release` parameter to an
`apt::source` resource. On the Red Hat family, it is ignored.
Default value 'stable'
### Class: cassandra::firewall_ports
An optional class to configure incoming network ports on the host that are
relevant to the Cassandra installation. If firewalls are being managed
already, simply do not include this module in your manifest.
IMPORTANT: The full list of which ports should be configured is assessed at
evaluation time of the configuration. Therefore if one is to use this class,
it must be the final cassandra class included in the manifest.
#### Parameters
##### `client_ports`
Only has any effect if the `cassandra` class is defined on the node.
Allow these TCP ports to be opened for traffic
coming from the client subnets.
Default value '[9042, 9160]'
##### `client_subnets`
Only has any effect if the `cassandra` class is defined on the node.
An array of the list of subnets that are to allowed connection to
cassandra::native_transport_port and cassandra::rpc_port.
Default value '['0.0.0.0/0']'
##### `inter_node_ports`
Only has any effect if the `cassandra` class is defined on the node.
Allow these TCP ports to be opened for traffic
between the Cassandra nodes.
Default value '[7000, 7001, 7199]'
##### `inter_node_subnets`
Only has any effect if the `cassandra` class is defined on the node.
An array of the list of subnets that are to allowed connection to
cassandra::storage_port, cassandra::ssl_storage_port and port 7199
for cassandra JMX monitoring.
Default value '['0.0.0.0/0']'
##### `inter_node_ports`
Allow these TCP ports to be opened for traffic
coming from OpsCenter subnets.
Default value '[7000, 7001, 7199]'
##### `public_ports`
Allow these TCP ports to be opened for traffic
coming from public subnets the port specified in `$ssh_port` will be
appended to this list.
Default value '[8888]'
##### `public_subnets`
An array of the list of subnets that are to allowed connection to
cassandra::firewall_ports::ssh_port and if cassandra::opscenter has been
included, both cassandra::opscenter::webserver_port and
cassandra::opscenter::webserver_ssl_port.
Default value '['0.0.0.0/0']'
##### `ssh_port`
Which port does SSH operate on.
Default value '22'
##### `opscenter_ports`
Only has any effect if the `cassandra::datastax_agent` or
`cassandra::opscenter` classes are defined.
Allow these TCP ports to be opened for traffic
coming to or from OpsCenter
appended to this list.
Default value '[61620, 61621]'
##### `opscenter_subnets`
A list of subnets that are to be allowed connection to
port 61620 for nodes built with cassandra::opscenter and 61621 for nodes
built with cassandra::datastax_agent.
Default value '['0.0.0.0/0']'
### Class: cassandra::java
A class to install an appropriate Java package.
#### Parameters
##### `ensure`
Is passed to the package reference for the JRE/JDK package. Valid values are
**present** or a version number.
Default value 'present'
##### `jna_ensure`
Is passed to the package reference for the JNA package. Valid values are
**present** or a version number.
Default value 'present'
##### `jna_package_name`
If the default value of *undef* is left as it is, then a package called
jna or libjna-java will be installed on a Red Hat family or Debian system
respectively. Alternatively, one can specify a package that is available in
a package repository to the node.
Default value *undef*
##### `package_name`
If the default value of *undef* is left as it is, then a package called
java-1.8.0-openjdk-headless or openjdk-7-jre-headless will be installed
on a Red Hat family or Debian system respectively. Alternatively, one
can specify a package that is available in a package repository to the
node.
Default value *undef*
### Class: cassandra::opscenter
This class installs and manages the DataStax OpsCenter. Leaving the defaults
as they are will provide a running OpsCenter without any authentication on
port 8888.
#### Parameters
##### `agents_agent_certfile`
This sets the agent_certfile setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_agent_keyfile`
This sets the agent_keyfile setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_agent_keyfile_raw`
This sets the agent_keyfile_raw setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_config_sleep`
This sets the config_sleep setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_fingerprint_throttle`
This sets the fingerprint_throttle setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_incoming_interface`
This sets the incoming_interface setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_incoming_port`
This sets the incoming_port setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_install_throttle`
This sets the install_throttle setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_not_seen_threshold`
This sets the not_seen_threshold setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_path_to_deb`
This sets the path_to_deb setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_path_to_find_java`
This sets the path_to_find_java setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_path_to_installscript`
This sets the path_to_installscript setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_path_to_rpm`
This sets the path_to_rpm setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_path_to_sudowrap`
This sets the path_to_sudowrap setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_reported_interface`
This sets the reported_interface setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_runs_sudo`
This sets the runs_sudo setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_scp_executable`
This sets the scp_executable setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_executable`
This sets the ssh_executable setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_keygen_executable`
This sets the ssh_keygen_executable setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_keyscan_executable`
This sets the ssh_keyscan_executable setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_port`
This sets the ssh_port setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_sys_known_hosts_file`
This sets the ssh_sys_known_hosts_file setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssh_user_known_hosts_file`
This sets the ssh_user_known_hosts_file setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssl_certfile`
This sets the ssl_certfile setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_ssl_keyfile`
This sets the ssl_keyfile setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_tmp_dir`
This sets the tmp_dir setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `agents_use_ssl`
This sets the use_ssl setting in the agents section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `authentication_audit_auth`
This sets the audit_auth setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `authentication_audit_pattern`
This sets the audit_pattern setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `authentication_method`
This sets the authentication_method setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `authentication_enabled`
This sets the enabled setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value 'False'
##### `authentication_passwd_db`
This sets the passwd_db setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `authentication_timeout`
This sets the timeout setting in the authentication section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `cloud_accepted_certs`
This sets the accepted_certs setting in the cloud section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `clusters_add_cluster_timeout`
This sets the add_cluster_timeout setting in the clusters section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `clusters_startup_sleep`
This sets the startup_sleep setting in the clusters section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `config_file`
The full path to the OpsCenter configuration file.
Default value '/etc/opscenter/opscenterd.conf'
##### `definitions_auto_update`
This sets the auto_update setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_definitions_dir`
This sets the definitions_dir setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_download_filename`
This sets the download_filename setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_download_host`
This sets the download_host setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_download_port`
This sets the download_port setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_hash_filename`
This sets the hash_filename setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_sleep`
This sets the sleep setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_ssl_certfile`
This sets the ssl_certfile setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `definitions_use_ssl`
This sets the use_ssl setting in the definitions section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ensure`
This is passed to the package reference for **opscenter**. Valid values are
**present** or a version number.
Default value 'present'
##### `failover_configuration_directory`
This sets the failover_configuration_directory setting in the failover section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `failover_heartbeat_fail_window`
This sets the heartbeat_fail_window setting in the failover section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `failover_heartbeat_period`
This sets the heartbeat_period setting in the failover section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `failover_heartbeat_reply_period`
This sets the heartbeat_reply_period setting in the failover section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `hadoop_base_job_tracker_proxy_port`
This sets the base_job_tracker_proxy_port setting in the hadoop section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_admin_group_name`
This sets the admin_group_name setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_connection_timeout`
This sets the connection_timeout setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_debug_ssl`
This sets the debug_ssl setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_group_name_attribute`
This sets the group_name_attribute setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_group_search_base`
This sets the group_search_base setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_group_search_filter`
This sets the group_search_filter setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_group_search_type`
This sets the group_search_type setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_ldap_security`
This sets the ldap_security setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_opt_referrals`
This sets the opt_referrals setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_protocol_version`
This sets the protocol_version setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_search_dn`
This sets the search_dn setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_search_password`
This sets the search_password setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_server_host`
This sets the server_host setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_server_port`
This sets the server_port setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_ssl_cacert`
This sets the ssl_cacert setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_ssl_cert`
This sets the ssl_cert setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_ssl_key`
This sets the ssl_key setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_tls_demand`
This sets the tls_demand setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_tls_reqcert`
This sets the tls_reqcert setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_uri_scheme`
This sets the uri_scheme setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_user_memberof_attribute`
This sets the user_memberof_attribute setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_user_search_base`
This sets the user_search_base setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ldap_user_search_filter`
This sets the user_search_filter setting in the ldap section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `logging_level`
This sets the level setting in the logging section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `logging_log_length`
This sets the log_length setting in the logging section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `logging_log_path`
This sets the log_path setting in the logging section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `logging_max_rotate`
This sets the max_rotate setting in the logging section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `logging_resource_usage_interval`
This sets the resource_usage_interval setting in the logging section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `package_name`
The name of the OpsCenter package.
Default value 'opscenter'
##### `provisioning_agent_install_timeout`
This sets the agent_install_timeout setting in the provisioning section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `provisioning_keyspace_timeout`
This sets the keyspace_timeout setting in the provisioning section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `provisioning_private_key_dir`
This sets the private_key_dir setting in the provisioning section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_alert_on_repair_failure`
This sets the alert_on_repair_failure setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_cluster_stabilization_period`
This sets the cluster_stabilization_period setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_error_logging_window`
This sets the error_logging_window setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_incremental_err_alert_threshold`
This sets the incremental_err_alert_threshold setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_incremental_range_repair`
This sets the incremental_range_repair setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_incremental_repair_tables`
This sets the incremental_repair_tables setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_ks_update_period`
This sets the ks_update_period setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_log_directory`
This sets the log_directory setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_log_length`
This sets the log_length setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_max_err_threshold`
This sets the max_err_threshold setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_max_parallel_repairs`
This sets the max_parallel_repairs setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_max_pending_repairs`
This sets the max_pending_repairs setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_max_rotate`
This sets the max_rotate setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_min_repair_time`
This sets the min_repair_time setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_min_throughput`
This sets the min_throughput setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_num_recent_throughputs`
This sets the num_recent_throughputs setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_persist_directory`
This sets the persist_directory setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_persist_period`
This sets the persist_period setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_restart_period`
This sets the restart_period setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_single_repair_timeout`
This sets the single_repair_timeout setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_single_task_err_threshold`
This sets the single_task_err_threshold setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `repair_service_snapshot_override`
This sets the snapshot_override setting in the repair_service section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `request_tracker_queue_size`
This sets the queue_size setting in the request_tracker section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `security_config_encryption_active`
This sets the config_encryption_active setting in the security section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `security_config_encryption_key_name`
This sets the config_encryption_key_name setting in the security section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `security_config_encryption_key_path`
This sets the config_encryption_key_path setting in the security section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `service_enable`
Enable the OpsCenter service to start at boot time. Valid values are true
or false.
Default value 'true'
##### `service_ensure`
Ensure the OpsCenter service is running. Valid values are running or stopped.
Default value 'running'
##### `service_name`
The name of the service that runs the OpsCenter software.
Default value 'opscenterd'
##### `service_provider`
The name of the provider that runs the service. If left as *undef* then the OS family specific default will
be used, otherwise the specified value will be used instead.
Default value *undef*
##### `spark_base_master_proxy_port`
This sets the base_master_proxy_port setting in the spark section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `stat_reporter_initial_sleep`
This sets the initial_sleep setting in the stat_reporter section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `stat_reporter_interval`
This sets the interval setting in the stat_reporter section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `stat_reporter_report_file`
This sets the report_file setting in the stat_reporter section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `stat_reporter_ssl_key`
This sets the ssl_key setting in the stat_reporter section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ui_default_api_timeout`
This sets the default_api_timeout setting in the ui section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ui_max_metrics_requests`
This sets the max_metrics_requests setting in the ui section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ui_node_detail_refresh_delay`
This sets the node_detail_refresh_delay setting in the ui section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `ui_storagemap_ttl`
This sets the storagemap_ttl setting in the ui section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_interface`
This sets the interface setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value '0.0.0.0'
##### `webserver_log_path`
This sets the log_path setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_port`
This sets the port setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value '8888'
##### `webserver_ssl_certfile`
This sets the ssl_certfile setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_ssl_keyfile`
This sets the ssl_keyfile setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_ssl_port`
This sets the ssl_port setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_staticdir`
This sets the staticdir setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_sub_process_timeout`
This sets the sub_process_timeout setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
##### `webserver_tarball_process_timeout`
This sets the tarball_process_timeout setting in the webserver section of the
OpsCenter configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscConfigProps_r.html
for more details. A value of *undef* will ensure the setting is not present
in the file. Default value *undef*
### Class: cassandra::opscenter::pycrypto
On the Red Hat family of operating systems, if one intends to use encryption
for configuration values then the pycrypto library is required. This class
will install it for the user. See
http://docs.datastax.com/en/opscenter/5.2//opsc/configure/installPycrypto.html
for more details.
This class has no effect when included on nodes that are not in the Red Hat
family.
#### Parameters
##### `ensure`
This is passed to the package reference for **pycrypto**. Valid values are
**present** or a version number.
Default value 'present'
##### `manage_epel`
If set to true, the **epel-release** package will be installed.
Default value 'false'
##### `package_name`
The name of the PyCrypto package.
Default value 'pycrypto'
##### `provider`
The name of the provider of the pycrypto package.
Default value 'pip'
##### `reqd_pckgs`
Packages that are required to install the pycrypto package.
Default value '['python-devel', 'python-pip' ]'
### Class: cassandra::optutils
A class to install the optional Cassandra tools package.
#### Parameters
##### `ensure`
Is passed to the package reference. Valid values are **present** or a version
number.
Default value 'present'
##### `package_name`
If the default value of *undef* is left as it is, then a package called
cassandra22-tools or cassandra-tools will be installed
on a Red Hat family or Debian system respectively. Alternatively, one
can specify a package that is available in a package repository to the
node.
Default value *undef*
### Defined Type cassandra::opscenter::cluster_name
With DataStax Enterprise, one can specify a remote keyspace for OpsCenter
to store metric data (this is not available in the DataStax Community Edition).
#### Parameters
##### `cassandra_seed_hosts`
This sets the seed_hosts setting in the cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_api_port`
This sets the api_port setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_bind_interface`
This sets the bind_interface setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_connection_pool_size`
This sets the connection_pool_size setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_connect_timeout`
This sets the connect_timeout setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_cql_port`
This sets the cql_port setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_keyspace`
This sets the keyspace setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_local_dc_pref`
This sets the local_dc_pref setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_password`
This sets the password setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_retry_delay`
This sets the retry_delay setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_seed_hosts`
This sets the seed_hosts setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_send_rpc`
This sets the send_rpc setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_ssl_ca_certs`
This sets the ssl_ca_certs setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_ssl_client_key`
This sets the ssl_client_key setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_ssl_client_pem`
This sets the ssl_client_pem setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_ssl_validate`
This sets the ssl_validate setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_used_hosts_per_remote_dc`
This sets the used_hosts_per_remote_dc setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
##### `storage_cassandra_username`
This sets the username setting in the storage_cassandra section of the
_cluster_name_.conf configuration file. See
http://docs.datastax.com/en/opscenter/5.2/opsc/configure/opscStoringCollectionDataDifferentCluster_t.html
for more details. A value of *undef* will ensure the setting is not
present in the file. Default value *undef*
### Defined Type cassandra::private::data_directory
A defined type to handle the `::cassandra::data_file_directoryies` array.
This is not intended to be used by a user but is documented here for
completeness.
#### Parameters
##### `title`
The name of an individual directory.
### Defined Type cassandra::private::firewall_ports::rule
A defined type to be used as a macro for setting host based firewall
rules. This is not intended to be used by a user (who should use the
API provided by cassandra::firewall_ports instead) but is documented
here for completeness.
#### Parameters
##### `title`
A text field that contains the protocol name and CIDR address of a subnet.
##### `port`
The number(s) of the port(s) to be opened.
### Defined Type cassandra::private::opscenter::setting
A defined type to be used as a macro for settings in the OpsCenter
configuration file. This is not intended to be used by a user (who
should use the API provided by cassandra::opscenter instead) but is documented
here for completeness.
#### Parameters
##### `service_name`
The name of the service to be notified if a change is made to the
configuration file. Typically this would by **opscenterd**.
##### `path`
The path to the configuration file. Typically this would by
**/etc/opscenter/opscenterd.conf**.
##### `section`
The section in the configuration file to be added to (e.g. **webserver**).
##### `setting`
The setting within the section of the configuration file to changed
(e.g. **port**).
##### `value`
The setting value to be changed to (e.g. **8888**).
## Limitations
Tested on the Red Hat family versions 6 and 7, Ubuntu 12.04 and 14.04,
Debian 7 Puppet (CE) 3.7.5 and DSC 2. Currently this module does not support
Cassandra 3 but this is planned for the near future.
From release 1.6.0 of this module, regular updates of the Cassandra 1.X
template will cease and testing against this template will cease. Testing
against the template for versions of Cassandra >= 2.X will continue.
## Contributers
Contributions will be gratefully accepted. Please go to the project page,
fork the project, make your changes locally and then raise a pull request.
Details on how to do this are available at
https://guides.github.com/activities/contributing-to-open-source.
Please also see the
[CONTRIBUTING.md](https://github.com/locp/cassandra/blob/master/CONTRIBUTING.md)
page for project specific requirements.
### Additional Contributers
* Yanis Guenane (GitHub [@spredzy](https://github.com/Spredzy)) provided the
Cassandra 1.x compatible template
(see [#11](https://github.com/locp/cassandra/pull/11)).
* Amos Shapira (GitHub [@amosshapira](https://github.com/amosshapira)) fixed
a bug in the requirements metadata that caused a problem with Puppetfile
(see [#34](https://github.com/locp/cassandra/pull/34)).
* Dylan Griffith (GitHub [@DylanGriffith](https://github.com/DylanGriffith))
identified that the dependency for puppetlabs-apt was incorrect
(see [#87](https://github.com/locp/cassandra/pull/87)).
* Sam Powers (GitHub [@sampowers](https://github.com/sampowers)) reported a
bug in the ability to set the running state of the Cassandra service and
subsequently submitted a pull request with a fix
(see [#93](https://github.com/locp/cassandra/issues/93)).
* [@markasammut](https://github.com/markasammut) contributed a pull request
to set the batch_size_warn_threshold_in_kb parameter (see
[#100](https://github.com/locp/cassandra/pull/100)).
* [@markasammut](https://github.com/markasammut) also contributed a pull
request to restart the service if the datastax-agent package is upgraded
(see [#110](https://github.com/locp/cassandra/pull/110)).
* Issues with the newly released Cassandra 3 were reported by
[@mantunovic](https://github.com/mantunovic) in
[#136](https://github.com/locp/cassandra/issues/136) with some excellent
help and advice from [@al4](https://github.com/al4). Thanks to both
Mladen and Alex for your feedback and constructive collaboration.
* Allowing the setting of the local_interface for the DataStax agent
configuration was submitted via a pull request
(see [#144](https://github.com/locp/cassandra/pull/144)) by
[@Mike-Petersen](https://github.com/Mike-Petersen).
* In the Cassandra class, the addition of the listen_interface and
rpc_interface parameters in
[#153](https://github.com/locp/cassandra/pull/153) were contributed by
Tom Taylor ([@t0mmyt](https://github.com/t0mmyt)).
* In the cassandra::datastax_agent the agent_alias parameter was
contributed by
Stuart Fox ([@stuartbfox](https://github.com/stuartbfox)).

File Metadata

Mime Type
text/plain
Expires
Sat, Jun 21, 8:03 PM (3 w, 1 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3356875

Event Timeline