草庐IT

k8s-Kubernetes

全部标签

go - 使用入口部署 Rest + gRPC 服务器部署到 k8s

我使用了示例gRPCHelloWorld应用程序https://github.com/grpc/grpc-go/tree/master/examples/helloworld.本示例在本地系统运行流畅。我想使用Ingress将它部署到kubernetes。下面是我的配置文件。service.yaml-作为NodePortapiVersion:v1kind:Servicemetadata:name:grpc-scratchlabels:run:grpc-scratchannotations:service.alpha.kubernetes.io/app-protocols:'{"grpc

go - kubernetes API中是否有通过注解获取所有服务的函数

我正在设置一个kubernet集群来部署我们的容器应用程序。应用程序实际上需要所有标签,但标签超过63个字符,我得到一个error.这使我依赖于注释。服务的注释如下所示:com.example.development.london/component.proxy-config.secure-routes.backend.proxy-path。/仅用于绕过RFC域错误。在Golang应用程序中,请求命名空间的所有服务。实际上基于标签。为此,到目前为止我使用了以下代码。func(kc*KubernetesCollector)generateRoutes(errorChannelchan但是

go - 从 Mutating Admission Controller 中创建一个新的 Kubernetes 对象

MutatingAdmissionController可以通过连接到api-server来更新/创建另一个对象吗?我看到我们可以使用JSONPatch通过AdmissionReview改变入站对象,但我可以扩展它来创建一个完全不同的对象吗?谢谢!!-斯雷尼 最佳答案 您可以创建一个mutatingwebhookconfigurations,它基本上将服务Hook到mutatingadmissioncontroller。这就是istio向所有启用了istio注入(inject)的pod注入(inject)sidecar代理的方式。可以

go - golang在kubernetes上创建监视程序/ Controller ,以将sidecar容器附加到具有PVC附件的任何pod/部署中

我是个新手,想把上面的事情做完。最简单的方法是什么?我要找的是:1-部署观察者2-更新/删除/添加部署时,将附加一个侧车(修补部署)3-控制来自侧车的反馈。任何参考都有帮助 最佳答案 我建议你看看webhooks这样你就不会重新发明轮子了。webhook可用于拦截对api服务器的资源(包括部署)更新/删除/创建请求。然后,可以根据您的目标修改或拒绝这些请求。 关于go-golang在kubernetes上创建监视程序/Controller,以将sidecar容器附加到具有PVC附件的任何

K8S集群中Node节点资源不足导致Pod无法运行的故障排查思路

K8S集群中Node节点资源不足导致Pod无法运行的故障排查思路文章目录K8S集群中Node节点资源不足导致Pod无法运行的故障排查思路1.Node节点资源不足可能会产生的故障2.Node节点资源不足故障排查案例一3.Node节点资源不足故障排查案例二1.Node节点资源不足可能会产生的故障故障一:Pod数量太多超出物理节点的限制每一台Node节点中默认限制最多运行110个Pod资源,当一个应用程序有成百上千的Pod资源时,如果不扩容Node节点或者修改最大Pod数量限制,那么就会导致部分Pod资源无法正常运行,因为节点已经没有资源可以被调度了。解决思路就是扩容Node节点数量或者修改Pod的

http - Golang for Kubernetes 中的自定义 404 错误页面

我正在尝试为我的Kubernetes集群实现一个自定义的default-http图像。我只有2个要求:任何图片都可以,只要:它在/提供404页面它在/healthz端点上为200人提供服务截至目前,我得到的是:1packagemain23import(4"fmt"5"net/http"6"html/template"7)89funcmain(){10http.HandleFunc("/healthz",healhtzHandler)11http.HandleFunc("/",errorHandler)12http.ListenAndServe(":8000",nil)13}1415fu

go - 使用 operator-framework 负载平衡 K8s Pod

我通过调整memcached示例构建了一个简单的运算符。唯一的主要区别是我的pod中需要两个docker镜像。让部署运行。我的test.yaml曾经使用kubectl进行部署。apiVersion:"cache.example.com/v1alpha1"kind:"Memcached"metadata:name:"solar-demo"spec:size:3group:cache.example.comnames:kind:MemcachedlistKind:MemcachedListplural:solar-demossingular:solar-demoscope:Namespac

go - 使用 Kubernetes 的 Go 客户端列出 Traefik 入口 Controller

我们有一个小的内部工具使用GoclientforKubernetes列出我们的Kubernetes服务.现在我们已经添加了Traefik以使用入口Controller将我们的服务映射到有意义的dns名称。我们看到有一个ingresslisterextension在Kubernetes的Go客户端中,可用于列出入口Controller。但是,我们无法让它发挥作用。是否有列出入口Controller的任何Go客户端代码片段? 最佳答案 到目前为止你尝试了什么?发布示例有帮助。尝试以下任意示例以帮助您入门://imports//metav

go - 为 Kubernetes go-client 使用 HTTP 代理

我正在使用go-clientforkubernetes来控制我的GKE集群上的部署,但此客户端将在代理后面运行,并且需要通过它发出所有与互联网绑定(bind)的请求。但我似乎无法找到一种方法来配置我的KubeClient以通过代理发出所有http请求。我的代码与此处的示例差别不大-https://github.com/kubernetes/client-go/blob/master/examples/out-of-cluster-client-configuration/main.go 最佳答案 当您使用配置(kubernetes.

go - 将自定义 kubernetes 调度程序部署为 pod

如何将自定义kubernetes调度程序部署为使用golang语言编写的pod? 最佳答案 我相信这是有据可查的heremy-scheduler.yaml类似这样的内容:apiVersion:v1kind:ServiceAccountmetadata:name:my-schedulernamespace:kube-system---kind:ClusterRoleBindingapiVersion:rbac.authorization.k8s.io/v1metadata:name:my-scheduler-as-kube-sched