Skip to content

Commit

Permalink
Merge pull request kubernetes#24774 from tengqm/fix-21226
Browse files Browse the repository at this point in the history
Resync tutorial page expose external IP address
  • Loading branch information
k8s-ci-robot authored Oct 30, 2020
2 parents 04b4e4c + f1e5b34 commit a1331a2
Showing 1 changed file with 112 additions and 113 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,10 @@ title: 公开外部 IP 地址以访问集群中应用程序
content_type: tutorial
weight: 10
---

<!--
---
title: Exposing an External IP Address to Access an Application in a Cluster
content_type: tutorial
weight: 10
---
-->

<!-- overview -->
Expand All @@ -20,12 +17,8 @@ external IP address.
-->
此页面显示如何创建公开外部 IP 地址的 Kubernetes 服务对象。




## {{% heading "prerequisites" %}}


<!--
* Install [kubectl](/docs/tasks/tools/install-kubectl/).
Expand All @@ -40,30 +33,23 @@ external IP address.

* 安装 [kubectl](/zh/docs/tasks/tools/install-kubectl/).

* 使用 Google Kubernetes Engine 或 Amazon Web Services 等云供应商创建 Kubernetes 群集。
本教程创建了一个[外部负载均衡器](/zh/docs/tasks/access-application-cluster/create-external-load-balancer/),需要云供应商。
* 使用 Google Kubernetes Engine 或 Amazon Web Services 等云供应商创建 Kubernetes 集群。
本教程创建了一个[外部负载均衡器](/zh/docs/tasks/access-application-cluster/create-external-load-balancer/)
需要云供应商。

* 配置 `kubectl` 与 Kubernetes API 服务器通信。有关说明,请参阅云供应商文档。




## {{% heading "objectives" %}}


<!--
* Run five instances of a Hello World application.
* Create a Service object that exposes an external IP address.
* Use the Service object to access the running application.
-->

* 运行 Hello World 应用程序的五个实例。
* 创建一个公开外部 IP 地址的 Service 对象。
* 使用 Service 对象访问正在运行的应用程序。




<!-- lessoncontent -->

<!--
Expand All @@ -77,118 +63,130 @@ external IP address.
-->
1. 在集群中运行 Hello World 应用程序:

{{< codenew file="service/load-balancer-example.yaml" >}}

```shell
kubectl apply -f https://k8s.io/examples/service/load-balancer-example.yaml
```

<!--
The preceding command creates a
[Deployment](/docs/concepts/workloads/controllers/deployment/)
object and an associated
[ReplicaSet](/docs/concepts/workloads/controllers/replicaset/)
object. The ReplicaSet has five
[Pods](/docs/concepts/workloads/pods/pod/),
each of which runs the Hello World application.
-->
前面的命令创建一个 [Deployment](/zh/docs/concepts/workloads/controllers/deployment/)
对象和一个关联的 [ReplicaSet](/zh/docs/concepts/workloads/controllers/replicaset/)对象。
ReplicaSet 有五个 [Pod](/zh/docs/concepts/workloads/pods/pod/),每个都运行 Hello World 应用程序。
{{< codenew file="service/load-balancer-example.yaml" >}}

```shell
kubectl apply -f https://k8s.io/examples/service/load-balancer-example.yaml
```

<!--
The preceding command creates a
{{< glossary_tooltip text="Deployment" term_id="deployment" >}}
and an associated
{{< glossary_tooltip term_id="replica-set" text="ReplicaSet" >}}.
The ReplicaSet has five
{{< glossary_tooltip text="Pods" term_id="pod" >}}
each of which runs the Hello World application.
-->
前面的命令创建一个
{{< glossary_tooltip text="Deployment" term_id="deployment" >}}
对象和一个关联的
{{< glossary_tooltip term_id="replica-set" text="ReplicaSet" >}} 对象。
ReplicaSet 有五个 {{< glossary_tooltip text="Pods" term_id="pod" >}},
每个都运行 Hello World 应用程序。

