Table of Contents
Question content
Workaround
Home Backend Development Golang k8s uses OwnerRef to get all pod hierarchies in the cluster

k8s uses OwnerRef to get all pod hierarchies in the cluster

Feb 08, 2024 pm 09:45 PM
Containerized applications

k8s 使用 OwnerRef 获取集群中的所有 pod 层次结构

#php Editor Banana today will introduce to you a method to use OwnerRef to obtain the hierarchy of all Pods in the Kubernetes cluster. Kubernetes is a popular container orchestration platform that helps us manage and schedule containerized applications. In Kubernetes, Pod is the smallest schedulable unit, often composed of one or more containers. Understanding the Pod hierarchy is important to understanding and optimizing applications in a cluster. Let’s learn how to use OwnerRef to get all Pod hierarchies in the cluster!

Question content

We want to get all pods in the cluster, so we use something like this:

1

pods, err := client.CoreV1().Pods("").List(context.Background(), metav1.ListOptions{})

Copy after login

This code will receive all pods in the cluster.

My question is: Is there a code or library that can bring all pods with owner references to . That is, if the pods are owned by deployment or statfulset etc. you will get all the hierarchy, the trick here is if I need like some recursion Get an extra level like statefulset which is owned by a controller with a custom type

Workaround

As @CoolNetworking suggested, there is a library or code gives you all pods and their owner references, but you can use the k8s API to retrieve the owner reference for each pod. You can then use the k8s API to retrieve the owner object referenced by each owner. This will allow you to create a hierarchy of all Pods in the cluster.

The Kubernetes API is a resource-based (RESTful) programming interface provided over HTTP. It supports retrieving, creating, updating, and deleting primary resources via standard HTTP verbs (POST, PUT, PATCH, DELETE, GET).

Most Kubernetes API resource types are objects: they represent concrete instances of concepts on the cluster, such as Pods or namespaces.

See documentation kubernetes API for more information

The above is the detailed content of k8s uses OwnerRef to get all pod hierarchies in the cluster. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1657
14
PHP Tutorial
1257
29
C# Tutorial
1229
24
How to install Snap on Debian 12 How to install Snap on Debian 12 Mar 20, 2024 pm 08:51 PM

Snap is an external package manager designed for Linux systems that provides you with a convenient way to install containerized applications. Snap allows you to easily download and install packages without worrying about installing additional dependencies. The manager automatically resolves the dependencies required by the package, ensuring that the package runs smoothly on your system. Snap complements the native apt package manager, giving you another option for installing and running applications on your system. In this guide, you will find a complete guide on how to install Snap on Debian12. Outline: How to install Snap on Debian12 How to find package availability on Snap How to find information about packages on Snap

How to debug docker-compose? Where is the configuration path set? How to debug docker-compose? Where is the configuration path set? Feb 10, 2024 pm 12:48 PM

I'm trying to debug docker-compose, this Go file, to solve some problem (this). To do this, I set up a GoLang debugger gorunmain.go-f/.../project_root/docker-compose.yml-f/.../project_root/folder1/docker-compose.ymlconfig's output is as expected, merged Configuration files. For some reason I can't find the configuration files set in the code, although they must be set somewhere because the output is the correctly merged configuration files. I suspect they must be set

What languages ​​does pycharm support? What languages ​​does pycharm support? Apr 18, 2024 am 10:57 AM

Programming languages ​​supported by PyCharm include: Python (main supported language) JavaScript (including Node.js and React) HTML/CSSTypeScriptJavaC/C++GoSQLDockerKotlinRust

6 Best Linux Distributions for Network Engineers 6 Best Linux Distributions for Network Engineers Feb 05, 2024 pm 05:20 PM

As a network engineer, when considering installing Linux for your job, you may be faced with a question: Of the thousands of Linux distributions available, which one should you choose? Don't worry, you're not alone. Linux is a common operating system of choice for network engineers, and there are many distributions suitable for network-related tasks. If you are a network engineer, you may want to know which distributions provide the best functionality for your work. The following are six excellent Linux distributions that are widely recommended by network engineers: 1. Fedora Among the many Linux distributions, Fedora is one of the most respected among network engineers, and the reason is simple. Fedora is an open source distribution equivalent to Red Hat Enterprise

What are the application fields of Go language development? What are the application fields of Go language development? Apr 03, 2024 am 11:33 AM

The Go language is used in the following fields: back-end development (microservices, distributed systems) cloud computing (cloud native applications, containerized applications) data processing (data analysis, big data engines) networks and distributed systems (proxy servers, distribution cache) system tools (operating system, utilities)

The wide application of Linux in the field of cloud computing The wide application of Linux in the field of cloud computing Mar 20, 2024 pm 04:51 PM

The wide application of Linux in the field of cloud computing With the continuous development and popularization of cloud computing technology, Linux, as an open source operating system, plays an important role in the field of cloud computing. Due to its stability, security and flexibility, Linux systems are widely used in various cloud computing platforms and services, providing a solid foundation for the development of cloud computing technology. This article will introduce the wide range of applications of Linux in the field of cloud computing and give specific code examples. 1. Application virtualization technology of Linux in cloud computing platform Virtualization technology

Five selected Go language open source projects to take you to explore the technology world Five selected Go language open source projects to take you to explore the technology world Jan 30, 2024 am 09:08 AM

In today's era of rapid technological development, programming languages ​​are springing up like mushrooms after a rain. One of the languages ​​that has attracted much attention is the Go language, which is loved by many developers for its simplicity, efficiency, concurrency safety and other features. The Go language is known for its strong ecosystem with many excellent open source projects. This article will introduce five selected Go language open source projects and lead readers to explore the world of Go language open source projects. KubernetesKubernetes is an open source container orchestration engine for automated

Image from ECR to EKS not working as the resulting Pod is always 0/2 Image from ECR to EKS not working as the resulting Pod is always 0/2 Feb 08, 2024 pm 10:39 PM

I've tried almost everything to get things on the right path but still can't get my pod to be in a usable state. So I have a basic application written in go. I created an image of my program using dockerbuild --tagdocker-gs-ping. Then I tried running the same command inside the container dockerrun --publish8080:8080docker-gs-ping and then I wanted to save my image to amazonecr, for which I Created a repository in ecr. Now, after creating the repository, I tagged the images that exist in my local. docker

See all articles