Add your comments directly to the page. Include links to any relevant research, data, or feedback.

Summarize this decision in the table below. Type /date to quickly add the due date and @mention the driver, approver, contributors, and informed to keep everyone on the same page.


Status
Impact

Driver
Approver
Contributors
InformedBrandon Riden Kendall Moore, Nick MarkowskiDylan CochranSteven PritchardNick Miller,  Adam Yohrling
Due date01 May 2019
Outcome(Sprint 82 is tentatively proceeding with Option 1)



This decision refines decisions from the log, How to restructure the RPM installation sequence to be more r10k/Code Manager friendly.


This document describes proposed behavior in an upcoming SIMP release (6.4.0+).  Links to SIMP's documentation refer to the current release of SIMP at the time of writing (6.3.3).

Table of Contents


Background

This article describes the workflow specific to installing a fresh SIMP 6.4.0+ server from an ISO.  It builds on the decision log SIMP 6.4.0: What r10k-friendly RPM features should it include?.

Drivers:

Other considerations:

Relevant data

What the word "Environment" means

The term "environment" is heavily overloaded with respect to SIMP, Puppet, DevOps, and IT in general. 

This decision log uses the SIMP-specific terminology defined in the design article, SIMP Environments.


Proposed workflow

High-level workflow

For reference, the process has been broken down into stages A, B, and C:

New 6.4.0+ behavior is marked in red.

A: (Admin) installs SIMP from ISO

A diagram that describes an Admin installing SIMP from an ISO Info

(Admin) installs SIMP from ISO, ala the SIMP docs procedure, "ISO Installation (preferred)." 

Key 6.4.0+ differences:


B: Admin runs simp config

(Admin) logs into the newly-installed SIMP host and runs simp config.

Key 6.4.0+ differences:

All stage B logic is new to simp config, and it replaces RPM logic in SIMP ≤ 6.3Specifically, it replaces the old logic between simp-environment and simp-adapter that effectively accomplished the "auto-deploy" in SIMP ≤ 6.3, but in an opinionated manner that can conflict with r10k administration. The old logic:

  1. created the simp/ Puppet environment directory, and
  2. auto-deployed each RPM-installed Puppet module's files into the simp Puppet environment using rsync.

By contrast, the new logic will:

  1. ensure that a production environment exists under the Puppet (/etc/puppetlabs) and Secondary (/var/simp/...) environment directories, while running simp config.
    1. Note that this is now the production/ environment—with r10k workflows, it doesn't make sense to create a simp/ symlinked to production/
  2. create an initial Puppetfile and Puppetfile.simp in the production Puppet environment directory
  3. deploy the new Puppetfile using r10k puppetfile install 

A significant difference is that the simp config "auto-deploy" only runs once in the lifetime of the the SIMP server, whereas the SIMP ≤ 6.3 the auto-deploy executed during the %post or %posttrans  of each Puppet Module and simp-environment RPM, including upgrades.

C: Remainder of SIMP installation process

After deploying the initial Puppet environment, the rest of the SIMP installation continues without any specific alterations to support the Puppetfile-based workflow.  This includes the remainder of simp config (C1), (admin-initiated) simp bootstrap, (admin-initiated) reboot, and the post-boot Puppet agent run.

Workflow details

A2: Puppet module RPMs + local bare git repositories



B2: simp config's initial "auto-deploy"

The "auto-deploy" referenced in stage B2 must perform at least three actions:

  1. Create the production Puppet environment directory $codedir/environments/production and secondary environment directory at /var/simp/environments/production.
  2. Generate the Puppetfile and Puppetfile.simp in the Puppet environment directory.

    (As of SIMP-6193) this can currently be accomplished manually by running:

  3. Deploy the SIMP Puppet modules


B2: simp environment new ENVIRONMENT

During the initial planning for the ISO installation, it was noted that the initial install (and subsequent admin work) would need to create environments.

Deployment scenarios 

This proposed ISO+Puppetfile workflow accommodates all common Puppetfile-based deployment methods as natively as possible.


ISO-only: r10k + RPM-delivered module repositories


Local Puppet admin(s):

6.4.0+: The new ISO+Puppetfile workflow is most relevant to this scenario.  

Users are only expected to maintain their (non-SIMP) Puppetfile (if necessary), and deploy RPM-delivered updates with r10k puppetfile install.


6.4.0+:  Local Puppet admins may create new Puppet environments, however: a Secondary environment is required to exist for each Puppet environment.





Professional: r10k + Control Repository

Administrators of all control repository scenarios are assumed to have enough git and r10k (or Code Manager) expertise to manage their own infrastructure.  This includes arranging their own external git-hosting service, managing their own control repository, and updating their modules repositories with the contents delivered on the local filesystem by SIMP Puppet module RPMs.

Puppet admins:

6.4.0+:  The ISO+Puppetfile workflow will not interfere with this scenario, however a Secondary environment is required to exist for each Puppet environment.


Enterprise: PE Code Manager + Control Repository


Puppet admins:

6.4.0+:  The ISO+Puppetfile workflow will not interfere with this scenario, however a Secondary environment is required to exist for each Puppet environment.

Options considered


Option 1:Option 2:
Description
  • The Proposed workflow is implemented.
  • There is only one circumstance where SIMP will automatically scaffold and deploy a Puppet environment, and that is when simp config is run on a Puppet server without any deployed Puppet environments.
  • B1 determines the environment 

Pros and cons

(plus)

(minus)

(plus)

(minus)

Estimated cost

Action items

Add action items to close the loop on open questions or concerns

Outcome

(Working assumption for Sprint 82 as of 14 Mar 2019): Option 1

Resources