zoukankan      html  css  js  c++  java
  • squid 访问日志记录

    squid日志记录在squid.conf 也可记录。并且squid日志可以不记录静态项

    在squid.conf 加入

    (1)access_log /var/log/squid/access.log  squid        #定义日志存放记录

    (2)不记录静态加入

    acl nolog urlpath_regex -i .css .js .swf .jpg .gif .png .jpeg    #常见的静态项
    access_log /var/log/squid/access.log common !nolog     其中common 为日志格式

    (3) 下面对squid的access.log日志内容的第四域介绍:这个与squid命中率有关

    cat access.log|awk ‘{print $4}’|sort|uniq -c|sort –nr

    9568 TCP_IMS_HIT/304
    6313 TCP_HIT/200
    2133 TCP_MISS/200
    1568 TCP_MISS/206
    587 TCP_MEM_HIT/200
    531 TCP_MISS/304
    207 TCP_REFRESH_HIT/200
    152 TCP_REFRESH_HIT/304
    86 TCP_NEGATIVE_HIT/404
    69 TCP_MISS/404
    9 TCP_MISS/000
    4 TCP_MISS/503
    1 TCP_REFRESH_MISS/000
    1 TCP_DENIED/400
    可以使用上面的方法,大约的分析一下命令中比。什么意思就看下面的详解.
    #cat /var/log/squid/access.log |grep TCP_MEM_HIT
    如果看到很多的TCP_MEM_HIT ,这表明该文件是从内存缓存读取的,squid已经起作用了!
    你再用浏览器打开该文件,应该是快如闪电了。。呵呵,大功告成了!还有其他类型的HIT,如TCP_HIT等等,这些是从磁盘读取的,我觉得加速的意义不大,只不过缓解了apache的压力而已。
    相应于HTTP请求,下列标签可能出现在access.log文件的第四个域。
    TCP_HIT
    Squid发现请求资源的貌似新鲜的拷贝,并将其立即发送到客户端。
    TCP_MISS
    Squid没有请求资源的cache拷贝。
    TCP_REFERSH_HIT
    Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器。原始服务器返回304(未修改)响应,指示squid的拷贝仍旧是新鲜的。
    TCP_REF_FAIL_HIT
    Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器。然而,原始服务器响应失败,或者返回的响应Squid不能理解。在此情形下,squid发送现有cache拷贝(很可能是陈旧的)到客户端。
    TCP_REFRESH_MISS
    Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器。原始服务器响应新的内容,指示这个cache拷贝确实是陈旧的。
    TCP_CLIENT_REFRESH_MISS
    Squid发现了请求资源的拷贝,但客户端的请求包含了Cache-Control: no-cache指令。Squid转发客户端的请求到原始服务器,强迫cache确认。
    TCP_IMS_HIT
    客户端发送确认请求,Squid发现更近来的、貌似新鲜的请求资源的拷贝。Squid发送更新的内容到客户端,而不联系原始服务器。
    TCP_SWAPFAIL_MISS
    Squid发现请求资源的有效拷贝,但从磁盘装载它失败。这时squid发送请求到原始服务器,就如同这是个cache丢失一样。
    TCP_NEGATIVE_HIT
    在对原始服务器的请求导致HTTP错误时,Squid也会cache这个响应。在短时间内对这些资源的重复请求,导致了否命中。 negative_ttl指令控制这些错误被cache的时间数量。请注意这些错误只在内存cache,不会写往磁盘。下列HTTP状态码可能导致否定 cache(也遵循于其他约束): 204, 305, 400, 403, 404, 405, 414, 500, 501, 502, 503, 504。
    TCP_MEM_HIT
    Squid在内存cache里发现请求资源的有效拷贝,并将其立即发送到客户端。注意这点并非精确的呈现了所有从内存服务的响应。例如,某些cache在内存里,但要求确认的响应,会以TCP_REFRESH_HIT, TCP_REFRESH_MISS等形式记录。
    TCP_DENIED
    因为http_access或http_reply_access规则,客户端的请求被拒绝了。注意被http_access拒绝的请求在第9域的值是NONE/-,然而被http_reply_access拒绝的请求,在相应地方有一个有效值。
    TCP_OFFLINE_HIT
    当offline_mode激活时,Squid对任何cache响应返回cache命中,而不用考虑它的新鲜程度。
    TCP_REDIRECT
    重定向程序告诉Squid产生一个HTTP重定向到新的URI(见11.1节)。正常的,Squid不会记录这些重定向。假如要这样做,必须在编译squid前,手工定义LOG_TCP_REDIRECTS预处理指令。
    NONE
    无分类的结果用于特定错误,例如无效主机名。
    相应于ICP查询,下列标签可能出现在access.log文件的第四域。
    UDP_HIT
    Squid在cache里发现请求资源的貌似新鲜的拷贝。
    UDP_MISS
    Squid没有在cache里发现请求资源的貌似新鲜的拷贝。假如同一目标通过HTTP请求,就可能是个cache丢失。请对比UDP_MISS_NOFETCH。
    UDP_MISS_NOFETCH
    跟UDP_MISS类似,不同的是这里也指示了Squid不愿去处理相应的HTTP请求。假如使用了-Y命令行选项,Squid在启动并编译其内存索引时,会返回这个标签而不是UDP_MISS。
    UDP_DENIED
    因为icp_access规则,ICP查询被拒绝。假如超过95%的到某客户端的ICP响应是UDP_DENIED,并且客户端数据库激活了(见附录A),Squid在1小时内,停止发送任何ICP响应到该客户端。若这点发生,你也可在cache.log里见到一个警告。
    UDP_INVALID
    Squid接受到无效查询(例如截断的消息、无效协议版本、URI里的空格等)。Squid发送UDP_INVALID响应到客户端

    (4)如何查看squid的缓存命中率

    http://www.apelearn.com/bbs/forum.php?mod=viewthread&tid=757&fromuid=6071

    使用命令:  squidclient -h host -p port mgr:info
    比如:  /usr/local/squid/bin/squidclient -h 127.0.0.1 -p 8080 mgr:info
    使用这个命令的前提是,你在你的squid.conf 中配置了相关的选项
    acl manager proto cache_object
    http_access allow manager

    查看squid所有信息:squidclient -h 10.10.90.20 -p 80 mgr:info
    查看mgr:后可用参数:squidclient -h 10.10.90.20 -p 80 mgr:
    查看squid命中率:squidclient -h 10.10.90.20 -p 80 mgr:info |grep  "Hits as"
    查看squid 存储的对象:squidclient -h 10.10.90.20.56 -p 80 mgr:objects
    查看5分钟内squid 的运行状况:squidclient -h 10.10.90.20 -p 80 mgr:5min


  • 相关阅读:
    java小提示:标示符常见命名规则、常用ASCII
    java程序练习:数组中随机10个数中的最大值
    java第四课:数组
    java程序练习:x进制转Y进制
    java第三课:分支结构、循环结构
    java第二课:运算符和表达式
    java第一课:环境、变量、数据类型
    00
    linux 设备驱动 nand驱动框架
    linux内核源码分析plat-form 分析
  • 原文地址:https://www.cnblogs.com/the-study-of-linux/p/5014726.html
Copyright © 2011-2022 走看看