• Modern UX

    Edit and navigate faster in the terminal with Warp's IDE-like input editor.

  • AI Tools

    Prompt in natural language, generate code, delegate tasks to AI and much more.

  • Warp Drive

    Save and share interactive notebooks, workflows, and environment variables.

  • All Features

Create Kubernetes Namespace With `kubectl`

Mansi Manhas

Mansi Manhas

Published: 1/31/2024

About Terminus

In Kubernetes, namespaces provide a logical way to separate resources within an application, forming isolated virtual clusters within the Kubernetes cluster. For example, you can create namespaces for the development and production environments and manage their resources independently.

The operations performed in one namespace do not affect the other namespaces. Thus, it is an ideal option for managing resources separately, especially when working on large projects where every resource has different needs, authorization controls, and varied resource consumption limits.

The short answer

By default, Kubernetes allocates all resources to the default namespace, allowing you to utilize your cluster without the initial step of manually creating a namespace.

To create a custom namespace, you can use the kubectl create namespace command followed by the name of your namespace:

$ kubectl create namespace <namespace_name>

For example:

$ kubectl create namespace development
namespace/development created.

Upon execution, the above command will output the name of the newly created namespace in the terminal to confirm its successful creation.

Note that you can use the kubectl get namespaces command to view all available namespaces in your cluster. You can read more about this command by consulting the official documentation page.

If you’re using Warp as your terminal, you can easily retrieve this command using the Warp AI Command Search feature:

Entering k8 namespace in the AI Command Search will prompt a kubectl command, which can be inserted quickly into your shell by doing CMD+ENTER.

Adding labels to existing namespaces

In Kubernetes, labels are key-value pairs that can be attached to various resources, including namespaces. Labels are beneficial to identify and organize namespaces in larger Kubernetes environments.

To label an existing namespace, you can use the kubectl label command as follows:

$ kubectl label namespace <key>=<value>

key is the label key.
value is the value of the label key.

For example:

$ kubectl label namespace <key>=<value>

You can learn more about this command on the official documentation page. Note that, by applying labels strategically, you can implement pod security standards, implement access control and organize your resources better.

Simulating namespace creation

Simulating namespace creation helps validate the creation before directly applying it to your live Kubernetes cluster. This simulation will help you avoid unintended changes, such as misconfigurations or potential errors causing instability within the live cluster.

To simulate the creation of a namespace, you can use the kubectl create namespace command followed by the --dry-run flag:

$ kubectl create namespace <namespace> --dry-run=[client|server|none]

The--dry-run flag offers three possible values:

  • client specifies a dry run on the client side, meaning it validates the request locally without sending server requests. This is helpful for quickly verifying the correctness of the command and ensuring it won't trigger any errors.
  • server specifies a dry run on the server side, where the request is sent to the server for validation, but any changes are not persisted. The response from the server indicates whether the creation of the namespace would have been successful or not without actually creating the namespace.
  • none specifies that no dry run is performed, and the namespace creation request is directly applied to the server, resulting in the actual creation of the namespace. This is the default behavior of the kubectl create namespace command without the --dry-run flag.

For example:

$ kubectl create namespace production --dry-run=server
namespace/production created (server dry run)

The above command performs a dry run on the server side to create a new namespace named production, and the --dry-run=server flag ensures that the server processes the request as if it were a real creation attempt, providing a response indicating success or failure without actually creating the namespace.

Creating a namespace using a YAML file

To create a namespace using a YAML file, you can define the configurations as follows:

apiVersion: v1
kind: Namespace
metadata:
  name: development
  labels:
    pod-security.kubernetes.io/enforce: baseline
    pod-security.kubernetes.io/enforce-version: v1.28

Where:

  • apiVersion specifies the version of the Kubernetes API.
  • kind specifies the type of Kubernetes resource.
  • metadata specifies metadata about the resource.
  • name specifies the name of the resource.
  • labels specifies the key-value pairs which you want to assign to the resource.

Then use the kubectl create command with the -f flag to create the namespace defined in the YAML file:

$ kubectl create -f ./my-namespace-file.yaml

This command reads the configurations from the file and creates a new namespace accordingly.

Note that using a YAML file for namespace creation is beneficial as storing it in repositories enables easy tracking of namespace configurations. This also aids in versioning and automating namespace creation.

Creating multiple namespaces at once

To create multiple namespaces at once using a single YAML file, you can define the configurations as follows:

