- 75
- 427 173
Vivek Singh
India
เข้าร่วมเมื่อ 11 ก.ย. 2020
Hey,
My name is Vivek, I am Software Engineer working around Open Source and Cloud Native technologies around Kubernetes primarily using Go as programming language.
In this channel I am going to create videos about Containers, Kubernetes, Go programming language and Software Engineering in general. In these videos I am planning to actually show you things by doing, instead of just talking about them; so that you would actually learn about them and can use them either at your work or as some other place.
My name is Vivek, I am Software Engineer working around Open Source and Cloud Native technologies around Kubernetes primarily using Go as programming language.
In this channel I am going to create videos about Containers, Kubernetes, Go programming language and Software Engineering in general. In these videos I am planning to actually show you things by doing, instead of just talking about them; so that you would actually learn about them and can use them either at your work or as some other place.
Implementing K8S Volume Populator | Writing a K8S Volume Populator from scratch - 3
This video is the next video in the series where we have been talking about the Kubernetes volume populators. In this video we actually write the volume populator and showed the end to end working of it.
GitHub repo: github.com/viveksinghggits/generichttppopulator
Docs and other things referred:
pkg.go.dev/k8s.io/api/core/v1#TypedObjectReference
kubernetes.io/docs/concepts/storage/persistent-volumes/#persistentvolumeclaims
kubernetes.io/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions/#create-a-customresourcedefinition
kubernetes.io/blog/2022/05/16/volume-populators-beta/#trying-it-out
Web:
viveksingh.dev/
00:00 Introduction
00:23 Agenda
01:01 Creating project and which populator are we writing
06:00 Specifying dataSourceRef
07:07 CRD for our GenericHTTPPopulator
11:03 Creating and instance of GenericHTTPPopulator
14:35 Demoing data source validator
21:21 Registering our populator GenericHTTPPopulator
25:49 Arch. of populator controller
28:52 Writing controller
37:36 Explaining arguments to populator machinery's RunController
40:55 Resuming writing controller
54:06 Implementing populator
01:04:22 Build and containerise the project
01:07:09 Deployment manifest for controller
01:08:23 Specifying args in deployment manifest
01:10:09 RBAC for controller (populator machinery)
01:13:51 Testing the populator E2E
01:18:15 Consume PVC to check populated volume
01:21:58 Summary
01:25:15 Like, Share, Subscribe
GitHub repo: github.com/viveksinghggits/generichttppopulator
Docs and other things referred:
pkg.go.dev/k8s.io/api/core/v1#TypedObjectReference
kubernetes.io/docs/concepts/storage/persistent-volumes/#persistentvolumeclaims
kubernetes.io/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions/#create-a-customresourcedefinition
kubernetes.io/blog/2022/05/16/volume-populators-beta/#trying-it-out
Web:
viveksingh.dev/
00:00 Introduction
00:23 Agenda
01:01 Creating project and which populator are we writing
06:00 Specifying dataSourceRef
07:07 CRD for our GenericHTTPPopulator
11:03 Creating and instance of GenericHTTPPopulator
14:35 Demoing data source validator
21:21 Registering our populator GenericHTTPPopulator
25:49 Arch. of populator controller
28:52 Writing controller
37:36 Explaining arguments to populator machinery's RunController
40:55 Resuming writing controller
54:06 Implementing populator
01:04:22 Build and containerise the project
01:07:09 Deployment manifest for controller
01:08:23 Specifying args in deployment manifest
01:10:09 RBAC for controller (populator machinery)
01:13:51 Testing the populator E2E
01:18:15 Consume PVC to check populated volume
01:21:58 Summary
01:25:15 Like, Share, Subscribe
มุมมอง: 608
วีดีโอ
Internal architecture of K8S Volume Populators | Writing a K8S Volume Populator from scratch - 2
มุมมอง 399ปีที่แล้ว
In this video we looked into the dataSourceRef field of PersistentVolumeClaim resource in detail and discussed what are valid and invalid volume populators. A part from that we also looked into the internal architecture of how volume populators are going to be written. We talked about the architecture in detail and in the next video we are going to actually write the controller. Web: viveksingh...
DataSource and DataSourceRef for PVC resources | Writing a K8S Volume Populator from scratch - 1
มุมมอง 666ปีที่แล้ว
This video is the first video in the series where we are going to write a Volume Populator from scratch, and in this video we looked into the DataSource and DataSourceRef field of PVC resource. We talked about these resources in details for example how they can be used to create volume from existing PVC or volume snapshot resource. A part from that we also talked about the difference between th...
Using veth network interface to connect two network namespaces | Kubernetes Networking | Part - 1
มุมมอง 1.9Kปีที่แล้ว
This is first video of the series in which I am going to talk about Kubernetes networking in details. In this video looked into how two processes that are running in two different network namespace can communicate with each other. Video about network namespaces: th-cam.com/video/7t_OTxJfB_o/w-d-xo.html Web: viveksingh.dev/ GitHub Repo with commands: github.com/viveksinghggits/cross-nwnamespace-...
What are Kubernetes Finalizers? | Implementing Kubernetes finalizer for a resource
มุมมอง 2.8K2 ปีที่แล้ว
In this video we talked about what exactly are Kubernetes finalizers and how they are useful in making sure that we can make sure a condition is met before the Kubernetes resource is deleted. Apart from that we also looked into how we can implement a respecitve controller for the finalizer that wold delete it, once that condition is met. Kluster Playlist: th-cam.com/video/89PdRvRUcPU/w-d-xo.htm...
Implementing NodePublishVolume of NodePlugin | Writing a Kubernetes CSI plug-in from scratch -9
มุมมอง 6272 ปีที่แล้ว
In this video we concluded writing the CSI plugin that we have been writing in some of the previous videos. We specifically implemented NodePublishVolume RPC of the node plugin in this video that mounts the volume from the staging dir to the target dir. After implementing the NodePlublishVolume we showed how the volume request (PVC) that was created using this new CSI Plugin was actually fulfil...
Mounting attached volume to a staging directory | Writing a Kubernetes CSI plug-in from scratch -8
มุมมอง 5002 ปีที่แล้ว
In this video we continued writing the CSI plugin that we have been writing in previous videos in this series and implemented the NodeGetCapabilities and NodeStageVolume RPCs of the node plugin. This RPC (NodeStageVolume) is called after the ControllerPublishVolume of the controller plugin was successful and Node plugin has specified that is supports stage and unstage of volumes (using NodeGetC...
Implement ControllerPublishVolume of Plugin | Writing a Kubernetes CSI plug-in from scratch -7
มุมมอง 4972 ปีที่แล้ว
In this video we implemented the ControllerPublishVolume RPC of Controller plugin that gets called by external attacher to attach a volume to a specific node. This is the volume that was created by CreateVolume RPC of the Controller plugin. GitHub: github.com/viveksinghggits/bsos Writing CSI Plugin from Scratch Playlist: th-cam.com/video/OIpX7WkJzOg/w-d-xo.html Web: viveksingh.dev/ 00:00 Introd...
Deploy node plugin and node-driver-registrar | Writing a Kubernetes CSI plug-in from scratch -6
มุมมอง 6592 ปีที่แล้ว
In this video we tried to make sure that the ControllerPublishVolume RPC of the controller plugin is being called for the VolumeAttachment resources in the Kubernetes cluster. We know that once PV resource is created by external provisioner and we try to use the volume in a workload, attach-detach controller creates VolumeAttachment resource. To make sure that VolumeAttachment resources are wat...
Implement CreateVolume RPC of Controller Service | Writing a Kubernetes CSI plug-in from scratch -5
มุมมอง 9322 ปีที่แล้ว
We actually went ahead and implemented CreateVolume RPC of the controller service form the CSI plugin. As described in the CSI specification, CreateVolume method/RPC from controller service gets called as soon as a volume is requested from Container Orchestrator, in our case Kubernetes. We also looked, in detail, into how the input object to create volume request looks like. For example AccessM...
Deploying ext.-provisioner and controller plugin | Writing a Kubernetes CSI plug-in from scratch -4
มุมมอง 8882 ปีที่แล้ว
In this videos we tried to deploy the skeleton CSI plugin that we have written till now in this series. We discussed in detail about how we are going to create the unix domain socket where the gRPC server is going to run at and how to make the external provisioner aware of that unix domain socket using volume that is mounted on both the directories. Once deployed we also looked into the workflo...
Setting up the gRPC server for CSI plug-in | Writing a Kubernetes CSI plug-in from scratch -3
มุมมอง 1.1K2 ปีที่แล้ว
In this video we actually started coding the CSI plugin specifically for DigitalOcan. So, using this plugin we would be able to provision volumes on DigitalOcean dynamically. In this we actually set up the gRPC server and registered the service implementations with the server. Web: viveksingh.dev/ GitHub of bsos: github.com/viveksinghggits/bsos DigitalOcean CSI GitHub: github.com/digitalocean/c...
How Kubernetes communicates with CSI Plugin | Writing a Kubernetes CSI plug-in from scratch -2
มุมมอง 1.6K2 ปีที่แล้ว
In this video we talked about Kubernetes or other Kubernetes components can communicate with CSI plug-in to call the appropriate RPC to manage the Volumes on Kubernetes. We also looked into the ways we are going to deploy these components (node plugin and controller plugin) with the external components on a Kubernetes cluster. We also talked about all the external components (external-provision...
What is Kubernetes CSI plugin and Specification | Writing a Kubernetes CSI plug-in from scratch -1
มุมมอง 4.1K2 ปีที่แล้ว
In this video we started talking about dynamic and static provisioning of volumes on Kubernetes cluster and then what is in-tree and out of tree mechanism to support creating volumes on specific storage providers. Later we started talking about what exactly is CSI specification and what is CSI plugin that storage providers can write to make sure Container Orchestrators can call the plugins to p...
Get complete GVR (Group Version Resource) for Kubernetes Resource | Demo of RESTMapper interface
มุมมอง 2.4K2 ปีที่แล้ว
In this video we looked into how we can get the complete GVR (Group Version Resource) for a specified Kubernetes resource. Web: viveksingh.dev/ GitHub: github.com/viveksinghggits/restmapper 00:00 Introduction 00.24 Agenda 03:22 RestMapper.ResourceFor 04:51 How do we get RestMapper instance 06:31 Implementation 16:05 Demo 17:40 Testing for Custom Resource types 19:56 Discovery Cache and Dir 22:0...
Linux cgroups explained | limit resources for a set of processes
มุมมอง 9K2 ปีที่แล้ว
Linux cgroups explained | limit resources for a set of processes
Kubernetes Dynamic Client | Interacting with CRs without having generated code
มุมมอง 3.1K2 ปีที่แล้ว
Kubernetes Dynamic Client | Interacting with CRs without having generated code
Writing Mutating Admission Controller from Scratch | Mutating Webhook Kubernetes
มุมมอง 1.8K2 ปีที่แล้ว
Writing Mutating Admission Controller from Scratch | Mutating Webhook Kubernetes
What is Aggregated API Server | Difference between Aggregated API Server and CRDs
มุมมอง 2.7K2 ปีที่แล้ว
What is Aggregated API Server | Difference between Aggregated API Server and CRDs
Handling AdmissionReview object | Writing Validating Webhook Controller From Scratch - Final
มุมมอง 1.2K3 ปีที่แล้ว
Handling AdmissionReview object | Writing Validating Webhook Controller From Scratch - Final
Writing Validating Webhook Controller From Scratch - 1 | Validating Webhook Kubernetes
มุมมอง 4K3 ปีที่แล้ว
Writing Validating Webhook Controller From Scratch - 1 | Validating Webhook Kubernetes
Adding users to a managed Kubernetes cluster | Generating private key and certificate
มุมมอง 3K3 ปีที่แล้ว
Adding users to a managed Kubernetes cluster | Generating private key and certificate
Anatomy of Persistent Volume Controller in Kubernetes | Code walk through
มุมมอง 1.1K3 ปีที่แล้ว
Anatomy of Persistent Volume Controller in Kubernetes | Code walk through
Admission Controllers in Kubernetes | Mutating and Validating Webhooks in Kubernetes
มุมมอง 7K3 ปีที่แล้ว
Admission Controllers in Kubernetes | Mutating and Validating Webhooks in Kubernetes
Supporting multiple versions (v1alpha1, v1beta1) of CR in Kubernetes | Conversion Webhook Explained
มุมมอง 2.2K3 ปีที่แล้ว
Supporting multiple versions (v1alpha1, v1beta1) of CR in Kubernetes | Conversion Webhook Explained
Packaging (containerise and RBAC) your K8S operator as a developer | Writing K8S Operator - Part 6
มุมมอง 8833 ปีที่แล้ว
Packaging (containerise and RBAC) your K8S operator as a developer | Writing K8S Operator - Part 6
Event recorder for Kluster and routines to handle Objects from Queue | Writing K8S Operator - Part 5
มุมมอง 1.1K3 ปีที่แล้ว
Event recorder for Kluster and routines to handle Objects from Queue | Writing K8S Operator - Part 5
Setting up 3 node Kubernetes cluster version 1.22 from scratch, on Ubuntu instances
มุมมอง 6K3 ปีที่แล้ว
Setting up 3 node Kubernetes cluster version 1.22 from scratch, on Ubuntu instances
SubResources and additional printer columns for CRDs | Writing K8S Operator - Part 4
มุมมอง 1.5K3 ปีที่แล้ว
SubResources and additional printer columns for CRDs | Writing K8S Operator - Part 4
Calling DigitalOcean APIs on Kluster's add event | Writing K8S Operator - Part 3
มุมมอง 1.2K3 ปีที่แล้ว
Calling DigitalOcean APIs on Kluster's add event | Writing K8S Operator - Part 3
from 23:52 i was telling you, you forgot to do the go build 😀 only if i could catch such mistakes of my own 😅 Thanks for the useful content👍 -mytreya
Lovely explaination, However can't we use unshare api call to create a isolated filesystem using mount namespace instead of using chroot
Thank you for the great video
Very useful and informative Thanks
now a serviceAccount created do not have a secret , its null now , how to get Authorization token from
THANK you nice explaination
I have an issue with my application running in a Kubernetes cluster and exposed via Ingress. The application displays correctly when I access the public IP or domain name, but I encounter 404 errors for routes such as `/Api/admin/category` and `/Api/admin/courses`. All my backend routes start with `/Api`. In my Ingress configuration, I mapped `/` to the frontend and `/Api` to the backend. Can u help me please
Thank you for making such detailed videos and taking the time to explain the k8s codebase!
Great video. Thank you so much!
Very good one! Everything was explained simply-even I understood it.
amazing content
Your videos are much better than paid sessions.Thank you for your effort.
Thank you for watching.
@Vivek Singh : Could you make a video on using key and certs stored in pem files
Hi Vivek,thank you for your efforts! You mentioned that the CP should run on the master nodes, and the NP on the worker nodes. However, when I apply the CSI driver, I’m seeing a CrashLoopBackOff error. After investigating, I found that both CP pods and NP pods are running on both master and worker nodes. It seems like the taints/tolerations may need modification. Could you clarify why the default behavior doesn't match what you explained?
How we can implement that issue of informer trying to resync after few minutes even if there is no change in the resources?
good videos
keep making these videos bhai..thanks a lot
Pls create more videos ❤(given, if you're not busy in life and have time to give us this superb content) Thank you so much!!
Thank you. What would you like me to make videos on?
This is so informational thanks so much!!
very exciting start
I think this could be more obvious =) ``` if err != nil && os.IsExists { //... } ```
can we add informers to Custom resources
Yes, we can do that. I think I have a video about that.
Thanks Sir !!
Sir, I have a multiple microservices how can i access all the microservices with DNS through ingress. Please help 🙏 🙏 me I have stuck on it from long days
audio having some issue
Thankyou very much . I am very close to understanding the internals of containerization.
Great session
file kaha pe milagi ??
Vivek sir can you please revamp your k8s series lot of stuff has changed.
Do you have anything specific in your mind that I should look into?
Great video, cleared most of my confusion. Thank you
Thank you. I am glad it helped.
Great content, Thanks🙂
Thank you.
"I should not have done that" LOL!
great vai
Thank you.
This helped me a lot! Could you please make a video on authentication mechanisms
Awesome Content! Understood the architecture clearly. Also could you share the terminal font you were using in this video :-)
Great video man, thanks for this, im looking forward to complete the whole series ASAP!
Great video :)
Hey Vivek. Thank you for the very detailed explanation. It was super helpful!
Nice video Vivek, really helped me a lot. Also, I want to read further about CR and CRDs so can anyone help me with some resources for it?
Great one
Thank you.
Sir how can i access for domain i have add domain i am accessing within cluster but i can't access in external world in my domain what i should add in dns for access my application in my domain
Awesome stuff!
Please fix your sound
Great content
Thanks It's Great Keep going
Thank you.
There are two processes here..1) the terminal 2) the go executable. The memory constraint is applied to which process? If it applies to the terminal, commenting out the fmt on line21 should allow the go process to execute? If it applies to the go binary, does it inherit the constraint from its parent process, terminal in this case???
Hi Amarjeet, I might be a bit off here, so please read more about it. But if I try to answer your question, the terminal would not be considered a process running in the shell. It would be the programs that we are running from the shell like we ran the go program. For the second question, I am not really sure which constraints are you talking about. If you are talking about memory it can use, we saw that we can configure that using cgroup. If you are talking about the resources that are not configured using cgroup, I am not really sure about that right now. I will have to check that.
Highly appreciate your effort Vivek 🙏
Thank you.
hi Vivek, how we can contact you,
There is a link on my website to schedule a call with me.
best video for service account explanation 💪💪
Thank you.
excellent videos . do you have git repo for kubernetes or gendral things for devops
github.com/viveksinghggits