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 进程。
5. 停止 squid
#/usr/sbin/squid -k shutdown
6. 重引导修改过的 squid.conf
#/usr/sbin/squid -k reconfigure /// 载入新的配置文件
这个估计用的时候比较多,当你发现你的配置有不尽你意的时候,可以随时修改squid.conf,然后别忘记对你的 squid.conf排错,然后再执行此指令,即可让squid重新按照你的 squid.conf 来运行。
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. 查看你的日志文档。
#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
三 、异常排除案例
1、突然发现squid服务停止,一阵换乱,深吸一口气,排查故障。
查看服务端口,发现端口和服务都没有在运行
2. squid -z 进行初始化
发现是因为权限的问题,导致缓存文件无法写入
3、赋予权限/重启
粗暴做法chmod 777
/var/spool/squid
systemctl restart squid.service
4、查看服务状态
转载于:https://blog.51cto.com/2333657/2330887