У меня есть кластер kubernetes, в котором я развернул контроллер входящего трафика nginx с помощью helm диаграмма nginx-ingress.
Мне нужно добавить некоторую настраиваемую конфигурацию в файл nginx.conf, который создается в nginx-controller-pod, и я вижу проблему, при которой, если я добавлю однострочную опцию, такую как proxy-buffer-size: "512k"
, я могу увидеть, как это отражается в nginx. conf и все работает как положено.
Однако, если я попытаюсь добавить фрагмент, чтобы выполнить то же самое:
location-snippet: |
proxy_buffer_size "512k";
Это как если бы это игнорировалось файлом nginx.conf, а для параметра proxy_buffer_size
оставалось значение по умолчанию.
Мне нужно иметь возможность добавлять переопределения http-snippet
, server-snippet
и location-snippet
, но независимо от того, пытаюсь ли я добавить их в ConfigMap или как аннотацию в файле Ingress.yaml, они всегда игнорируются.
Мой YAML-файл Ingress:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: my-ingress
annotations:
kubernetes.io/ingress.class: nginx
ingress.kubernetes.io/ssl-redirect: "true"
ingress.kubernetes.io/secure-backends: "true"
ingress.kubernetes.io/force-ssl-redirect: "true"
ingress.kubernetes.io/location-snippet: |
proxy_buffer_size 512k; --This does not update the nginx.conf
spec:
tls:
- hosts:
- my.app.co.uk
secretName: tls-secret
rules:
- host: my.app.co.uk
http:
paths:
- path: /
backend:
serviceName: myappweb-service
servicePort: 80
Моя конфигурационная карта nginx:
apiVersion: v1
kind: ConfigMap
metadata:
labels:
app: nginx-ingress
chart: nginx-ingress-0.28.3
component: controller
heritage: Tiller
release: nginx-ingress
name: nginx-ingress-controller
namespace: default
data:
proxy-buffer-size: "512k" -- this works and updates the nginx.conf
location-snippet: |
proxy_buffers 4 512k; -- this does not update the nginx.conf
server-snippet: | -- this does not update the nginx.conf
location /messagehub {
proxy_set_header Upgrade $http_upgrade;
proxy_http_version 1.1;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header Host $host;
proxy_set_header Connection "upgrade";
proxy_cache_bypass $http_upgrade;
}