apiVersion: v1
kind: Namespace
metadata:
   name: development
---
apiVersion: v1
kind: Namespace
metadata:
   name: production

Where each section represents a separate namespace configuration.

Note that the three dashes (---) are used as a document separator, allowing you to define multiple resources at once using a single YAML file.

Alternatively, you can use the List resource with the following syntax to achieve the same result:

For example:

apiVersion: v1
kind: List
items:
- apiVersion: v1
  kind: Namespace
  metadata:
      name: mynamespace1
- apiVersion: v1
  kind: Namespace
  metadata:
      name: mynamespace2
- apiVersion: v1
  kind: Namespace
  metadata:
      name: mynamespace3

Creating a namespace using a JSON file

To create a namespace using a JSON file, you can define the configurations as follows:

{
    "apiVersion": "v1",
    "kind": "Namespace",
    "metadata": {
      "name": "development",
      "labels": {
        "pod-security.kubernetes.io/enforce": "baseline",
        "pod-security.kubernetes.io/enforce-version": "v1.28"
      }
    }
  }

And run the kubectl create command with the -f flag to create this namespace:

$ kubectl create -f ./my-namespace-file.json

Creating namespaces using either YAML or JSON files is beneficial when orchestrating complex deployments or managing configurations across various environments. These structured files offer a clear and concise way to define Kubernetes resources, aiding in better management and automation of your applications within Kubernetes.

Best practices when choosing a namespace

In Kubernetes, namespaces must be defined according to the following rules:

  • It must be unique in a cluster and should not clash with existing ones. If you attempt to create an existing namespace, the command will result in an error (indicating that the namespace already exists), and the creation of the namespace will fail.
  • It must be a valid DNS label (i.e. it can only contain lowercase characters, numbers, dash (-), underscore (_), or period (.).
  • It must start and end with an alphanumeric character.

It should not use prefixes like kube-, as they are reserved for system namespaces (such as kube-public and kube-system).

Written by

Mansi Manhas

Mansi Manhas

Filed Under

Related Articles

Copy Files From Pod in Kubernetes

Learn how to copy files and directories from within a Kubernetes Pod into the local filesystem using the kubectl command.

Kubernetes
Razvan Ludosanu

Scale Deployments in Kubernetes

Learn how to manually and automatically scale a Deployment based on CPU usage in Kubernetes using the kubectl-scale and kubectl-autoscale commands.

Kubernetes
Razvan Ludosanu

Get Kubernetes Logs With kubectl

Learn how to get the logs of pods, containers, deployments, and services in Kubernetes using the kubectl command. Troubleshoot a cluster stuck in CrashloopBackoff, ImagePullBackoff, or Pending error states.

Kubernetes
Ekene Ejike

Forward Ports In Kubernetes

Learn how to forward the ports of Kubernetes resources such as Pods and Services using the kubectl port-forward command.

Kubernetes

Tail Logs In Kubernetes

Learn how to tail and monitor Kubernetes logs efficiently to debug, trace, and troubleshoot errors more easily using the kubectl command.

Kubernetes

Get Context In Kubernetes

Learn how to get information about one or more contexts in Kubernetes using the kubectl command.

Kubernetes

Delete Kubernetes Namespaces With kubectl

Learn how to delete one or more namespaces and their related resources in a Kubernetes cluster using the kubectl command.

Kubernetes

Get Kubernetes Secrets With kubectl

Learn how to list, describe, customize, sort and filter secrets in a Kubernetes cluster by name, type, namespace, label and more using the kubectl command.

Kubernetes
Mansi Manhas

List Kubernetes Namespaces With kubectl

Learn how to list, describe, customize, sort and filter namespaces in a Kubernetes cluster by name, label, and more using the kubectl command.

Kubernetes
Mansi Manhas

How To List Events With kubectl

Learn how to list and filter events in Kubernetes cluster by namespace, pod name and more using the kubectl command.

Kubernetes
Mansi Manhas

Kubernetes vs Docker: The Backbone of Modern Backend Technologies

Lean the fundamentals of the Kubernetes and Docker technologies and how they interplay with each other.

KubernetesDocker
Gabriel Manricks

Set Context With kubectl

Learn how to create, modify, switch, and delete a context in Kubernetes using the kubectl config command.

Kubernetes
Mansi Manhas

Trusted by hundreds of thousands of professional developers

Download Warp to get started

Download for Mac