我使用以下简单的yaml文件创建了部署
kubectl apply -f deployment.yaml
deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-deployment
labels:
tier: frontend
app: myapp
spec:
selector:
matchLabels:
app: myapp
replicas: 3
template:
metadata:
name: nginx-pod
labels:
app: myapp
spec:
containers:
- name: nginx-pod
image: nginx
,然后使用以下yaml文件为其创建服务
kubectl apply -f service.yaml
service.yaml
apiVersion: v1
kind: Service
metadata:
name: myapp-service
spec:
type: NodePort
ports:
- port: 89
targetPort: 89
nodePort: 30009
selector:
app: myapp
现在我跑步
minikube service myapp-service
它给了我
$ minikube service myapp-service
|-----------|---------------|-------------|-------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|-----------|---------------|-------------|-------------------------|
| default | myapp-service | 89 | http://172.17.0.2:30009 |
|-----------|---------------|-------------|-------------------------|
? Starting tunnel for service myapp-service.
|-----------|---------------|-------------|------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|-----------|---------------|-------------|------------------------|
| default | myapp-service | | http://127.0.0.1:52289 |
|-----------|---------------|-------------|------------------------|
? Opening service default/myapp-service in default browser...
❗ Because you are using a Docker driver on darwin, the terminal needs to be open to run it.
,当我尝试访问给定的http://127.0.0.1:52289时,出现“无法访问此网站”错误。
yaml文件有什么问题吗?我正在使用
minikube版本:v1.12.1
$ kubectl version
Client Version: version.Info{Major:"1", Minor:"18", GitVersion:"v1.18.0", GitCommit:"9e991415386e4cf155a24b1da15becaa390438d8", GitTreeState:"clean", BuildDate:"2020-03-25T14:58:59Z", GoVersion:"go1.13.8", Compiler:"gc", Platform:"darwin/amd64"}
Server Version: version.Info{Major:"1", Minor:"18", GitVersion:"v1.18.3", GitCommit:"2e7996e3e2712684bc73f0dec0200d64eec7fe40", GitTreeState:"clean", BuildDate:"2020-05-20T12:43:34Z", GoVersion:"go1.13.9", Compiler:"gc", Platform:"linux/amd64"}
Docker版本
$ docker version
Client: Docker Engine - Community
Version: 19.03.8
API version: 1.40
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:21:11 2020
OS/Arch: darwin/amd64
Experimental: false
Server: Docker Engine - Community
Engine:
Version: 19.03.8
API version: 1.40 (minimum version 1.12)
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:29:16 2020
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: v1.2.13
GitCommit: 7ad184331fa3e55e52b890ea95e65ba581ae3429
runc:
Version: 1.0.0-rc10
GitCommit: dc9208a3303feef5b3839f4323d9beb36df0a9dd
docker-init:
Version: 0.18.0
GitCommit: fec3683
答案 0 :(得分:0)
这是一个社区Wiki答案,旨在总结评论中的信息以及其他详细信息和解释。
评论中的人是正确的。您的端口配置存在缺陷。您需要了解的几件事可以帮助您更好地理解此概念。我们为Kubernetes服务提供了几种不同的端口配置:
Port:
在群集内的指定端口上公开Kubernetes服务。群集中的其他Pod可以在指定端口上与此服务器通信。
TargetPort:
是服务将请求发送到的端口,您的Pod将在此端口上监听。您容器中的应用程序也需要在此端口上进行监听。
NodePort:
通过目标节点的IP地址和NodePort在群集外部公开服务。如果未指定端口字段,则NodePort是默认设置。
从上面的示例中,myapp-service
服务将在端口89的内部向群集应用程序公开,在节点30003的节点IP地址上向外部公开群集。它还将请求转发给标签为“ app: my-app”在端口89上。
您可以通过以下方式查看服务的详细信息:
kubectl describe service myapp-service
将您的targetPort:
调整为80
,就可以了。