在k8s集群中,我们都是通过ingress的方法对外暴露访问的。对一些静态的资源,我们可以在nginx ingress侧增加缓存,减小后端服务的压力。
1、需要先找到nginx ingress的configmap配置文件,增加http-snippet
# configmap.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: ingress-nginx-controller
namespace: default
data:
http-snippet: "proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=static-cache:10m max_size=10g inactive=60m use_temp_path=off;"
$ kubectl apply -f configmap.yml
configmap/ingress-nginx-controller configured
proxy_cache_path指令的完整语法如下:
Syntax: proxy_cache_path path [levels=levels] [use_temp_path=on|off] keys_zone=name:size [inactive=time] [max_size=size] [manager_files=number] [manager_sleep=time] [manager_threshold=time] [loader_files=number] [loader_sleep=time] [loader_threshold=time] [purger=on|off] [purger_files=number] [purger_sleep=time] [purger_threshold=time];
Nginx对缓存的处理
Nginx针对响应缓存有两个处理动作
- 缓存管理器会定时检查缓存的状态。如果缓存的内容大小达到了指令
proxy_cache_path的参数max-size指定的值,则缓存管理器会根据LRU算法删除缓存的内容。 在检查的间隔时间内,总的缓存内容大小可以临时超过设定的大小阈值。 - 缓存加载器只在Nginx启动的时候执行一次,将缓存内容的
原信息加载到指定的共享内存区内。一次将所有的缓存内容加载到内存中会耗费大量的资源,并且会影响Nginx启动后几分钟内的性能。为了避免这种问题可以通过在指令proxy_cache_path


被折叠的 条评论
为什么被折叠?



