哪个是使用nginx RBAC入口控制器公开服务的正确方法?

时间:2017-07-07 15:42:34

标签: nginx kubernetes rbac kubeadm

我正在使用kubeadm工具,以便创建一个kubernetes v1.7集群。

公开服务" echoheaders"非常简单。在我的主机kubenode1.kube.com上使用external-ip

创建正在运行的部署:

kubectl run echoheaders --image=gcr.io/google_containers/echoserver:1.5

从部署中公开服务:

kubectl expose deployment echoheaders --port=80 --target-port=8080 --external-ip='192.168.10.96'

从您的网络浏览器访问它:

http://kubenode1.kube.com

现在,我想使用本指南中的基于角色的入口控制器公开相同的服务echoheadershttps://github.com/kubernetes/ingress/tree/master/examples/rbac/nginx

从上面的指南我运行命令没有问题..

之后,创建部署和服务" echoheader"类型:NodePort但不使用external-ip选项

kubectl run echoheaders --image=gcr.io/google_containers/echoserver:1.5

kubectl expose deployment echoheaders --port=80 --target-port=8080 --type=NodePort

我们可以使用curl 192.168.10.96:31782

访问该服务

还为此服务创建echoheaders入口资源:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: echoheaders-ingress
spec:
  rules:
    - host: kubenode1.kube.com
      http:
        paths:
          - path: /
            backend:
              serviceName: echoheaders
              servicePort: 80

但我无法访问该服务:

curl http(s)://kubenode1.kube.com -H "Host: kubenode1.kube.com"

返回

curl: (7) Failed connect to kubenode1.kube.com:80; Connection Refused

检查命令时,一切似乎都没问题: kubectl描述echoheaders

最后我从这里尝试了kubernetes-dashboard服务: https://github.com/kubernetes/dashboard/blob/master/src/deploy/kubernetes-dashboard.yaml

这与Kubernetes 1.6 RBAC兼容..但我也无法从外部访问它。 仍然得到同样的错误:

curl:(7)连接到kubenode1.kube.com:80失败;拒绝连接

我是否需要提供更多详细信息? 我是否遗漏了一些东西,以便能够使用基于角色的nginx-ingress控制器公开服务?

我需要从http(s)://kubenode1.kube.com访问我的服务,而不能在Nodeport端口上公开访问(http(s)://kubenode1.kube.com:31782)

1 个答案:

答案 0 :(得分:0)

如果要在该端口上访问nginx控制器,则需要在nodeport 80上公开nginx控制器。看起来您链接的示例在端口30080上公开它:https://github.com/kubernetes/ingress/blob/master/examples/rbac/nginx/nginx-ingress-controller-service.yml

对于使用端口80,首先必须允许节点端口服务使用如此低的端口号。您可以使用apiserver的--service-node-port-range参数执行此操作,请参阅https://kubernetes.io/docs/admin/kube-apiserver/