Squid 启动/停止/重载/服务异常配置命令



           

当你的 squid.conf 配置文件按照你的想法修改完以后,squid 之旅就开始了。    


一、Squid安装调试命令:    
1. 初始化你在 squid.conf 里配置的 cache 目录    
#/usr/sbin/squid -z          ///  初始化缓存空间    
如果有错误提示,请检查你的 cache目录的权限。    


2. 对你的squid.conf 排错,即验证 squid.conf 的 语法和配置。    
#/usr/sbin/squid -k parse    
如果squid.conf 有语法或配置错误,这里会返回提示你,如果没有返回,恭喜,可以尝试启动squid。    


3. 在前台启动squid,并输出启动过程。    
#/usr/sbin/squid -N -d1    
如果有到 ready to server reques,恭喜,启动成功。    
然后 ctrl + c,停止squid,并以后台运行的方式启动它。    


4. 启动squid在后台运行。    
#/usr/local/squid/sbin/squid -s    
这时候可以 ps -A 来查看系统进程,可以看到俩个 squid 进程。  

  图片.png


5. 停止 squid    
#/usr/sbin/squid -k shutdown    
   


6. 重引导修改过的 squid.conf    
#/usr/sbin/squid -k reconfigure             /// 载入新的配置文件    
这个估计用的时候比较多,当你发现你的配置有不尽你意的时候,可以随时修改squid.conf,然后别忘记对你的 squid.conf排错,然后再执行此指令,即可让squid重新按照你的 squid.conf 来运行。    

图片.png


7.  /usr/sbin/squid -k rotate 轮循日志    


8. 把squid添加到系统启动项    
编辑 /etc/rc.d/rc.local    
添加如下行: /usr/sbin/squid -s    


9.  修改cache 缓存目录的权限。    
#chown -R squid:squid /var/spool/squid    
我的cache缓存目录是 /var/spool/squid    ,squid执行用户和用户组是 squid,squid。   


10.  修改squid 日志目录的权限    
#chown -R squid:squid /var/log/squid
这一步并不是适合每一个使用squid的用户.意为让squid有权限在该目录进行写操作 。    
例如生成 access.log cache.log store.log    


11. 查看你的日志文档。

图片.png    
#more /var/log/squid/access.log | grep TCP_MEM_HIT    
该指令可以看到在squid运行过程中,有那些文件被squid缓存到内存中,并返回给访问用户。    
#more /var/log/squid/access.log | grep TCP_HIT    
该指令可以看到在squid运行过程中,有那些文件被squid缓存到cache目录中,并返回给访问用户。    
#more /var/log/squid/access.log | grep TCP_MISS    
该指令可以看到在squid运行过程中,有那些文件没有被squid缓存,而是现重原始服务器获取并返回给访问用户。    
关于 TCP_XXXX 等参数及代表的信息,请参看《squid中文权威指南》13.2.1 章节。    
当然,本例中的蓝色文字是可以修改为其他的参数,例如你的域名 www.xxxx.com ,同样可以看到access.log里关于该域名的行。    




二、squid命中率分析    
/usr/local/squid/bin/squidclient -p 80 mgr:info    
/usr/local/squid/bin/squidclient -p 80 mgr:5min    
可以看到详细的性能情况,其中PORT是你的proxy的端口,5min可以是60min    


取得squid运行状态信息: squidclient -p 80 mgr:info    
*取得squid内存使用情况: squidclient -p 80 mgr:mem    
*取得squid已经缓存的列表: squidclient -p 80 mgrbjects. use it carefully,it may crash    
*取得squid的磁盘使用情况: squidclient -p 80 mgr:diskd    
*强制更新某个url:squidclient -p 80 -m PURGE http://www.xxx.com/xxx.php    
*更多的请查看:squidclient-h 或者 squidclient -p 80 mgr:    


查命中率:    
/usr/local/squid/bin/squidclient -h 111.222.111.111 -p80 mgr:info    
/usr/local/squid/bin/squidclient -h具体的IP -p80 mgr:info


图片.png


三 、异常排除案例

     1、突然发现squid服务停止,一阵换乱,深吸一口气,排查故障。

        查看服务端口,发现端口和服务都没有在运行

      图片.png

    2. squid -z 进行初始化

        发现是因为权限的问题,导致缓存文件无法写入图片.png

   3、赋予权限/重启

    粗暴做法chmod 777 /var/spool/squid

     systemctl restart squid.service

 4、查看服务状态

   图片.png

  图片.png