Skip to content

Latest commit

 

History

History
416 lines (302 loc) · 18.6 KB

README.md

File metadata and controls

416 lines (302 loc) · 18.6 KB

Chart Map

GitHub last commit GitHub release (latest by date) GitHub Release Date Maven Central GitHub issues License GitHub Build Status GitHub Deploy Status Sonar Cloud Quality Gate Status Coverage Security Rating

See some examples → https://melahn.github.io/helm-chartmap/

Overview

This project generates a file that shows the recursive dependencies of a Helm Chart.

The generated file can be in JSON format, PlantUML text format or plain text format.

The JSON file can be used with helm-inspector to create an interactive visualization of the Helm Chart using the tree view of Data Driven Documents. You can see an example of such a JSON file here → https://melahn.github.io/helm-chartmap/alfresco-dbp/alfresco-dbp-1.5.0.json and you can see an example of how it can be visualized with helm inspector here → https://melahn.github.io/helm-inspector/src/?chart=./examples/alfresco-dbp-1.5.0

The PlantUML file can be turned into an image. You can see an example of that here → https://melahn.github.io/helm-chartmap/alfresco-dbp/alfresco-dbp-1.5.0.png. For more information about PlantUML, see http://plantuml.com/.

The text file provides a simple text summary of the charts and images used, and the dependencies. It also detects anomalies such as a stable chart depending on an incubator chart. You can see an example of a text file generated from Chart Map here → https://melahn.github.io/helm-chartmap/alfresco-dbp/alfresco-dbp-1.5.0.txt.

Dependency Info

Available from the Maven Central Repository and from GitHub Packages

<dependency>
  <groupId>com.melahn</groupId>
  <artifactId>helm-chartmap</artifactId>
  <version>1.2.0</version>
</dependency>

Prerequisites

Java 8 or later.

The Helm Client is required since a ChartMap is based on the dependencies discovered with the Kubernetes Helm client using the helm template command. The helm-chartmap-1.1.x and 1.2.x versions have been tested with version 3.8.1 of the Helm Client and the helm-chartmap-1.0.2 version has been tested with version 2.17.0 of the Helm Client. Other Helm client versons may also work.

For instructions on installing the Helm Client, see https://docs.helm.sh/using_helm/#installing-helm.

The helm client command is determined by first using the value of the environment variable HELM_BIN. If not found, then the value helm is used and it is assumed that the executable helm will be found in the PATH. It is arguably more secure to set HELM_BIN explictly since that way you prevent the security exposure of some other (unknown) executable named helm being found in the PATH.

The location of the helm cache and configuration directories is derived using the helm env command.

Graphviz is a prerequisite if you want to have ChartMap generate images from the PlantUML files created by helm-chartmap.

Using Chart Map

Setup

  1. Download the executable jar from Maven Central or build it yourself from source (see below)
  2. Run the command line
  3. Write a Java program using the API, to generate a ChartMap

See Syntax and Examples below.

If debug information is desired, set the environment variable CHARTMAP_DEBUG=<anyvalue>.

Command Line Syntax

java -jar helm-chartmap-1.2.0.jar

Flags:
  -a  <apprspec>  A name and version of a chart as an appr specification
  -c  <chartname>  A name and version of a chart
  -f  <filename>  A location in the file system for a Helm Chart package (a tgz file)
  -u  <url>    A url for a Helm Chart
  -o  <filename>  The location of the output file
  -e  <filename>  The location of an Environment Specification file
  -t  <timeout>  The maximum time in seconds to wait for a helm command to complete
  -g      Generate image from PlantUML file
  -r      Refresh
  -v      Verbose
  -h      Help               

Flags

  • Required
    • To specify the Helm Chart, one of the following input formats must be specified
      • -a <apprspec> * A name and version of the chart as an appr specification <host>/<org>/<chart-name>@<chart-version>
      • -c <chartname> * A name and version of the chart in the format <chart-name:chart-version>
      • -f <filename> * A location in the file system for a Helm Chart package (a tgz file)
      • -u <url> * A url for the Helm Chart
    • -o <filename>
      • The name of the file to be generated. If a file extension of 'puml' is specifed the format of the generated file will be PlantUML. If a file extension of 'json' is specifed the format of the generated file will be in JSON format. Otherwise it will be plain text.
  • Optional
    • -e <filename>
      • The location of an Environment Specification which is a yaml file containing a list of environment variables to set before rendering helm templates. See the example environment specification provided in resource/example-env-spec.yaml to understand the format.
    • -t <seconds>
      • The maximum amount of time to wait (in seconds) for a helm command to complete. This is rarely, if ever needed, and is intended for cases where a helm chart is very complex, and the helm update dependency command may take a long time because of machine or network constraints. If the number is not greater than zero, a detault of 600 seconds is used.
    • -g
      • Generate image. Whenever specified, an image file is generated from the PlantUML file. This is only applicable if the filename of the generated output file has the extension 'puml'.
    • -r
      • Refresh. If specified, the Helm command helm update dependencies will be run before generating the chart map
    • -v
      • Verbose. If specified, some extra command line output is shown
    • -h
      • Help. Whenever specified, any other parameters are ignored. When no parameters are specified, -h is assumed.

