3

我正在从这里学习 k8s 中的服务

我创建了没有选择器和一个端点的服务。我想要做的是我已经安装了 apache,它在端口 80 上运行。我在端口 31000 上创建了一个节点端口服务。现在这个服务应该将 ip:31000 重定向到 ip:80 端口。

它适用于服务的内部 ip,但不适用于外部 ip。

我的服务.yaml

apiVersion: v1
kind: Service
metadata:
  name: my-service
spec:
  ports:
  - protocol: TCP
    port: 9376
    targetPort: 80
    nodePort: 31000
  type: NodePort

我的端点.yaml

apiVersion: v1
kind: Endpoints
metadata:
  name: my-service
subsets:
  - addresses:
      - ip: <IP>
    ports:
      - port: 80

kubectl get service -o wide的输出

NAME         TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGE   SELECTOR
kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP          53m   <none>
my-service   NodePort    10.111.205.207   <none>        9376:31000/TCP   30m   <none>
4

3 回答 3

3

首先,您需要在集群中运行一个 pod,然后使用端口在 Endpoints yaml 中分配该 pod 的 ip,因为服务将 pod 暴露在集群内部或外部,我们必须使用选择器或 pod 的地址这样服务就可以将它自己附加到特定的 pod。

apiVersion: v1
kind: Endpoints
metadata:
  name: my-service
subsets:
  - addresses:
      - ip: <ip address of the pod>
    ports:
      - port: <port of the pod>

另一件事是使用 Statefulset 代替 Deployment 来运行 pod。

于 2019-07-10T05:37:01.960 回答
2

有多种类型的服务可以为您提供不同级别的访问权限:

ClusterIP - 可以从另一个 pod 访问服务(仅在 Kubernetes 集群内部)

NodePort - 可以从另一个 pod 以及运行 Kubernetes 集群的机器访问服务

LoadBalancer - 可以从 Kubernetes 集群外部访问服务(使用外部 IP)

当您有 TCP 级别的连接时,LoadBalancers非常棒。如果您有更高级别的连接 ( http ),您也可以使用Ingress + NodePort

于 2019-07-09T13:39:01.843 回答
1

服务的用途是在所有不同的 Pod 之间建立通信,或者从集群外部访问 Pod。

因此,您创建的每个 pod 或每个部署总是会附带某种匹配的服务。有几种不同类型的服务。

1.集群IP:设置一个容易记住的URL来访问一个pod。仅公开集群中的 pod。因此,只要您想在集群内的不同 pod 之间建立通信,就可以随时使用集群 IP 服务。

例如:事件总线部署.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: event-bus-depl
spec:
  replicas: 1
  selector:
    matchLabels:
      app: event-bus
  template:
    metadata:
      labels:
        app: event-bus
    spec:
      containers:
        - name: event-bus
          image: lordrafiq/event-bus:latest
---
apiVersion: v1
kind: Service
metadata:
  name: event-bus-srv
spec:
  selector:
    app: event-bus
  type: ClusterIP
  ports:
    - name: event-bus
      protocol: TCP
      port: 4005
      targetPort: 4005

因此,在您想与事件​​总线通信的任何 pod 内部,您可以在端口 4005 上使用 event-bus-srv。

 await axios.post('http://event-bus-srv:4005/events', {});

2. 节点端口:使 pod 可以从集群外部访问(通常仅用于开发目的)。因此,节点端口可用于您想从集群外部访问 pod 的任何时间,但它仅用于开发目的,负载均衡器是从集群访问 pod 的正确方法。

apiVersion: v1
kind: Service
metadata:
  name: posts-srv
spec:
  type: NodePort
  selector:
    app: posts
  ports:
    - name: posts
      protocol: TCP
      port: 4000
      targetPort: 4000
http://192.168.39.234:31154/posts

31154是我们创建节点端口服务后得到的nodePort。

在此处输入图像描述

3. 负载均衡器:使 pod 可以从集群外部访问。这是将 pod 暴露给外界的正确方法。

4. 外部名称: 将集群内请求重定向到 CNAME url。

于 2021-03-30T16:49:49.730 回答