squid研究记录

Squid研究记录

Squid cache(简称为Squid)是一个流行的自由软件(GNU通用公共许可证)的代理服务器和Web缓存服务器。Squid有广泛的用途,从作为网页服务器的前置cache服务器缓存相关请求来提高Web服务器的速度,到为一组人共享网络资源而缓存万维网,域名系统和其他网络搜索,到通过过滤流量帮助网络安全,到局域网通过代理上网。Squid主要设计用于在Unix一类系统运行。

    Squid的发展历史相当悠久,功能也相当完善。除了HTTP外,对于FTP与HTTPS的支援也相当好,在3.0 测试版中也支援了IPv6。

                                                                      ----摘自“开源中国社区”

 

下面是从安装,到配置的整个过程,并对其中的一些参数进行粗浅的解释

1、下载安装

    先去http://www.squid-cache.org/去下载源代码包squid-3.1.19.tar.gz

    当前版本为squid-3.1.19

# tar xvfz squid-3.1.19.tar.gz
# cd squid-3.1.19

    在目录里执行configure操作,该操作是为了生成makefile文件的,所以有一些参数需要设置

#./configure --prefix=/usr/local/squid --enable-dlmalloc --enable-gnuregex --enable-removal-policies=heap,lru --enable-icmp --enable-delay-pools --enable-snmp --enable-arp-acl --enable-cahce-digests  --enable-storeio=aufs,ufs  --with-pthreads --enable-default-err-languages="Simplify_Chinese" --enable-epoll --enable-linux-netfilter --disable-ident-lookups --with-maxfd=65536 --enable-kill-parent-hack --enable-follow-x-forwarded-for --enable-stacktraces [--enable-ecap]
# make
# sudo make install

         安装完成后,进入/usr/local目录,更改squid目录的owner和grouper,这里可以根据自身需要进行更改,可以是新建一个用户专门用来执行squid,如:

# groupadd  -g  100  squid
# useradd   -u  100  -g  100  squid

或者直接使用目前的用户和用户组。

# sudo chown {owner}:{group} squid –R

至此,安装过程已经基本结束。

2、配置squid

#缓存机制:
quick_abort_min 0 KB
quick_abort_max 0 KB
#如果cache与缓存空间大小的比例达cache_swap_high时,开始swap操作,当比例降到cache_swap_low时,swap操作停止:
cache_swap_low 90
cache_swap_high 95
#采用的swap方式:
cache_replacement_policy heap LFUDA
#大于maximum_object_size的不进行disk存储:
maximum_object_size 4096 KB
#大于maximum_object_size的不进行memory存储:
maximum_object_size_in_memory 4096 KB
#指定内存的最大使用量(根据机器的内存和其它环境进行设定):
cache_mem 4096 MB
#打开SMP系统间的内存共享机制(squid-3.1.19不支持):
#memory_cache_shared on
#关闭半链接功能(有时squid会停止发送数据,但接收功能不会停止):
half_closed_clients off
#打开内存池以供后期使用:
memory_pools on
#关闭收集client的统计信息:
client_db off
#开启log信息的缓存功能:
buffered_logs on
#DNS相关设置(前者指缓存时间上限,后期指失败DNS解析的TTL):
positive_dns_ttl 8 hours
negative_dns_ttl 1 seconds
#IP的最大缓存数量:
ipcache_size 20480
#同cache_swap_low和cache_swap_high:
ipcache_low 90
ipcache_high 95
#FQDN的最大缓存数量:
fqdncache_size 20480
#http监听端口:
http_port 3128
#打开该选项后,用户的no-cache和reload请求将会更新cache:
reload_into_ims on
#设置一个limit,如果request的range超过这个limit,则将request进行透传(相当于not cache):
range_offset_limit -1
#打开该选项能够忽略带有no-cache的request的超时机制:
vary_ignore_expire on

#路径设置:
#cache资源存储的路径 ufs|aufs Mbytes L1 L2(L1为在squid下有多少个目录存放资源,L2为在每个L1目录下有多少个目录存放资源):
cache_dir aufs /usr/local/squid/var/cache/squid 8192 16 256
#coredump保存路径,否则保存在起始目录下:
coredump_dir /usr/local/squid/var/cache/squid
#access.log的存放路径(如果不存放可替换为cache_access_log none),该log包含了request的响应结果,哪些MEM_HIT,哪些MEM_MISS等:
cache_access_log /usr/local/squid/var/logs/access.log squid
# store.log的存放路径(存储缓存信息的log):
cache_store_log /usr/local/squid/var/logs/store.log