Example Commands

Generating a ChartMap using a chart reference
java -jar target/helm-chartmap-1.2.0.jar -c "wordpress:14.2.5" -o wordpress-14.2.5.txt  -v
Generating a ChartMap using a file specification
java -jar target/helm-chartmap-1.2.0.jar -f "./src/test/resource/test-chart-file-2.tgz" -o test-chart-file-2.puml -e "./resource/example/example-env-spec.yaml"
Generating a ChartMap using a url specification
java -jar target/helm-chartmap-1.2.0.jar -u "http://kubernetes-charts.alfresco.com/stable/alfresco-content-services-5.2.0.tgz" -o alfresco-content-services-5.2.0.puml -g -v -r -e "./resource/example/example-env-spec.yaml" -t 1200

Note in this example, the -g flag is set to automatically generate the image from the PlantUML file and a timeout value of 1200 seconds is used.

Also note that the system property PLANTUML_LIMIT_SIZE allows the generation of complex PlantUML images without cropping. It can be set directly on the command line using the '-D' argument or by setting it indirectly using the same named system environment variable. By default, Chart Map sets the property to 8192, which is enough to handle any chart encountered so far.

Generating a ChartMap using an appr specification
java -jar target/helm-chartmap-1.2.0.jar -a "quay.io/melahn/[email protected]"  -o helm-chartmap-test-chart.puml -g -v

Note in this example, the chart is stored as a quay.io application file and contains, for illustrative purposes, several subcharts, nginx and memcached from the bitnami charts repo.

Java Methods

In addition to the command line interface, a Java API is provided.

Constructor - V1.1.x and V1.0.x

    public ChartMap(ChartOption option,
                    String chart,
                    String outputFilename,
                    String envFilename,
                    boolean[] switches)                  

Constructor - V1.2.x

    public ChartMap(ChartOption option,
                    String chart,
                    String outputFilename,
                    String envFilename,
                    int timeout,
                    boolean... switches)                  
Description of ChartMap constructor

Constructs a new instance of the com.melahn.util.helm.ChartMap class

Parameters
  • option
    • The format of the Helm Chart. One of...
      • ChartOption.APPRSPEC
      • ChartOption.CHARTNAME
      • ChartOption.FILENAME
      • ChartOption.URL
  • chart
    • The name of the Helm Chart in one of the formats specified by the option parameter
  • outputFilename
    • The name of the file to which to write the generated Chart Map. Note the file is overwritten if it exists.
  • envSpecFilename
    • The location of an Environment Specification which is a yaml file containing a list of environment variables to set before rendering helm templates, or <null>. See the example environment specification to understand the format.
  • timeout (V1.2.x only)
    • The maximum amount of time to wait (in seconds) for a helm command to complete. This is rarely, if ever needed, and is intended for cases where a helm chart is very complex, and the helm update dependency command may take a long time because of machine or network constraints. If the number is not greater than zero, a detault of 600 seconds is used.
  • switches
    • V1.1.x and V1.1.0
      • An array containing the following three boolean values
        • switches[0] generate
          • When true, an image file is generated from the PlantUML file (if any). (default false)
        • switches[1] refresh
          • When true, refresh the local Helm repo (default false)
        • switches[2] verbose
          • When true, provides a little more information as the Chart Map is generated (default false)
    • V1.2.x
      • 0 or more boolean arguments defined as follows.
        • switches[0] refresh
          • When true, refresh the local Helm repo (default false)
        • switches[1] verbose
          • When true, provides a little more information as the Chart Map is generated (default false)
        • switches[2] generate
          • When true, an image file is generated from the PlantUML file (if any). (default false)
        • Any extra switches are ignored.
Throws
  • com.melahn.util.helm.ChartMapException

print

Description of print command

Prints a ChartMap

    public void print ()
                    
Throws in print command
  • com.melahn.util.helm.ChartMapException

Java Example - V1.1.x and V1.0.x

import com.melahn.util.helm.ChartMap;
import com.melahn.util.helm.ChartMapException;
import com.melahn.util.helm.ChartOption;

