Skip to content

CLI

The RCTL utility provides the means to manage the lifecycle of namespaces across the fleet of managed clusters. The following operations can be performed on namespaces managed by the controller on the fleet of clusters.

Resource Create Get Update Delete Status Publish
Namespace YES YES YES YES YES YES

Managed Namespaces

As a multi cluster operations platform, the Controller creates/deletes namespaces on managed Kubernetes clusters.

For immediate operations on a namespace on a cluster, use the Zero Trust KubeCTL to manage these directly.


Create Namespace

Create a new "managed" namespace in the current Project using the YAML config spec.

Declarative

To create/update a namespace with the declarative method, use the below command

./rctl apply -f namespace.yaml

Namespace with Labels, Annotations, and Placement Type

Below is an example of a YAML file with labels, annotations, 'namespace type' as Wizard, and 'placement type' as specific clusters.

apiVersion: infra.k8smgmt.io/v3
kind: Namespace
metadata:
  annotations:
    annotation1: annovalue1
    annotation2: ""
  labels:
    key1: keyvalue1
    key2: ""
  name: testnamespace
  project: demoproject
spec:
  limitRange:
    container:
      default:
        cpu: 1u
        memory: 200Mi
      defaultRequest:
        cpu: 1u
        memory: 100Mi
      max:
        cpu: 1u
        memory: 1Gi
      min:
        cpu: 1u
        memory: 6Mi
      ratio:
        cpu: 1
        memory: 4
    pod:
      max:
        cpu: 1u
        memory: 1Gi
      min:
        cpu: 1u
        memory: 6Mi
      ratio:
        cpu: 1
        memory: 4
  networkPolicyParams:
    networkPolicyEnabled: true
    policies:
    - name: ns-network
      version: v1
  placement:
    labels:
    - key: rafay.dev/kubernetesProvider
      value: EKS
  resourceQuotas:
    configMaps: "14"
    cpuLimits: 4m
    cpuRequests: 1m
    memoryLimits: 4Mi
    memoryRequests: 1Mi
    persistentVolumeClaims: "4"
    pods: "4"
    replicationControllers: "20"
    secrets: "20"
    services: "10"
    servicesLoadBalancers: "2"
    servicesNodePorts: "2"

Important

Avoid upper case characters for the name because Kubernetes does not support it.


List Namespace

The below command is to retrieve/list all "managed namespaces" in the currently specified "Project".

./rctl get namespace --v3
+-------------------------+----------+--------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+-------------+
| NAME                    | TYPE     | PLACEMENT DETAILS                                      | LABELS                                                                                                                                                                                                                                                                 | ANNOTATIONS |
+-------------------------+----------+--------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+-------------+
| new-ns                  | Wizard   | rafay.dev/clusterName:new-prod-eks                     |                                                                                                                                                                                                                                                                        |             |
+-------------------------+----------+--------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+-------------+
| ns-1                    | Wizard   | rafay.dev/clusterName:new-prod-eks                     |                                                                                                                                                                                                                                                                        |             |
+-------------------------+----------+--------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+-------------+

The below command is to retrieve a specific namespace from a project. When viewing a specific namespace, labels and annotations associated with the namespace are also shown.

./rctl get namespace nov-ns --v3
+--------+--------+----------------------------------------+--------+-------------+
| NAME   | TYPE   | PLACEMENT DETAILS                      | LABELS | ANNOTATIONS |
+--------+--------+----------------------------------------+--------+-------------+
| nov-ns | Wizard | rafay.dev/clusterName:prod-eks         |        |             |
+--------+--------+----------------------------------------+--------+-------------+

Or you can use the below commands to get more information of the namespace in json or yaml format.

./rctl get namespace <namespace-name> -o json
./rctl get namespace <namespace-name> -o yaml

Example:

./rctl get namespace demo-ns -o yaml
apiVersion: infra.k8smgmt.io/v3
kind: Namespace
metadata:
  annotations:
    annotation1: value1
    annotation2: ""
  labels:
    key1: value1
    key2: ""
  name: ns2
  project: project1
spec:
  placement:
    labels:
    - key: rafay.dev/clusterName
      value: demo-agent

Namespace Label Configuration Specification

The Namespace Labels feature enables the definition and management of key-value labels for all namespaces at a project level. This functionality allows users to specify multiple namespace-label combinations, streamlining the organization and consistency of resource management across clusters. Labels can be configured manually through various interfaces, including the Terraform, API, and RCTL, ensuring ease of use and adaptability. Users can track modifications via audit logs, making the feature robust and user-friendly.

📌 Note: - Namespace labels applied through this feature will only be reflected in the UI if sync is enabled. If sync is not enabled, users must query the cluster directly to view the labels for a particular namespace - Default Rafay labels cannot be configured or updated - Namespace associations are not applicable to clusters shared across projects. They are effective only on clusters within their parent project.

This enhancement is particularly beneficial for users by automating the application of namespace labels, eliminating the need for manual scripting after cluster provisioning. It supports efficient Day 2 operations by enabling updates to namespace labels and providing workflows that can be utilized for various use cases, such as chargebacks and resource tracking. Additionally, users can consistently apply labels across all namespaces, enhancing operational efficiency.

Below is the configuration specification for applying namespace labels:

