package

command
v0.26.0-dev Latest Latest
Warning

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

Go to latest
Published: Jul 27, 2022 License: Apache-2.0 Imports: 26 Imported by: 0

README

Package

Manage package lifecycle operations.

Usage

Package and Repository Operations ( Subject to Change ):

>>> tanzu package --help
Tanzu package management

Usage:
  tanzu package [command]

Available Commands:
    available   Manage available packages
    install     Install a package
    installed   Manage installed packages
    repository  Manage registered package repositories


Flags:
  -h, --help              help for package
      --log-file string   Log file path
  -v, --verbose int32     Number for the log level verbosity(0-9)

Use "tanzu package [command] --help" for more information about a command.
>>> tanzu package repository --help
Add, list, get or delete a repository for tanzu packages

Usage:
  tanzu package repository [command]

Available Commands:
  add         Add a repository
  delete      Delete a repository
  get         Get repository status
  list        List repository
  update      Update a repository

Flags:
  -h, --help   help for repository

Global Flags:
      --log-file string   Log file path
  -v, --verbose int32     Number for the log level verbosity(0-9)

Use "tanzu package repository [command] --help" for more information about a command.

Test

  1. Create a management cluster using latest tanzu cli

  2. Use package commands to:

    • add a repository
    • list a repository
    • get a repository status
    • list packages
    • get a package information
    • get an installed package information
    • update a package
    • delete a repository

    Use the following image package bundles for testing:

    S.no Repository URL
    1. projects-stg.registry.vmware.com/tkg/test-packages/test-repo:v1.0.0
    2. projects-stg.registry.vmware.com/tkg/test-packages/standard-repo:v1.0.0

    Here is an example workflow

  3. Add a repository

    >>> tanzu package repository add standard-repo --url projects-stg.registry.vmware.com/tkg/test-packages/standard-repo:v1.0.0 -n test-ns --create-namespace
    Added package repository 'standard-repo'
    
  4. Get repository status

    >>> tanzu package repository get standard-repo -n test-ns
    NAME:        standard-repo
    VERSION:     88984
    REPOSITORY:  projects-stg.registry.vmware.com/tkg/test-packages/standard-repo:v1.0.0
    STATUS:      Reconcile succeeded
    REASON:
    
  5. Update a repository

    >>> tanzu package repository update standard-repo --url projects-stg.registry.vmware.com/tkg/test-packages/standard-repo:v1.0.0 -n test-ns
    Updated package repository 'standard-repo' in namespace 'test-ns'
    
  6. List the repository

    >>> tanzu package repository list -A
    NAME           REPOSITORY                                                               STATUS               DETAILS  NAMESPACE
    standard-repo  projects-stg.registry.vmware.com/tkg/test-packages/standard-repo:v1.0.0  Reconcile succeeded           test-ns
    repo           projects-stg.registry.vmware.com/tkg/test-packages/test-repo:v1.0.0      Reconcile succeeded           test-ns
    
  7. Get information of a package

    Example 1: Get detailed information of a package

    >>> tanzu package available get contour.tanzu.vmware.com/1.15.1+vmware.1-tkg.1 --namespace test-ns
    / Retrieving package details for contour.tanzu.vmware.com/1.15.1+vmware.1-tkg.1...
      NAME:                           contour.tanzu.vmware.com
      VERSION:                        1.15.1+vmware.1-tkg.1
      RELEASED-AT:
      DISPLAY-NAME:                   contour
      SHORT-DESCRIPTION:              This package provides ingress functionality.
      PACKAGE-PROVIDER:
      MINIMUM-CAPACITY-REQUIREMENTS:
      LONG-DESCRIPTION:               This package provides ingress functionality.
      MAINTAINERS:                    []
      RELEASE-NOTES:
      LICENSE:                        []
    

    Example 2: Get openAPI schema of a package

    >>> tanzu package available get external-dns.tanzu.vmware.com/0.8.0+vmware.1-tkg.1 -n external-dns --values-schema
     KEY                         DEFAULT       TYPE     DESCRIPTION
     deployment.args             <nil>         array    List of arguments passed via command-line to external-dns.
                                                        For more guidance on configuration options for your
                                                        desired DNS provider, consult the ExternalDNS docs at
                                                        https://github.com/kubernetes-sigs/external-dns#running-externaldns
    
     deployment.env              <nil>         array    List of environment variables to set in the external-dns container.
     deployment.securityContext  <nil>         <nil>    SecurityContext defines the security options the external-dns container should be run with. More info: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
     deployment.volumeMounts     <nil>         array    Pod volumes to mount into the external-dns container's filesystem.
     deployment.volumes          <nil>         array    List of volumes that can be mounted by containers belonging to the external-dns pod. More info: https://kubernetes.io/docs/concepts/storage/volumes
     namespace                   external-dns  string   The namespace in which to deploy ExternalDNS.
    

    Example 3: Generate default values.yaml for a package

    >>> tanzu package available get contour.tanzu.vmware.com/1.18.2+vmware.1-tkg.1-rc.1 --generate-default-values-file
     NAME:                             contour.tanzu.vmware.com
     VERSION:                          1.18.2+vmware.1-tkg.1-rc.1
     RELEASED-AT:                      2021-10-04 17:00:00 -0700 PDT
     DISPLAY-NAME:                     contour
     SHORT-DESCRIPTION:                An ingress controller
     PACKAGE-PROVIDER:                 VMware
     MINIMUM-CAPACITY-REQUIREMENTS:    Varies significantly based on number of Services, Ingresses/HTTPProxies, etc. A starting point is 128MB RAM and 0.5 CPU for each Contour and Envoy pod, but this can and should be tuned based on observed usage.
     LONG-DESCRIPTION:                 An Envoy-based ingress controller that supports dynamic configuration updates and multi-team ingress delegation. See https://projectcontour.io for more information.
     MAINTAINERS:                      [{Steve Kriss} {Steve Sloka} {Nick Young} {Sunjay Bhatia} {Nicholas Seemiller}]
     RELEASE-NOTES:                    contour 1.18.2 https://github.com/projectcontour/contour/releases/tag/v1.18.2
     LICENSE:                          [VMware’s End User License Agreement (Underlying OSS license: Apache License 2.0)]
     SUPPORT:                          Support provided by VMware for deployment on TKG 1.4+ clusters. Best-effort support for deployment on any conformant Kubernetes cluster. Contact support by opening a support request via VMware Cloud Services or my.vmware.com.
     CATEGORY:                         [ingress]
    
     Created default values file at /home/contour-default-values.yaml
    

    contour-default-values.yaml

     certificates:
       duration: 8760h
       renewBefore: 360h
     contour:
       logLevel: info
       replicas: 2
       useProxyProtocol: false
     envoy:
       hostNetwork: false
       hostPorts:
         enable: true
         http: 80
         https: 443
       logLevel: info
       service:
         aws:
           LBType: classic
         externalTrafficPolicy: Cluster
       terminationGracePeriodSeconds: 300
     namespace: tanzu-system-ingress  
    
  8. Install a package

    Example 1: Install the specified version for package name "fluent-bit.tkg-standard.tanzu.vmware", while providing the values.yaml file and without waiting for package reconciliation to complete

    
    >>> tanzu package install fluentbit --package-name fluent-bit.tanzu.vmware.com --namespace test-ns --create-namespace --version 1.7.5+vmware.1-tkg.1 --values-file values.yaml --wait=false
    \ Installing package 'fluent-bit.tanzu.vmware.com'
    | Getting package metadata for fluent-bit.tanzu.vmware.com
    / Creating service account 'fluentbit-test-ns-sa'
    
    - Creating cluster role binding 'fluentbit-test-ns-cluster-rolebinding'
    
    Added installed package 'fluentbit' in namespace 'test-ns'
    

    An example values.yaml is as follows:

    fluent_bit:
       config:
         outputs: |
           [OUTPUT]
             Name     stdout
             Match    *
    

    Example 2: Install the latest version for package name "contour.tanzu.vmware.com". If the namespace does not exist beforehand, it gets created.

    >>> tanzu package install contour-pkg --package-name contour.tanzu.vmware.com --namespace test-ns --version 1.15.1+vmware.1-tkg.1
    \ Installing package 'contour.tanzu.vmware.com'
    / Getting package metadata for contour.tanzu.vmware.com
    
    - Creating cluster admin role 'contour-pkg-test-ns-cluster-role'
    
    / Creating package resource
    / Package install status: Reconciling
    
     Added installed package 'contour-pkg' in namespace 'test-ns'
    
  9. Get information of an installed package

    Example 1: Get information of an installed package

    >>> tanzu package installed get contour-pkg --namespace test-ns
    NAME:                 contour.tanzu.vmware.com
    PACKAGE-NAME:         contour-pkg
    PACKAGE-VERSION:      1.15.1+vmware.1-tkg.1
    STATUS:               Reconcile succeeded
    CONDITIONS:
    USEFUL-ERROR-MESSAGE:
    

    Example 2: Get data value secret of an installed package and save it to file (example: config.yaml)

    >>> tanzu package installed get fluent-bit --namespace test-ns --values-file config.yaml
    / Retrieving installation details for myfb...
    
    cat config.yaml
    fluent_bit:
      config:
        outputs: |
          [OUTPUT]
            Name     stdout
            Match    *
    
  10. Update a package

    Example 1: Update a package with different version

    >>> tanzu package installed update mypkg --version 3.0.0-rc.1 --namespace test-ns
    | Updating package 'mypkg'
    / Getting package install for 'mypkg'
    - Getting package metadata for 'pkg.test.carvel.dev'
    
    Updated package install 'mypkg' in namespace 'test-ns'
    

    Example 2: Update a package which is not installed

    >>> tanzu package installed update fluent-bit --package-name fluent-bit.tanzu.vmware.com --version 1.7.5+vmware.1-tkg.1 --namespace test-ns --install
    / Getting package install for 'fluent-bit'
    
    - Getting package metadata for fluent-bit.tanzu.vmware.com
    \ Creating service account 'fluent-bit-test-ns-sa'
    
    | Creating cluster role binding 'fluent-bit-test-ns-cluster-rolebinding'
    - Creating package resource
    \ Package install status: Reconciling
    
    Updated package install 'fluent-bit' in namespace 'test-ns'
    

    Example 3: Update an installed package with providing values.yaml file

    >>> tanzu package installed update fluent-bit --version 1.7.5+vmware.1-tkg.1 --namespace test-ns --values-file values.yaml
    | Updating package 'fluent-bit'
    | Getting package install for 'fluent-bit'
    / Updating secret 'fluent-bit-test-ns-values'
    
    Updated package install 'fluent-bit' in namespace 'test-ns'
    

    An example values.yaml is as follows:

    fluent_bit:
       config:
         outputs: |
           [OUTPUT]
             Name     stdout
             Match    /
    
  11. Uninstall a package

    >>> tanzu package installed delete contour-pkg --namespace test-ns
    | Uninstalling package 'contour-pkg' from namespace 'test-ns'
    - Getting package install for 'contour-pkg'
    - Deleting package install 'contour-pkg' from namespace 'test-ns'
    | Package uninstall status: Deleting
    / Deleting service account 'contour-pkg-test-ns-sa'
    
    
    Uninstalled package 'contour-pkg' from namespace 'test-ns'
    
  12. List the packages

    #List installed packages in the default namespace
    >>> tanzu package installed list
    NAME  DISPLAY-NAME  SHORT-DESCRIPTION
    
    #List installed packages across all namespaces
    >>> tanzu package installed list -A
    - Retrieving installed packages...
      NAME         PACKAGE-NAME              PACKAGE-VERSION        STATUS               NAMESPACE
      contour-pkg  contour.tanzu.vmware.com  1.15.1+vmware.1-tkg.1  Reconcile succeeded  test-ns
      mypkg        pkg.test.carvel.dev       2.0.0                  Reconcile succeeded  test-ns
    
    
    #List installed packages in user provided namespace
    >>> tanzu package installed list --namespace test-ns
    / Retrieving installed packages...
      NAME         PACKAGE-NAME              PACKAGE-VERSION        STATUS
      contour-pkg  contour.tanzu.vmware.com  1.15.1+vmware.1-tkg.1  Reconcile succeeded
      mypkg        pkg.test.carvel.dev       2.0.0                  Reconcile succeeded
    
    #List all available package CRs in default namespace
    >>> tanzu package available list
    / Retrieving available packages...
      NAME  DISPLAY-NAME  SHORT-DESCRIPTION
    
    #List all available package CRs across all namespace
    >>> tanzu package available list -A
    | Retrieving available packages...
      NAME                           DISPLAY-NAME          SHORT-DESCRIPTION                                                                    NAMESPACE
      harbor.tanzu.vmware.com        harbor                This package provides cloud native container registry service.                       test-ns
      pkg.test.carvel.dev            Test Package in repo  Package used for testing                                                             test-ns
      prometheus.tanzu.vmware.com    prometheus            This package provides an open-source systems monitoring and alerting toolkit         test-ns
      external-dns.tanzu.vmware.com  external-dns          This package provides DNS synchronization functionality.                             test-ns
      fluent-bit.tanzu.vmware.com    fluent-bit            This package provides log shipping functionality.                                    test-ns
      grafana.tanzu.vmware.com       grafana               This package allows you to visualize and analyze metrics data                        test-ns
      multus-cni.tanzu.vmware.com    multus-cni            This package provides ability for attaching multiple network interfaces to the pod.  test-ns
      cert-manager.tanzu.vmware.com  cert-manager          This package provides certificate management functionality.                          test-ns
      contour.tanzu.vmware.com       contour               This package provides ingress functionality.                                         test-ns
    
    #List all available packages for package name
    >>> tanzu package available list contour.tanzu.vmware.com -A
    / Retrieving package versions for contour.tanzu.vmware.com...
    NAME                      VERSION                RELEASED-AT  NAMESPACE
    contour.tanzu.vmware.com  1.15.1+vmware.1-tkg.1               test-ns
    
  13. Delete the repository

    >>> tanzu package repository delete standard-repo --namespace test-ns
    Deleted package repository 'standard-repo' in namespace 'test-ns''
    

All the above commands are equipped with --kubeconfig flag to perform the package and repository operations on the desired cluster.

Example:

>>> tanzu package installed list -A --kubeconfig wc-kc-alpha8
 - Retrieving installed packages...
 NAME         PACKAGE-NAME              PACKAGE-VERSION        STATUS               NAMESPACE
 contour-pkg  contour.tanzu.vmware.com  1.15.1+vmware.1-tkg.1  Reconcile succeeded  test-ns
 mypkg        pkg.test.carvel.dev       2.0.0                  Reconcile succeeded  test-ns

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Package kctrl provides function to add package command tree from kctrl
Package kctrl provides function to add package command tree from kctrl
lib

Jump to

Keyboard shortcuts

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