无法在 gke 集群上部署带有通量的 Git 存储库接收器

Posted

技术标签:

【中文标题】无法在 gke 集群上部署带有通量的 Git 存储库接收器【英文标题】:Unable to deploy Git repository receiver with flux on gke cluster 【发布时间】:2021-05-18 22:12:23 【问题描述】:

通过在 GKE 上设置一个带有通量的 webhook 接收器,我一直在弄脏我的手,我遵循了这个 guide 的说明。根据它,我需要部署 Git 存储库接收器,如下所示:

apiVersion: notification.toolkit.fluxcd.io/v1beta1
kind: Receiver
metadata:
  name: webapp
  namespace: flux-system
spec:
  type: github
  events:
    - "ping"
    - "push"
  secretRef:
    name: webhook-token
  resources:
    - kind: GitRepository
      name: webapp

当我在具有 k8s 版本 1.18.12 的 gke 集群上应用相同时,我收到以下错误

prkumar@cloudshell:~ (portworx-eng)$ kubectl apply -f GitRepository.yml
error: unable to recognize "GitRepository.yml": no matches for kind "Receiver" in version "notification.toolkit.fluxcd.io/v1beta1"

我试图检查 CRD 是否存在,但我找不到任何东西:

prkumar@cloudshell:~ (portworx-eng)$ kubectl get customresourcedefinitions --all-namespaces
NAME                                                         CREATED AT
actionapprovals.autopilot.libopenstorage.org                 2021-02-15T16:22:04Z
applicationbackups.stork.libopenstorage.org                  2021-02-15T16:22:32Z
applicationbackupschedules.stork.libopenstorage.org          2021-02-15T16:22:47Z
applicationclones.stork.libopenstorage.org                   2021-02-15T16:22:42Z
applicationregistrations.stork.libopenstorage.org            2021-02-15T16:22:27Z
applicationrestores.stork.libopenstorage.org                 2021-02-15T16:22:37Z
autopilotruleobjects.autopilot.libopenstorage.org            2021-02-15T16:21:59Z
autopilotrules.autopilot.libopenstorage.org                  2021-02-15T16:21:59Z
backendconfigs.cloud.google.com                              2021-02-15T15:35:57Z
backuplocations.stork.libopenstorage.org                     2021-02-15T16:22:22Z
clusterdomainsstatuses.stork.libopenstorage.org              2021-02-15T16:22:12Z
clusterdomainupdates.stork.libopenstorage.org                2021-02-15T16:22:17Z
clusterpairs.stork.libopenstorage.org                        2021-02-15T16:21:57Z
frontendconfigs.networking.gke.io                            2021-02-15T15:35:59Z
groupvolumesnapshots.stork.libopenstorage.org                2021-02-15T16:21:51Z
managedcertificates.networking.gke.io                        2021-02-15T15:35:22Z
migrations.stork.libopenstorage.org                          2021-02-15T16:22:02Z
migrationschedules.stork.libopenstorage.org                  2021-02-15T16:22:07Z
rules.stork.libopenstorage.org                               2021-02-15T16:21:31Z
schedulepolicies.stork.libopenstorage.org                    2021-02-15T16:21:36Z
servicenetworkendpointgroups.networking.gke.io               2021-02-15T15:35:59Z
storagestates.migration.k8s.io                               2021-02-15T15:35:26Z
storageversionmigrations.migration.k8s.io                    2021-02-15T15:35:26Z
updateinfos.nodemanagement.gke.io                            2021-02-15T15:35:27Z
volumeplacementstrategies.portworx.io                        2021-02-15T16:20:24Z
volumesnapshotclasses.snapshot.storage.k8s.io                2021-02-15T15:35:25Z
volumesnapshotcontents.snapshot.storage.k8s.io               2021-02-15T15:35:25Z
volumesnapshotdatas.volumesnapshot.external-storage.k8s.io   2021-02-15T16:21:41Z
volumesnapshotrestores.stork.libopenstorage.org              2021-02-15T16:21:46Z
volumesnapshots.snapshot.storage.k8s.io                      2021-02-15T15:35:25Z
volumesnapshots.volumesnapshot.external-storage.k8s.io       2021-02-15T16:21:41Z
volumesnapshotschedules.stork.libopenstorage.org             2021-02-15T16:21:41Z
prkumar@cloudshell:~ (portworx-eng)$

