如何在kubernetes Nginx控制器中公开80端口

时间:2020-11-01 10:05:42

标签: nginx kubernetes kubernetes-ingress nginx-ingress

我在不使用云的情况下在多个树莓派4中安装了kubernete。 我按照教程部署mongodb和mongo express,我可以 使用节点端口模式进入mongo express网站。 但是,当我更改为使用nignx控制器时,当我 键入ip address:port(192.168.1.194:30574这是我的主节点ip,端口是ingress-nginx控制器公开的端口)或domain:port(mymongo.com:30574)。 但是,如果我仅使用域名(mymongo.com)而不使用端口,则无法进入网站。我想念什么吗?谢谢! 这是我的yaml

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata: 
  name: mongo-express-ingress
spec:
  rules:
   - host: "mymongo.com"
   - http:
      paths:
      - pathType: Prefix
        path: "/"
        backend:
          service:
            name: mongo-express-service
            port:
              number: 8081
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: mongo-express
  labels:
    app: mongo-express
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mongo-express
  template:
    metadata:
      labels:
        app: mongo-express
    spec:
      containers:
        - name: mongo-express
          image: mongo-express
          ports:
            - containerPort: 8081
          env:
            - name: ME_CONFIG_MONGODB_ADMINUSERNAME
              valueFrom:
                secretKeyRef:
                  name: mongodb-secret
                  key: mongo-root-username
            - name: ME_CONFIG_MONGODB_ADMINPASSWORD 
              valueFrom:
                secretKeyRef:
                  name: mongodb-secret
                  key: mongo-root-password
            - name: ME_CONFIG_MONGODB_SERVER
              valueFrom:
                configMapKeyRef:
                  name: mongodb-configmap
                  key: database_url
---
apiVersion: v1
kind: Service
metadata:
  name: mongo-express-service
spec:
  selector:
    app: mongo-express
  ports:
    - protocol: TCP
      port: 8081
      targetPort: 8081

ubuntu@master:~/k8s-config$ kubectl get services --all-namespaces
NAMESPACE              NAME                                 TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                      AGE
default                kubernetes                           ClusterIP   10.96.0.1       <none>        443/TCP                      8d
default                mongo-express-service                ClusterIP   10.107.95.131   <none>        8081/TCP                     6d19h
default                mongodb-service                      ClusterIP   10.101.118.57   <none>        27017/TCP                    6d19h
ingress-nginx          ingress-nginx-controller             NodePort    10.96.94.30     <none>        80:30574/TCP,443:31882/TCP   6d4h
ingress-nginx          ingress-nginx-controller-admission   ClusterIP   10.104.121.41   <none>        443/TCP                      6d4h
kube-system            kube-dns                             ClusterIP   10.96.0.10      <none>        53/UDP,53/TCP,9153/TCP       8d
kubernetes-dashboard   dashboard-metrics-scraper            ClusterIP   10.99.4.159     <none>        8000/TCP                     6d22h
kubernetes-dashboard   kubernetes-dashboard                 NodePort    10.98.92.238    <none>        443:31044/TCP             

1 个答案:

答案 0 :(得分:0)

在您当前的配置中,它可以按预期工作。

您的Nginx Ingress Controller被配置为NodePort Type

NodePort::在静态端口(NodePort)上公开每个节点IP上的Service。将自动创建NodePort服务路由到的ClusterIP服务。您可以通过请求从集群外部与NodePort Service联系。

因此,如果您使用的是NodePort类型,则只有在指定{strong> NodeIP:NodePort >的情况下,才能使用mymongo.com:30574({{ 1}}:mymongo.com,NodeIP:30574)。

如果您只想使用域,则需要将NodePort视为ServiceType

LoadBalancer :使用云提供商的负载均衡器在外部公开服务。自动创建外部负载均衡器路由到的NodePort和ClusterIP服务。

要在不使用LoadBalancer的情况下实现这一点,可以使用 MetalLB solution

您当前的配置Cloud LoadBalancer中也被描述为Over a NodePort Service

您还可以考虑使用 host network solution代替Nginx Ingress Documentation

在没有可用的外部负载均衡器但不能使用NodePorts的设置中,可以配置ingress-nginx Pods使用其运行的主机的网络,而不是专用的网络名称空间。这种方法的好处是,NGINX Ingress控制器可以将端口80和443直接绑定到Kubernetes节点的网络接口,而无需NodePort Services施加额外的网络转换。

baremaetal solution