首页域名资讯 正文

查看nginx cache命中率

2025-02-02 1 0条评论

一、在http header上增加命中显示

nginx提供了$upstream_cache_status这个变量来显示缓存的状态,我们可以在配置中添加一个http头来显示这一状态,达到类似squid的效果。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 location    / {          proxy_redirect           off ;          proxy_set_header         Host              $ host ;          proxy_set _header          X Real IP        $ remote_addr ;          proxy_set _header          X Forwarded For $ proxy_add_x_forwarded_for ;          proxy_connect _timeout    180 ;          proxy_send _timeout        180 ;          proxy_read _timeout        180 ;          proxy_buffer _size        128k ;          proxy _buffers            4 128k ;          proxy_busy_buffers _size 128k ;          proxy_temp_file_write _size 128k ;          proxy_cache cache ;          proxy_cache _valid 200 304 1h ;          proxy_cache _valid 404 1m ;          proxy_cache _key $ uri $ is_args $ args ;          add_header   Nginx Cache “$upstream_cache_status” ;          proxy_pass http : //backend;      }

而通过curl或浏览器查看到的header如下:

1 2 3 4 5 6 7 8 9 HTTP / 1.1 200 OK Date : Mon , 22 Apr 2013 02 : 10 : 02 GMT Server : nginx Content Type : image / jpeg Content Length : 23560 Last Modified : Thu , 18 Apr 2013 11 : 05 : 43 GMT Nginx Cache : HIT Accept Ranges : bytes Vary : User Agent

$upstream_cache_status包含以下几种状态:

·MISS 未命中,请求被传送到后端
·HIT 缓存命中
·EXPIRED 缓存已经过期请求被传送到后端
·UPDATING 正在更新缓存,将使用旧的应答
·STALE 后端将得到过期的应答

二、nginx cache命中率统计

即然nginx为我们提供了$upstream_cache_status函数,自然可以将命中状态写入到日志中。具体可以如下定义日志格式:

1 2 3 4 log_format   main    ‘$remote_addr – $remote_user [$time_local] “$request” ‘                    ‘$status $body_bytes_sent “$http_referer” ‘                    ‘”$http_user_agent” “$http_x_forwarded_for”‘                    ‘”$upstream_cache_status”‘ ;

命中率统计方法:用HIT的数量除以日志总量得出缓存命中率:

1 awk ‘{if($NF==””HIT””) hit++} END {printf “%.2f%”,hit/NR}’ access . log

了解了原理以后,也可以通过crontab脚本将每天的命中率统计到一个日志中,以备查看。

1 2 # crontab -l 1 0 * * * / opt / shell / nginx_cache_hit >> / usr / local / nginx / logs / hit

访脚本的内容为:

1 2 3 4 #!/bin/bash LOG_FILE = ‘/usr/local/nginx/logs/access.log.1’ LAST_DAY = $ ( date + % F d “-1 day” ) awk ‘{if($NF==””HIT””) hit++} END {printf “‘ $ LAST _DAY ‘: %d %d %.2f%n”, hit,NR,hit/NR}’ $ LOG_FILE

 

文章转载来自:trustauth.cn

文章版权及转载声明

本文作者:亿网 网址:https://edns.com/ask/post/150561.html 发布于 2025-02-02
文章转载或复制请以超链接形式并注明出处。