package

command
v0.17.0-dev Latest Latest
Warning

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

Go to latest
Published: Jan 27, 2022 License: Apache-2.0 Imports: 27 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
lib

Jump to

Keyboard shortcuts

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