skirmish

command module
v0.2.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 11, 2019 License: MIT Imports: 7 Imported by: 0

README

Skirmish

A game day orchestration tool
Build Status Maintainability Go Report Card Docker Repository on Quay
This application allows for users to run scripted game day events and be able to restore services if required.

Usage

In order to run skirmish, you need to follow the steps here so that the application can assume a role. If the skirmish is intended to run across multiple projects, then the account will need to have the correct permissions in each one.

To start using skirmish, it is as simple as:

skirmish --plan-path path/to/plan.yml

Considering a skirmish can run for over several hours, it is not recommend running within a CI environment that has timed usage.

Note: Skirmish has checks inbuilt to ensure it can restore services if repairable but it makes no guarantees if it receives a SIGKILL.

An example of a game day plan would be:

mode: repairable
projects: # projects defined here ensure the steps will fail if they are mistyped or should be part of the game day
    - staging
    - canary
steps:
    - name: Fail random instances
      description: |-
        Ensure that the systems are inplace for ensuring instance count or 
        that the correct procedure and alerts happen.
      operations: 
        - instance
      projects:
        - staging
      exclude:
        wildcards:        # wildcards support regular expressions
          - "data-node*"
          - "demo-server"
        regions:          # regions / zones support prefix matching
          - "us-west"
      wait: "10m"         # wait 10 minutes to restore instances
      sample: 80.0        # each valid instance will have an 80% chance of being paused
    - name: Stop communication of integration platform components
      description: |-
        Ensure that our platform is still operational when the integration pipeline is cut off
        from communicating
      operations: 
        - egress
      projects:
        - canary
      settings:
        network:
          name: data-ingestion
          deny:
            - protocol: "tcp"
              ports:
                - "8080"
                - "443"
                - "80"
      wait: "30m"
    - name: enstil fear in the cold hearted
      description: |- 
        Let the orchestration platform destroy as much of the project as possible to highlight worst case scenario.
        This will automatically recover once the step has reached its wait time.
      operations:
        - instance
        - egress
        - ingress
      projects:
        - staging
        - canary
      settings:
        network:
          # apply to the default work by leaving name blank
          deny:
            - protocol: "tcp"
              ports:
                - "443"
                - "80"
       wait: "20m"

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
pkg

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL