Kubernetes 入口nginx缓存

Kubernetes 入口nginx缓存,kubernetes,nginx-ingress,Kubernetes,Nginx Ingress,我试图找出如何使用nginx代理缓存,并给出一些具体的规则。例如,当我托管Ghost或Wordpress时,我不想缓存管理部分。使用服务器代码段,我尝试了许多不同的组合,但在管理部分中仍然存在缓存问题 nginx.ingress.kubernetes.io/proxy-buffering: "on" nginx.ingress.kubernetes.io/server-snippet: |- proxy_ignore_headers X-Accel-Expires Expires Cache

我试图找出如何使用nginx代理缓存,并给出一些具体的规则。例如,当我托管Ghost或Wordpress时,我不想缓存管理部分。使用服务器代码段,我尝试了许多不同的组合,但在管理部分中仍然存在缓存问题

nginx.ingress.kubernetes.io/proxy-buffering: "on"
nginx.ingress.kubernetes.io/server-snippet: |-
  proxy_ignore_headers X-Accel-Expires Expires Cache-Control;
  proxy_ignore_headers Set-Cookie;
  proxy_cache app_cache;
  proxy_cache_lock on;
  proxy_cache_valid any 30m;
  add_header X-Cache-Status $upstream_cache_status;
我想在管理区域中使用(ghost | sinout)路径的nginx代码片段绕过缓存,但我失去了代理传递上下文,导致502坏网关

以下是当前入口配置缓存每个页面的管理路径:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  annotations:
    nginx.ingress.kubernetes.io/proxy-buffering: "on"
    nginx.ingress.kubernetes.io/server-snippet: |-
      proxy_cache my_blog_cache;
      proxy_cache_lock on;
      proxy_cache_valid any 30m;
      add_header X-Cache-Status $upstream_cache_status;
      proxy_ignore_headers X-Accel-Expires Expires Cache-Control;
  name: my-blog
  namespace: web
spec:
  rules:
  - host: blog.example.com
    http:
      paths:
      - backend:
          serviceName: ingress-541322b8660dbd2ceb1e8ff1813f0dd5
          servicePort: 2368
        path: /
  tls:
  - hosts:
    - blog.example.com
    secretName: my-blog-cert
status:
  loadBalancer:
    ingress:
    - ip: 1.2.3.4
以下是我试图获取的nginx配置,但与入口注释不兼容:

   location / {
        proxy_cache my_blog_cache;
        proxy_cache_valid 200 30m;
        proxy_cache_valid 404 1m;
        proxy_pass http://ghost_upstream;
        proxy_ignore_headers X-Accel-Expires Expires Cache-Control;
        proxy_ignore_headers Set-Cookie;
        proxy_hide_header Set-Cookie;
        proxy_hide_header X-powered-by;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        expires 10m;
    }
    location /content/images {
        alias /path/to/ghost/content/images;
        access_log off;
        expires max;
    }
    location /assets {
        alias /path/to/ghost/content/themes/uno-master/assets;
        access_log off;
        expires max;
    }
    location /public {
        alias /path/to/ghost/core/built/public;
        access_log off;
        expires max;
    }
    location /ghost/scripts {
        alias /path/to/ghost/core/built/scripts;
        access_log off;
        expires max;
    }
    location ~ ^/(?:ghost|signout) { 
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header Host $http_host;
        proxy_pass http://ghost_upstream;
        add_header Cache-Control "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0";
    }

谢谢你的帮助

nginx ingress controller中有一些选项,只有在使用时才可以更改,其他选项也可以使用,就像您正在做的那样

您可以将两者结合起来以达到预期的结果,也可以创建一个新的


您可以找到一个可能对您有所帮助的替代方案。

谢谢您的回答。对于特定的规则和配置映射,使用注释是非常有限的,会影响整个入口吗?或者可能有某种方法将模板或configmap附加到入口?我找到了一个替代方法,为每个路径位置创建多个带有特定注释的入口。例如:路径:/>缓存已应用,缓存状态=命中路径:/ghost->无注释,缓存状态=未命中,它可以工作!这是一个很好的做法吗?创建多个应用程序入口没有问题,如果所有入口都获得相同的IP就可以了,您只需要注意将来的维护。。。正如您所说,注释对于所有nginx来说都是非常有限的,这也是您可以选择结合nginx模板选项的原因。