public class ChartMapExampleV11 {
    public static void printExampleChartMap(String[] args) {
        try {
            ChartMap testMap = new ChartMap(
                    ChartOption.FILENAME,
                    "src/test/resource/testChartFile.tgz",
                    "my-chartmap.puml",
                    "resource/example/example-env-spec.yaml",
                    new boolean[] { true, true, false });
            testMap.print();
        } catch (ChartMapException e) {
            System.out.println("ChartMapException generating ChartMap: ".concat(e.getMessage()));
        }
    }
}

Java Example - V1.2.x

import com.melahn.util.helm.ChartMap;
import com.melahn.util.helm.ChartMapException;
import com.melahn.util.helm.ChartOption;

public class ChartMapExampleV12 {
    public static void printExampleChartMap(String[] args) {
        try {
            ChartMap testMap = new ChartMap(
                    ChartOption.FILENAME,
                    "src/test/resource/testChartFile.tgz",
                    "my-chartmap.puml",
                    "resource/example/example-env-spec.yaml",
                    1200,
                    true); // take the default values for verbose and generate
            testMap.print();
        } catch (ChartMapException e) {
            System.out.println("ChartMapException generating ChartMap: ".concat(e.getMessage()));
        }
    }
}

Many more examples illustrating the use of the Java interface can be found in ChartMapTest.java.

Examples of Generated Files

Example Image generated from a PlantUML file generated by ChartMap

Example Image

Note that the colors chosen for a chart are randomly selected from a standard set of PlantUML colors (see PlantUML Colors) using a method that will depict Helm Charts or Docker Files that differ only by their version using the same color. For example 'postgresql:0.8.5' and 'postgresql:0.8.7' will be depicted with the same color. This will make it easier to spot cases you may want to optimize a deployment to use a common Helm Chart or Docker Image instead.

Helm Charts are depicted as rectangular objects. Docker Images are depicted as ovals.

Dependencies of Helm Charts on other Helm Charts are shown as green lines. Dependencies of Helm Charts on Docker Images are shown as orange lines.

Example PlantUML File generated by ChartMap

Example PlantUML File

Example JSON File generated by ChartMap

Example JSON File

Example Text File generated by ChartMap

Example Text File

Architecture Overview

Architecture

A illustrated, there is a ChartMap component, implemented as a Java class, that reads in a Helm Chart from a Helm Chart source. It then relies on the use of the helm template command to recursively generate a template representation of a Helm Chart and its dependencies. The resulting templates are parsed and the information saved in an in-memory representation of the Helm Chart and its dependencies, using a model of each of the main elements of Helm, such as HelmChart and HelmDeploymentContainer.

The result is then used to generate a file representation of the Helm Chart using one of several ChartMapPrinter classes, such as the PlantUMLChartMapPrinter. The end-user can then enjoy the result using an image viewer, a text viewer or helm-inspector.

Build Notes

Maven Commands

Building the jar from source and running tests

  1. git clone this repository
  2. run maven
mvn clean install 

Note: The helm-chartmap jar targets Java 8 for the widest compatibiity. You can target a different version of Java by modifying the configuration in the maven-compiler-plugin to use a different target like in the example below.

<target>11</target>

Building Image files from PUML source

  1. Git clone this repository
  2. Copy any PUML files into the source directory
  3. Run Maven

mvn com.github.jeluard:plantuml-maven-plugin:generate

Generating Images from PlantUML files outside of Maven

Having generated some PlantUML files, if you want to generate image files from the PlantUML files outside of Maven, there are several options.

  • The simplest option is to just include the '-g' option when running ChartMap to generate the PlantUML file. That will cause ChartMap to automatically generate a PNG file for you. For example,
java -jar helm-chartmap-1.2.0.jar -c "wordpress:14.2.5" -r -v -g -o "wordpress-14.2.5.puml" 
  • You can use the online PlantUML Service. Just copy/paste the generated PlantUML text and click 'Submit'. Then you can view the resulting image as PNG, SVG or Ascii Art.
  • Download the PlantUML jar and use the command line like this ...
java -jar ~/Downloads/plantuml.jar alfresco-dbp-1.5.0.puml
  • You can build PlantUML from source and then use the command line like this ...
java -jar ~/IdeaProjects/plantuml/target/plantuml-1.2022.5-SNAPSHOT.jar -tsvg alfresco-dbp-1.5.0.puml

Other Notes

When the shaded jar is built by the maven-shade-plugin there is a warning produced like this...

     target/classes (Is a directory)

This warning is due to a long-standing issue where the shade plugin checks if a classpath element is a jar, and if it is not, swallows useful error information. It instead prints out this meaningless warning. See https://issues.apache.org/jira/browse/MSHADE-376 for more details. See https://github.com/melahn/maven-shade-plugin if you want to install your own version of the plugin, with a fix that eliminates this warning.

Issues

If you find any problems please open an issue.

License

Apache 2.0