豆荚

prkumar@cloudshell:~ (portworx-eng)$ kubectl get pods --all-namespaces
NAMESPACE     NAME                                                             READY   STATUS    RESTARTS   AGE
demo          podinfo-58df84dbff-4wcl4                                         1/1     Running   0          9h
demo          podinfo-58df84dbff-54rbg                                         1/1     Running   0          9h
flux          flux-86845fff46-p6bdz                                            1/1     Running   0          9h
flux          memcached-5bd7849b84-k4g2h                                       1/1     Running   0          9h
kube-system   autopilot-859d58c8c4-x59b6                                       1/1     Running   0          10h
kube-system   event-exporter-gke-564fb97f9-2l4fp                               2/2     Running   0          10h
kube-system   fluentbit-gke-j42rm                                              2/2     Running   0          10h
kube-system   fluentbit-gke-ngv2c                                              2/2     Running   0          10h
kube-system   fluentbit-gke-zqjk4                                              2/2     Running   0          10h
kube-system   gke-metrics-agent-n7255                                          1/1     Running   0          10h
kube-system   gke-metrics-agent-rbc2b                                          1/1     Running   1          10h
kube-system   gke-metrics-agent-wmndz                                          1/1     Running   0          10h
kube-system   kube-dns-6bd88c9b66-dtn5c                                        4/4     Running   0          10h
kube-system   kube-dns-6bd88c9b66-jkq6w                                        4/4     Running   0          10h
kube-system   kube-dns-autoscaler-7f89fb6b79-6bbn2                             1/1     Running   0          10h
kube-system   kube-proxy-gke-prashanth-cluster-te-default-pool-28f88aed-0jhg   1/1     Running   0          10h
kube-system   kube-proxy-gke-prashanth-cluster-te-default-pool-28f88aed-3k7t   1/1     Running   0          10h
kube-system   kube-proxy-gke-prashanth-cluster-te-default-pool-28f88aed-hrxd   1/1     Running   0          10h
kube-system   l7-default-backend-7fd66b8b88-7h8jj                              1/1     Running   0          10h

欢迎任何帮助或建议。

-普拉桑特

【问题讨论】:

【参考方案1】:

问题在于未安装的助焊剂工具包。按照以下链接中的文档帮助我解决了这个问题。 https://github.com/fluxcd/kustomize-controller

【讨论】:

【参考方案2】:

根据文档,您的清单似乎有误。

要使用 Webhook Receivers 部署 Git 存储库,您必须牢记:

In order to receive Git push or Helm chart upload events, you'll have to expose the 
webhook receiver endpoint outside of your Kubernetes cluster on a public address.

助焊剂文档建议您做的是:

    创建 LoadBalancer 服务。 为其分配公共地址。 定义 Git 存储库。 定义一个 Git 存储库接收器。

您可以在文档的link 中一步一步地对您的文件进行配置。

【讨论】:

感谢您的回复。我确实使用公共地址公开了集群,但这里的问题似乎是“与类型“接收者”不匹配”,我怀疑这与公共地址有关。当我定义一个 Git 存储库接收器时,看到了问题。 如果你去文档你会发现他们没有设置kind: Receiver,他们设置了kind: Service。尝试按照文档中的示例进行操作,让我知道它是否有效。 我能够添加服务,但是当我转到定义 Git 存储库接收器的步骤时,通过以下更改它给了我错误 apiVersion: notification.toolkit.fluxcd.io/v1beta1 kind: Receiver metadata:名称:webapp 命名空间:flux-system 规范:类型:github 我得到了同样的解决方案。未安装 Flux 工具包,点击此链接 github.com/fluxcd/kustomize-controller 现在可以应用规范。 太棒了!您能否发布一个答案,以便社区中遇到类似问题的任何人也可以找到解决方案?

以上是关于无法在 gke 集群上部署带有通量的 Git 存储库接收器的主要内容,如果未能解决你的问题,请参考以下文章

在 GKE 集群上使用 Terraform 部署 Helm 工作负载

将现有 GKE 集群添加到 terraform stat 文件

使用 Terraform 部署时 GKE Autopilot 无法调度

无法在 GKE 上部署 mysql debezium 连接器 - 用户没有“锁定表”权限

在GKE专用集群上创建入口资源时超时

使用自定义网络的 gke 集群部署