#用户设置:
#如果以root权限启动该程序,在启动前转到设置的user和group:
cache_effective_user squid
cache_effective_group squid

#要用到的命令设置:
#squid启动过程中会调用pinger,这里要设置好路径,并打开开关:
pinger_program /usr/local/squid/libexec/pinger
pinger_enable on

#连接规则配置:
#localnet包含了一些基于IP的filter:
acl localnet src 10.0.0.0/8     # RFC1918 possible internal network
acl localnet src 172.16.0.0/12  # RFC1918 possible internal network
acl localnet src 192.168.0.0/16 # RFC1918 possible internal network
acl localnet src fc00::/7       # RFC 4193 local private network range
acl localnet src fe80::/10      # RFC 4291 link-local (directly plugged) machines
acl localnet src 118.192.34.0/24
#localnet包含了一些基于Port的filter:
acl SSL_ports port 443
acl Safe_ports port 80          # http
acl Safe_ports port 21          # ftp
acl Safe_ports port 443         # https
acl Safe_ports port 70          # gopher
acl Safe_ports port 210         # wais
acl Safe_ports port 1025-65535  # unregistered ports
acl Safe_ports port 280         # http-mgmt
acl Safe_ports port 488         # gss-http
acl Safe_ports port 591         # filemaker
acl Safe_ports port 777         # multiling http
acl CONNECT method CONNECT

#允许localnet定义的链接访问该代理:
http_access allow localnet
#禁止非Safe_ports定义的端口被访问:
http_access deny !Safe_ports
#禁止非SSL_ports定义的端口被链接:
http_access deny CONNECT !SSL_ports
#允许Purge功能:
acl localhost src 127.0.0.1/32
acl Purge method PURGE
http_access allow localhost Purge
#除上面规定的允许访问的链接,其他都不能访问该代理(一定要有这句话,而且顺序不能变):
http_access deny all

#squid实现gzip功能配置:

ecap_enable on
ecap_service gzip_service respmod_precache 0 ecap://www.vigos.com/ecap_gzip
loadable_modules /usr/local/lib/ecap_adapter_gzip.so
acl GZIP_HTTP_STATUS http_status 200
adaptation_access gzip_service allow GZIP_HTTP_STATUS

#这些可以具体了解下acl规则。


#下面这个是以ftp开头的链接,过期时间为3168分钟:
refresh_pattern ^ftp:           1440    20%     10080
#如果想cache图片资源,cache时间为1天,则可以设置:
refresh_pattern –i .*\\.img.*:           1440    0%     2880
refresh_pattern –i .*\\.png.*:           1440    0%     2880
refresh_pattern –i .*\\.gif.*:            1440    0%     2880
#如果想cache那些第三方设置了no-cache的资源,可以增加options,如:
refresh_pattern –i .*\\.img.*:           1440    0%     2880  ignore-no-cache
refresh_pattern –i .*\\.png.*:           1440    0%     2880  ignore-no-cache
refresh_pattern –i .*\\.gif.*:            1440    0%     2880  ignore-no-cache
#除此之外还有很多其他的选项,如ignore-no-store,请参考squid.conf.document。 

#cache规则配置:

#这块是非常重要的,关系到哪些资源是需要cache,而哪些资源不能cache的。主要的命令就是refresh_pattern [-i] regexp min percent max [options]:

#先插入段讲解,关于后面那三个数(min percent max),算法如下:

 min, max的单位是分钟,percent就是百分比。

(当前时间定义为CURRENT_DATE)
1) If ((CURRENT_DATE-DATE(
就是LM里定义的时间)) < min),cache是新鲜的
2) else if ((CURRENT_DATE-DATE) < (min + (max-min)*percent)
,cache是新鲜的
3) else cache
是过期的
cache
过期就需要从后面server取新鲜内容

3、运行squid

先建立disk缓存区:

# /usr/local/squid/sbin/squid –z

启动squid:

# /usr/local/squid/sbin/squid

查看squid是否启动:

# ps –ef | grep squid

如果没有squid进程,则可以通过查看/usr/local/squid/var/logs/cache.log来查看原因,如有pinger相关的错误,则需要更改pinger权限,且看conf文件中是否已经设置了pinger的路径:

# sudo chown root:root /usr/local/squid/libexec/pinger
# sudo chmod u+s /usr/local/squid/libexec/pinger 

4、squid其他命令

1、关闭squid

/usr/local/squid/sbin/squid –k shutdown

2、重新载入config文件

/usr/local/squid/sbin/squid –k reconfigure

可以通过/usr/local/squid/sbin/squid –k parse来检查config文件配置是否正确。