apiVersion: tags.k8smgmt.io/v3
kind: ProjectTagsAssociation
metadata:
  name: "demo-association"
  project: "defaultproject"
spec:
  associations:
    - tagKey: "demo-key"
      tagType: "namespacelabel"
      tagValue: "demo-value"
      resource: "demo-namespace"

RCTL Commands for Namespace label Association

  • Create Association
./rctl apply -f <spec_path>

Example:

./rctl apply -f namespacelabelassoc.yaml
  • Get Project Association
./rctl get projtagassoc

Get Specific Project Association

./rctl get projtagassoc <association_name>

Example:

./rctl get projtagassoc demo-association
┌──────────────────────────────┬──────────────────────────────────────────────────────────────────┐
│ PROJECT-TAG-ASSOCIATION NAME │                            TAGS-ASSOC                            │
│                              ├────────────────┬──────────────┬────────────────┬─────────────────┤
│                              │ TAG-ASSOC-TYPE │    TAG-KEY   │ TAG-VALUE      │ RESOURCE NAME   │
├──────────────────────────────┼────────────────┼──────────────┼────────────────┼─────────────────┤
│       demo-association       │ namespacelabel │ demo-key     │ demo-value     │ demo-namespace  │
└──────────────────────────────┴────────────────┴──────────────┴────────────────┴─────────────────┘
  • Delete Association
./rctl delete projtagassoc <association_name>

Example:

./rctl delete projtagassoc demo-association

Delete Namespace

Delete a "managed namespace" in the current project context using the following command. Users are allowed to delete one or more namespaces at once. Below is an example of multiple namespace deletion. Deleting a namespace will also delete the namespace from the clusters where the namespace is published.

./rctl delete namespace -f config.yaml --v3

Important

Managed namespaces cannot be deleted if they are in active use by workloads or blueprints


Namespace Status

To know the status of a namespace, use the below command

./rctl status namespace <ns-name> --v3

Output

+---------+------+----------------+------------------+------------------+----------------+
| NAME    | TYPE | PUBLISHPENDING | ASSIGNEDCLUSTERS | DEPLOYEDCLUSTERS | FAILEDCLUSTERS |
+---------+------+----------------+------------------+------------------+----------------+
| demo    | Repo | false          | demo-cluster     | demo-ckuster     |                |
+---------+------+----------------+------------------+------------------+----------------+

Note

For help commands, append -h or --help after any of these commands. Example: .rctl get namespace -h or .rctl get namespace --help


Templating

Users can also create multiple namespaces with a set of defined configurations. The template file contains a list of objects that helps to create multiple namespace(s) from a single template.

Below is an example of a namespace config template

# Generated: {{now.UTC.Format "2006-01-02T15:04:05UTC"}}
#      With: {{command_line}}
{{ $envName := environment "PWD" | basename}}
{{ $glbCtx := . }}{{ range $i, $project := .ProjectNames }}
{{ $ctxNS := $glbCtx }}{{ range $j, $ns := $glbCtx.Namespaces }}
apiVersion: infra.k8smgmt.io/v3
kind: Namespace
metadata:
  project: {{$envName}}-{{$project}}
  name: {{ $ns.Name }}
  labels:{{$q := $ctxNS}}{{range $k, $label := $ns.Labels}}
    {{ $label.Key }}: {{ $label.Value }}{{end}}
    environment: {{$envName}}
spec:
  drift:
    enabled: false
  placement:
    labels:{{$c := $ctxNS}}{{range $l, $cluster := $ctxNS.ClusterNames}}
      - key: rafay.dev/clusterName
        value: {{$envName}}-{{$project}}-{{ $cluster }}{{end}}
  resourceQuotas:
    configMaps: "{{ $c.ResourceQuota.ConfigMaps }}"
    cpuLimits: {{ $c.ResourceQuota.CpuLimits }}
    cpuRequests: {{ $c.ResourceQuota.CpuRequests }}
    memoryLimits: {{ $c.ResourceQuota.MemoryLimits }}
    memoryRequests: {{ $c.ResourceQuota.MemoryRequests }}
    storageRequests: {{ $c.ResourceQuota.StorageRequests }}
---{{end}}
{{end}}

Users can create one or more namespace(s) with the required configuration defined in the template file. Below is an example of an namespace value file. This file helps to create namespace with the specified objects

Namespaces:
  - Name: ns-frontend
    Labels:
      - Key: component
        Value: frontend
      - Key: app
        Value: service-xyz
  - Name: ns-backend
    Labels:
      - Key: component
        Value: backend
      - Key: app
        Value: service-xyz
  - Name: ns-database
    Labels:
      - Key: component
        Value: database
      - Key: app
        Value: service-xyz
ResourceQuota:
  ConfigMaps: "100.000000"
  CpuLimits: 500.000000m
  CpuRequests: 500.000000m
  MemoryLimits: 500.000000Mi
  MemoryRequests: 500.000000Mi
  StorageRequests: "1.000000"

Important

Only the objects defined in the template must be present in the value files

Use the command below to create namespace(s) with the specified configuration once the value file(s) are prepared with the necessary objects

 ./rctl apply -t namespace.tmpl --values values.yaml

where,

  • namespace.tmpl: template file
  • value.yaml: value file

Refer Templating for more details on Templating flags and examples

Important

Refer here for the deprecated RCTL commands