在阿里云Serverless Kubernetes集群中,我们可以通过LoadBalancer Service对外提供四层服务访问,同样您也可以通过Ingress来对外提供七层服务访问,下面介绍如何在Serverless Kubernetes集群中提供七层域名服务访问。
前提条件
# 生成测试TLS证书
$ openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout tls.key -out tls.crt -subj "/CN=bar.foo.com/O=bar.foo.com"# 创建TLS证书Secret
$ kubectl create secret tls cert-example --key tls.key --cert tls.crt
secret "cert-example" created
# 查看新建TLS证书
$ kubectl get secret cert-example
NAME TYPE DATA AGE
cert-example kubernetes.io/tls 2 12s
4、配置 Ingress通过Ingress配置tomcat service对外暴露的域名和Path路径,编排模板如下:apiVersion: extensions/v1beta1kind: Ingressmetadata: name: tomcat-ingress annotations:# 配置使用指定的SLB实例(SLB ID)service.beta.kubernetes.io/alicloud-loadbalancer-id: lb-xxxxxxxxxx ##替换为你的SLB IDspec: tls: - hosts: - bar.foo.com# 配置TLS证书 secretName: cert-example rules:# 配置七层域名 - host: bar.foo.com http: paths:# 配置Context Path - path: / backend: serviceName: tomcat servicePort: 8080$ kubectl apply -f tomcat-ingress.yml #在tomcat-ingress.yaml中输入上面的模板ingress "tomcat-ingress" created# 部署完成后,ADDRESS为指定的SLB IP地址$ kubectl get ing tomcat-ingressNAME HOSTS ADDRESS PORTS AGEtomcat-ingress bar.foo.com 47.101.20.67 80, 443 1m5、测试服务访问本例中在 hosts中添加一条DNS域名解析规则,用于测试服务访问。建议您在工作环境中对域名进行备案。47.101.20.67 bar.foo.com通过浏览器测试访问tomcat服务版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。