<!--
1. Display information about the Deployment:
-->
2. 显示有关 Deployment 的信息:

kubectl get deployments hello-world
kubectl describe deployments hello-world
```shell
kubectl get deployments hello-world
kubectl describe deployments hello-world
```

<!--
1. Display information about your ReplicaSet objects:
-->
3. 显示有关 ReplicaSet 对象的信息:

kubectl get replicasets
kubectl describe replicasets
```shell
kubectl get replicasets
kubectl describe replicasets
```

<!--
1. Create a Service object that exposes the deployment:
-->
4. 创建公开 deployment 的 Service 对象:
4. 创建公开 Deployment 的 Service 对象:

kubectl expose deployment hello-world --type=LoadBalancer --name=my-service
```shell
kubectl expose deployment hello-world --type=LoadBalancer --name=my-service
```

<!--
1. Display information about the Service:
-->
5. 显示有关 Service 的信息:

kubectl get services my-service
```shell
kubectl get services my-service
```

<!--
<!--
The output is similar to this:
-->
-->
输出类似于:

NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
my-service ClusterIP 10.3.245.137 104.198.205.71 8080/TCP 54s

<!--
{{< note >}}
The `type=LoadBalancer` service is backed by external cloud providers, which is not covered in this example, please refer to [this page](/docs/concepts/services-networking/service/#loadbalancer) for the details.
{{< /note >}}
-->
注意:`type=LoadBalancer` 服务由外部云服务提供商提供支持,本例中不包含此部分,详细信息请参考[此页](/docs/concepts/services-networking/service/#loadbalancer)

<!--
{{< note >}}
If the external IP address is shown as \<pending\>, wait for a minute and enter the same command again.
{{< /note >}}
-->
注意:如果外部 IP 地址显示为 \<pending\>,请等待一分钟再次输入相同的命令。
```
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
my-service ClusterIP 10.3.245.137 104.198.205.71 8080/TCP 54s
```

<!--
{{< note >}}
The `type=LoadBalancer` service is backed by external cloud providers, which is not covered in this example, please refer to [this page](/docs/concepts/services-networking/service/#loadbalancer) for the details.
{{< /note >}}
-->
提示:`type=LoadBalancer` 服务由外部云服务提供商提供支持,本例中不包含此部分,
详细信息请参考[此页](/docs/concepts/services-networking/service/#loadbalancer)

<!--
{{< note >}}
If the external IP address is shown as \<pending\>, wait for a minute and enter the same command again.
{{< /note >}}
-->
提示:如果外部 IP 地址显示为 \<pending\>,请等待一分钟再次输入相同的命令。

<!--
1. Display detailed information about the Service:
-->
6. 显示有关 Service 的详细信息:

kubectl describe services my-service
```shell
kubectl describe services my-service
```

<!--
<!--
The output is similar to this:
-->
-->
输出类似于:

Name: my-service
Namespace: default
Labels: run=load-balancer-example
Annotations: <none>
Selector: run=load-balancer-example
Type: LoadBalancer
IP: 10.3.245.137
LoadBalancer Ingress: 104.198.205.71
Port: <unset> 8080/TCP
NodePort: <unset> 32377/TCP
Endpoints: 10.0.0.6:8080,10.0.1.6:8080,10.0.1.7:8080 + 2 more...
Session Affinity: None
Events: <none>

<!--
```
Name: my-service
Namespace: default
Labels: run=load-balancer-example
Annotations: <none>
Selector: run=load-balancer-example
Type: LoadBalancer
IP: 10.3.245.137
LoadBalancer Ingress: 104.198.205.71
Port: <unset> 8080/TCP
NodePort: <unset> 32377/TCP
Endpoints: 10.0.0.6:8080,10.0.1.6:8080,10.0.1.7:8080 + 2 more...
Session Affinity: None
Events: <none>
```
<!--
Make a note of the external IP address (`LoadBalancer Ingress`) exposed by
your service. In this example, the external IP address is 104.198.205.71.
Also note the value of `Port` and `NodePort`. In this example, the `Port`
is 8080 and the `NodePort` is 32377.
-->
-->
记下服务公开的外部 IP 地址(`LoadBalancer Ingress`)。
在本例中,外部 IP 地址是 104.198.205.71。还要注意 `Port``NodePort` 的值。
在本例中,`Port` 是 8080,`NodePort` 是32377。


<!--
1. In the preceding output, you can see that the service has several endpoints:
10.0.0.6:8080,10.0.1.6:8080,10.0.1.7:8080 + 2 more. These are internal
Expand All @@ -200,78 +198,79 @@ If the external IP address is shown as \<pending\>, wait for a minute and enter
这些都是正在运行 Hello World 应用程序的 pod 的内部地址。
要验证这些是 pod 地址,请输入以下命令:

kubectl get pods --output=wide
```shell
kubectl get pods --output=wide
```

<!--
<!--
The output is similar to this:
-->
-->
输出类似于:

NAME ... IP NODE
hello-world-2895499144-1jaz9 ... 10.0.1.6 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-2e5uh ... 10.0.1.8 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-9m4h1 ... 10.0.0.6 gke-cluster-1-default-pool-e0b8d269-5v7a
hello-world-2895499144-o4z13 ... 10.0.1.7 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-segjf ... 10.0.2.5 gke-cluster-1-default-pool-e0b8d269-cpuc

```
NAME ... IP NODE
hello-world-2895499144-1jaz9 ... 10.0.1.6 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-2e5uh ... 10.0.1.8 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-9m4h1 ... 10.0.0.6 gke-cluster-1-default-pool-e0b8d269-5v7a
hello-world-2895499144-o4z13 ... 10.0.1.7 gke-cluster-1-default-pool-e0b8d269-1afc
hello-world-2895499144-segjf ... 10.0.2.5 gke-cluster-1-default-pool-e0b8d269-cpuc
```
<!--
1. Use the external IP address (`LoadBalancer Ingress`) to access the Hello
World application:
-->
8. 使用外部 IP 地址(`LoadBalancer Ingress`)访问 Hello World 应用程序:

curl http://<external-ip>:<port>
```shell
curl http://<external-ip>:<port>
```

<!--
<!--
where `<external-ip>` is the external IP address (`LoadBalancer Ingress`)
of your Service, and `<port>` is the value of `Port` in your Service
description.
If you are using minikube, typing `minikube service my-service` will
automatically open the Hello World application in a browser.
-->
-->
其中 `<external-ip>` 是您的服务的外部 IP 地址(`LoadBalancer Ingress`),
`<port>` 是您的服务描述中的 `port` 的值。
如果您正在使用 minikube,输入 `minikube service my-service` 将在浏览器中自动打开 Hello World 应用程序。

<!--
<!--
The response to a successful request is a hello message:
-->
-->
成功请求的响应是一条问候消息:

Hello Kubernetes!



```
Hello Kubernetes!
```

## {{% heading "cleanup" %}}


<!--
To delete the Service, enter this command:
-->
要删除服务,请输入以下命令:

kubectl delete services my-service
```shell
kubectl delete services my-service
```

<!--
To delete the Deployment, the ReplicaSet, and the Pods that are running
the Hello World application, enter this command:
-->
要删除正在运行 Hello World 应用程序的 Deployment,ReplicaSet 和 Pod,请输入以下命令:

kubectl delete deployment hello-world



```shell
kubectl delete deployment hello-world
```

## {{% heading "whatsnext" %}}


<!--
Learn more about
[connecting applications with services](/docs/concepts/services-networking/connect-applications-service/).
-->

了解更多关于[将应用程序与服务连接](/zh/docs/concepts/services-networking/connect-applications-service/)

进一步了解[将应用程序与服务连接](/zh/docs/concepts/services-networking/connect-applications-service/)

0 comments on commit a1331a2

Please sign in to comment.