HTTP/2 для ALB с EKS на AWS
Я экспериментирую с AWS EKS и создал следующую настройку:
- EKS кластер с одним сервисом / модулем / узлом
- Входной контроллер AWS ALB
- ALB
Я пытаюсь настроить ALB для:
- создавать журналы доступа
- обеспечить поддержку HTTP/2
Мое определение контроллера доступа:
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: alb-ingress-controller
name: alb-ingress-controller
namespace: kube-system
spec:
replicas: 1
selector:
matchLabels:
app: alb-ingress-controller
strategy:
rollingUpdate:
maxSurge: 1
maxUnavailable: 1
type: RollingUpdate
template:
metadata:
creationTimestamp: null
labels:
app: alb-ingress-controller
spec:
containers:
- args:
- --ingress-class=alb
- --cluster-name=eks
image: docker.io/amazon/aws-alb-ingress-controller:v1.1.2
imagePullPolicy: Always
name: server
resources: {}
terminationMessagePath: /dev/termination-log
dnsPolicy: ClusterFirst
restartPolicy: Always
securityContext: {}
terminationGracePeriodSeconds: 30
serviceAccountName: alb-ingress
serviceAccount: alb-ingress
Мой сервис и определение доступа:
apiVersion: v1
kind: Service
metadata:
name: my-app
spec:
ports:
- port: 5001
targetPort: 5001
protocol: TCP
type: NodePort
selector:
app: my-app
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: "my-app"
labels:
app: my-app
annotations:
kubernetes.io/ingress.class: alb
alb.ingress.kubernetes.io/scheme: internet-facing
alb.ingress.kubernetes.io/load-balancer-attributes: "access_logs.s3.enabled=true,access_logs.s3.bucket=my-bucket,access_logs.s3.prefix=some-path"
alb.ingress.kubernetes.io/load-balancer-attributes: "routing.http2.enabled=true"
spec:
rules:
- http:
paths:
- path: /*
backend:
serviceName: "my-app"
servicePort: 5001
Результат:
- ALB создается правильно и трафик направляется правильно
- но нет поддержки HTTP/2 (хотя консоль AWS говорит "включено" для HTTP/2, что по умолчанию)
- и никакие ALB не регистрируются в S3 (хотя все разрешения предоставлены)
Я проверил журналы ALB (kubectl logs -n kube-system $(kubectl get po -n kube-system | egrep -o alb-ingress[a-zA-Z0-9-]+)) и не нашел ошибок сообщение или предупреждение.
Кто-нибудь еще заставил это работать?
1 ответ
Тем временем я решил эти две проблемы. Краткое резюме на случай, если кто-то еще борется с тем же:
все alb.ingress.kubernetes.io/load-balancer-attributes необходимо объединить в один оператор, разделенный запятыми -> решена проблема с журналом S3
alb.ingress.kubernetes.io/load-balancer-attributes: "access_logs.s3.enabled=true,access_logs.s3.bucket= имя-корзины, access_logs.s3.prefix = some-prefix"
HTTPS должен быть включен для HTTP/2 -> решен вопрос HTTP / 2
alb.ingress.kubernetes.io/listen-ports: '[{"HTTP":80,"HTTPS":443}]' alb.ingress.kubernetes.io/certificate-arn: "arn:aws:acm:ap- к юго-1:1234567891011: сертификат / некоторые-UID"