3、查看squid的运行信息

获取cpu、内存、cache比例等数据:

/usr/local/squid/bin/squidclient -p 80 mgr:info

/usr/local/squid/bin/squidclient -p 80 cache_object://localhost/info

从cache中删除某个对象

/usr/local/squid/bin/squidclient -p 80 -m PURGE http://www.linux.com.cn/

往cache中添加某个对象

/usr/local/squid/bin/squidclient -p 80 http://www.linux.com.cn/

获取内存使用的详细信息

# /usr/local/squid/bin/squidclient -p 80 mgr:mem

获取cache对象列表(慎用,可能会导致squid崩溃)

# /usr/local/squid/bin/squidclient -p 80 mgr:objects

获取磁盘使用数据

# /usr/local/squid/bin/squidclient -p 80 mgr:diskd

4、清空cache

# /usr/local/squid/sbin/squid –k shutdown
# mv  /usr/local/squid/var/cache /usr/local/squid/var/cache-old
# mkdir cache
# /usr/local/squid/sbin/squid –z
# /usr/local/squid/sbin/squid
#rm –rf /usr/local/squid/var/cache-old 

5、透明代理设置

在conf文件中将http_port的设置改为

http_port 3128 transparent

使用iptables 做nat,并将所有的80请求重定向到本机的3128 以实现透明代理[摘自其他地方]。 
vi /data/myscripts/squid.firewall
脚本如下:

#!/bin/bash
echo "1" > /proc/sys/net/ipv4/ip_forward
echo "starting iptables rules"
/sbin/iptables -t filter -F
/sbin/iptables -t filter -Z
/sbin/iptables -t filter -X
/sbin/iptables -t nat -F
/sbin/iptables -t nat -Z
/sbin/iptables -t nat -X
/sbin/modprobe ip_tables
/sbin/modprobe iptable_nat
/sbin/modprobe iptable_filter
/sbin/modprobe ip_nat_ftp
/sbin/modprobe ip_conntrack
/sbin/modprobe ip_conntrack_ftp
/sbin/iptables -t filter -P INPUT ACCEPT
/sbin/iptables -t filter -P OUTPUT ACCEPT
/sbin/iptables -t filter -P  FORWARD ACCEPT
/sbin/iptables -t nat -A  POSTROUTING -s 192.168.1.0/24 -j SNAT --to-source a.b.c.d
/sbin/iptables -t nat -A  PREROUTING  -s 192.168.1.0/24 -p tcp --dport 80 -j REDIRECT --to-ports  3128

执行脚本并将其加入到开机自启动,注意将脚本中的a.b.c.d换成自己公司的公网静态ip

# ./squid.firewall
# echo "./squid.firewall" >>/etc/rc.d/rc.local 

6、将squid添加到开机自启动

# echo "/usr/local/squid/sbin/squid -s " >>/etc/rc.d/rc.local 

7、查看端口占用情况并杀掉对应进程:

# netstat –a
# lsof –i:3128   //查看占用该端口的进程id

8、情况iptables

 iptables -t nat -F
 iptables -t nat -X
 iptables -t nat -P PREROUTING ACCEPT
 iptables -t nat -P POSTROUTING ACCEPT
 iptables -t nat -P OUTPUT ACCEPT
 iptables -t mangle -F
 iptables -t mangle -X
 iptables -t mangle -P PREROUTING ACCEPT
 iptables -t mangle -P INPUT ACCEPT
 iptables -t mangle -P FORWARD ACCEPT
 iptables -t mangle -P OUTPUT ACCEPT
 iptables -t mangle -P POSTROUTING ACCEPT
 iptables -F
 iptables -X
 iptables -P FORWARD ACCEPT
 iptables -P INPUT ACCEPT
 iptables -P OUTPUT ACCEPT
 iptables -t raw -F
 iptables -t raw -X
 iptables -t raw -P PREROUTING ACCEPT
 iptables -t raw -P OUTPUT ACCEPT

5、squid运行中的问题

1、Your cache is running out of filedescriptors

sudo -s

ulimit -HSn 65536

在configure时加入 --with-maxfd=65536

不知道在squid.conf加入max_filedescriptors 15000是否起作用

6、squid实现gzip压缩,先要安装下列包

1、Download and install libecap Library

 http://www.e-cap.org/Downloads

cd libecap-0.0.3/
./configure
make
make install

2、Download and install VIGOS eCAP GZIP Adapter

http://code.google.com/p/squid-ecap-gzip/downloads/list

cd squid-ecap-gzip/
./configure
make
make install

原文地址:https://www.cnblogs.com/geekma/p/2625163.html