In this tutorial, you’ll learn how to create a Helm chart and deploy it to a repository. The repository can then be used as a source for a custom catalog in Rancher.

    You can fill your custom catalogs with either Helm Charts or Rancher Charts, although we recommend Rancher Charts due to their enhanced user experience.

    For a complete walkthrough of developing charts, see the upstream Helm chart developer reference.

    1. Within the GitHub repo that you’re using as your custom catalog, create a directory structure that mirrors the structure listed in Chart Directory Structure.

      Rancher requires this directory structure, although app-readme.md and questions.yml are optional.

      Tip:

    2. Recommended: Create an app-readme.md file.

      Use this file to create custom text for your chart’s header in the Rancher UI. You can use this text to notify users that the chart is customized for your environment or provide special instruction on how to use it.

      Example:

      1. $ cat ./app-readme.md
      2. # Wordpress ROCKS!
    3. Recommended: Create a questions.yml file.

      This file creates a form for users to specify deployment parameters when they deploy the custom chart. Without this file, users must specify the parameters manually using key value pairs, which isn’t user-friendly.

      The example below creates a form that prompts users for persistent volume size and a storage class.

      For a list of variables you can use when creating a questions.yml file, see Question Variable Reference.

      1. categories:
      2. - Blog
      3. - CMS
      4. questions:
      5. - variable: persistence.enabled
      6. default: "false"
      7. description: "Enable persistent volume for WordPress"
      8. type: boolean
      9. required: true
      10. label: WordPress Persistent Volume Enabled
      11. show_subquestion_if: true
      12. group: "WordPress Settings"
      13. subquestions:
      14. - variable: persistence.size
      15. default: "10Gi"
      16. description: "WordPress Persistent Volume Size"
      17. type: string
      18. label: WordPress Volume Size
      19. - variable: persistence.storageClass
      20. default: ""
      21. description: "If undefined or null, uses the default StorageClass. Default to null"
      22. type: storageclass
      23. label: Default StorageClass for WordPress
    4. Check the customized chart into your GitHub repo.

    Result: Your custom chart is added to the repo. Your Rancher Server will replicate the chart within a few minutes.