Skip to content

Latest commit

 

History

History
132 lines (78 loc) · 6.92 KB

orchestration_config.markdown

File metadata and controls

132 lines (78 loc) · 6.92 KB
layout title subtitle canonical
default
PE 3.2 » Orchestration » Configuration
Configuring Orchestration
/pe/latest/orchestration_config.html

The Puppet Enterprise (PE) orchestration engine can be configured to enable new actions, modify existing actions, restrict actions, and prevent run failures on non-PE nodes.

Disabling Orchestration on Some Nodes

By default, Puppet Enterprise enables and configures orchestration on all agent nodes (including non-PE agents and devices). This is generally desirable, but the Puppet code that manages orchestration does not work on non-PE agent nodes, and will result in Puppet run failures on these nodes.

It is possible to disable orchestration when adding non-PE nodes. Note: Disabling orchestration on non-PE agents is not a supported configuration. To maintain a supported configuration, connect non-PE agents to a separate (unsupported) master.

To disable orchestration for a node, add the node to the special no mcollective group in the PE console. This will prevent PE from attempting to enable orchestration on that node. See here for instructions on adding nodes to groups in the console.

(The corresponding mcollective group is automatically managed — it contains all nodes that have not been added to the no mcollective group.)

If your infrastructure includes non-root agents, you also need to disable orchestration on these nodes.

Adding Actions

See the "Adding Actions" page of this manual.

Changing the Port Used by MCollective/ActiveMQ

You can change the port that MCollective/ActiveMQ uses with a simple variable change in the console.

  1. In the sidebar, select the mcollective group.
  2. On the mcollective group page, click Edit.
  3. Under Variables, in the key field, add fact_stomp_port, and in the value field, add the port number you want to use.
  4. Click Update.

Configuring Orchestration Plugins

Some MCollective agent plugins, including the default set included with Puppet Enterprise, have settings that can be configured.

Since the main orchestration configuration file is managed by Puppet Enterprise, you must put these settings in separate plugin config files, as described in the "Adding Actions" page of this manual.

Restricting Orchestration Actions

See the "Policy Files" heading in the "Adding Actions" page of this manual.

Unsupported Features

Adding New Orchestration Users and Integrating Applications

Adding new orchestration users is not supported in Puppet Enterprise 3.0. Future versions of PE may change the orchestration engine's authentication backend, which will block additional orchestration users from working until they are updated to use the new backend. We plan to include an easy method to add new orchestration users in a future version of PE.

In the meantime, if you need to add a new orchestration user in order to integrate an application with Puppet Enterprise, you can:

  • Obtain client credentials and a config file as described in the standard MCollective deployment guide.
  • Write a Puppet module to distribute the new client's public key into the ${pe_mcollective::params::mco_etc}/ssl/clients/ directory. This class must use include pe_mcollective to ensure that the directory can be located.
  • Assign that Puppet class to the mcollective group in the PE console.

Again, this process is unsupported and may require additional work during a future upgrade.

Configuring Subcollectives

Using multiple orchestration subcollectives with Puppet Enterprise is not currently supported, and requires modifying PE's internal modules. If you enable this feature, your changes will be reverted by future PE upgrades, and you will need to re-apply your changes after upgrading.

If you choose to enable this unsupported feature, you will need to modify, at minimum, the /opt/puppet/share/puppet/modules/pe_mcollective/templates/server.cfg.erb and /opt/puppet/share/puppet/modules/pe_mcollective/templates/activemq.xml.erb files on your puppet master server(s). Any such modifications will be reverted during a future PE upgrade.

Configuring Performance

ActiveMQ Heap Usage (Puppet Master Server Only)

The puppet master node runs an ActiveMQ server to route orchestration commands. By default, its process uses a Java heap size of 512 MB; this is the best value for mid-sized deployments, but can be a problem when building small proof-of-concept deployments on memory-starved VMs.

You can set a new heap size by doing the following:

  1. In the PE console, navigate to the special puppet_master group.
  2. On the puppet_master group page, click Edit.
  3. Under Variables, in the key field, add activemq_heap_mb, and in the value field add a new heap size to use (in MB).
  4. Click Update.

You can later delete the variable to revert to the default setting.

Registration Interval

By default, all agent nodes will send dummy registration messages over the orchestration middleware every ten minutes. We use these as a heartbeat to work around weaknesses in the underlying Stomp network protocol.

Most users shouldn't need to change this behavior, but you can adjust the frequency of the heartbeat messages as follows:

  1. In the PE console, navigate to the special mcollective group.
  2. On the mcollective group page, click Edit.
  3. Under Variables, in the key field, add mcollective_registerinterval, and in the value field add a new interval (in seconds).
  4. Click Update.

You can later delete the variable to revert to the default setting.

Orchestration SSL

By default, the orchestration engine uses SSL to encrypt all orchestration messages. You can disable this in order to investigate problems, but should never disable it in a production deployment where business-critical orchestration commands are being run.

To disable SSL:

  1. In the PE console, navigate to the mcollective group.
  2. On the mcollective group page, click Edit.
  3. Under Variables, in the key field, add mcollective_enable_stopmp_ssl, and in the value field add false.
  4. Click Update.

You can later delete the variable to revert to the default setting.