使用 HTTP 代理访问 Kubernetes API

此页面展示了如何使用 HTTP 代理访问 Kubernetes API。

开始之前

您需要拥有一个 Kubernetes 集群,并且 kubectl 命令行工具必须配置为与您的集群通信。建议在至少有两个节点的集群上运行本教程,这些节点不充当控制平面主机。如果您还没有集群,可以使用 minikube 创建一个,或者可以使用以下 Kubernetes 游乐场之一

要检查版本,请输入 kubectl version

如果您还没有在集群中运行应用程序,请通过输入以下命令启动一个 Hello world 应用程序

kubectl create deployment hello-app --image=gcr.io/google-samples/hello-app:2.0 --port=8080

使用 kubectl 启动代理服务器

此命令启动到 Kubernetes API 服务器的代理

kubectl proxy --port=8080

探索 Kubernetes API

代理服务器运行后,您可以使用 curlwget 或浏览器探索 API。

获取 API 版本

curl https://#:8080/api/

输出应该类似于以下内容

{
  "kind": "APIVersions",
  "versions": [
    "v1"
  ],
  "serverAddressByClientCIDRs": [
    {
      "clientCIDR": "0.0.0.0/0",
      "serverAddress": "10.0.2.15:8443"
    }
  ]
}

获取 Pod 列表

curl https://#:8080/api/v1/namespaces/default/pods

输出应该类似于以下内容

{
  "kind": "PodList",
  "apiVersion": "v1",
  "metadata": {
    "resourceVersion": "33074"
  },
  "items": [
    {
      "metadata": {
        "name": "kubernetes-bootcamp-2321272333-ix8pt",
        "generateName": "kubernetes-bootcamp-2321272333-",
        "namespace": "default",
        "uid": "ba21457c-6b1d-11e6-85f7-1ef9f1dab92b",
        "resourceVersion": "33003",
        "creationTimestamp": "2016-08-25T23:43:30Z",
        "labels": {
          "pod-template-hash": "2321272333",
          "run": "kubernetes-bootcamp"
        },
        ...
}

下一步

详细了解 kubectl proxy

上次修改时间:2024 年 6 月 2 日凌晨 2:43 PST:修改图像 node-hello 为 hello-app (#46582) (d5b194da5b)