|
| 1 | +# Upgrade Puppet Enterprise with legacy compilers |
| 2 | + |
| 3 | +## What is a legacy compiler and a current compiler |
| 4 | + |
| 5 | +As a legacy compiler we refer to a compiler that doesn't have PuppetDB. And a current Compiler is a compiler that has PuppetDB. By default, latest versions of Puppet enterprise comes with compilers that have PuppetDB.If your primary server and compilers are connected with high-latency links or congested network segments, you might experience better PuppetDB performance with legacy compilers. |
| 6 | + |
| 7 | +## Who is this documentation for |
| 8 | + |
| 9 | +For those users that have installed Puppet Enterprise with puppetlabs-peadm prior version 3.21 and manually converted their existing complilers (all of the or at least 1) to legacy compilers. |
| 10 | + |
| 11 | +## Who is this documentation not for |
| 12 | + |
| 13 | +For those users that have installed Puppet Enterprise with PEADM with 3.21 version or later, there is no need to follow this documentation. The install process will automatically have created the necessary configurations for you and you can use the `peadm::convert_compiler_to_legacy` plan if you need a legacy compiler. example: |
| 14 | + |
| 15 | +```shell |
| 16 | +bolt plan run peadm::convert_compiler_to_legacy legacy_hosts=compiler1.example.com,compiler2.example.com primary_host=primary.example.com |
| 17 | +``` |
| 18 | + |
| 19 | +## How to upgrade Puppet Enterprise with legacy compilers |
| 20 | + |
| 21 | +### 1. Revert changes to the legacy compilers nodes |
| 22 | + |
| 23 | +Usually users pin the nodes in the Pe Master Node Group and then manually removing PuppetDB from compilers nodes. To revert this changes go to your Puppet Enterprise console and unpin the compilers nodes from the Group. |
| 24 | + |
| 25 | +### 2. Update certificate extensions for NON legacy compilers |
| 26 | + |
| 27 | +If you have NON legacy compilers in your infrastructure, you have to add a certificate extension to them that recognizes them as NON legacy compilers. To do this, execute the following plan: |
| 28 | + |
| 29 | +```shell |
| 30 | +bolt plan run peadm::update_compiler_extensions primary_host=primary.example.com compilers_hosts=compiler1.example.com,compiler2.example.com |
| 31 | +``` |
| 32 | + |
| 33 | +### 3. Use the convert legacy compiler plan |
| 34 | + |
| 35 | +Now that we have unpinned the compilers nodes from the PE Master node group, execute the following plan to convert your needed compilers to legacy compilers: |
| 36 | + |
| 37 | +```shell |
| 38 | +bolt plan run peadm::convert_compiler_to_legacy legacy_hosts=compiler1.example.com,compiler2.example.com primary_host=primary.example.com |
| 39 | +``` |
| 40 | + |
| 41 | +The above will create the needed Node group and Classifier rules to make the compilers legacy. Also will add certificate extensions to those nodes. |
| 42 | + |
| 43 | +### 4. Upgrade Puppet Enterprise |
| 44 | + |
| 45 | +After you have completed the above steps, you can proceed with the upgrade of Puppet Enterprise as usual using the puppetlabs-peadm module. There is no need to do the above ever again. |
0 commit comments