我正在kubernetes上部署一个Web应用程序(一组相互通信的节点服务器)。我使用Traefik控制器,作为负载平衡器,还使用群集中的内部通信。我通过AWS购买了该域名,并通过简单的负载均衡器通过路由53对其进行了设置。对于http:// domain-name
.com来说,它几乎可以正常工作。我正在尝试设置SSL证书(从外部供应商(非AWS)购买),以使网站成为https。但这是行不通的。我总是最终导致Connection超时。但是http方式工作得很好。
对于初学者来说,这是示例应用程序,我正在尝试通过traefik控制器(通过https)进行访问。
apiVersion: v1
kind: Service
metadata:
name: hello-kubernetes
spec:
type: LoadBalancer
ports:
- port: 80
targetPort: 8080
selector:
app: hello-kubernetes
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: hello-kubernetes
spec:
replicas: 1
selector:
matchLabels:
app: hello-kubernetes
template:
metadata:
labels:
app: hello-kubernetes
spec:
containers:
- name: hello-kubernetes
image: gcr.io/hello-minikube-zero-install/hello-node
ports:
- containerPort: 8080
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: hello-world-ingress
namespace: default
annotations:
kubernetes.io/ingress.class: traefik
traefik.frontend.rule.type: PathPrefixStrip
spec:
rules:
- http:
paths:
- path: /
backend:
serviceName: hello-kubernetes
servicePort: 80
tls:
- secretName: traefik-ui-tls-cert
就traefik控制器的舵图而言,
ssl:
enabled: true
enforced: false
permanentRedirect: false
upstream: false
insecureSkipVerify: false
generateTLS: false
defaultSANList: []
defaultIPList: []
defaultCert: <crt from IT> (which I converted from csr file that IT gave me using openssh tool)
defaultKey: <key from IT>
然后在aws控制台的“监听器”选项卡下的负载均衡器中,添加以下配置。
HTTPS-443-HTTP-80-e1e4096b-6a31-4b2d-9d33-9f3f94ab0320 (ACM) Change
我应该能够在https上访问我的网站。但是我只能在http上访问它。 有什么建议吗?