缓存代理概述

  • Squid提供了强大的代理控制机制,通过合理的设置ACL,并进行限制,可以针对源地址、目标地址、访问的URL路径、访问的时间等条件进行过滤。 作为应用层的代理服务器软件,Sqiod主要提供了缓存加速和引用层过滤控制能力
  • 代理的工作机制

当客户机通过代理来请求 Web 页面时,指定的代理服务器,会先检查自己的缓存如果缓存中已经有客户机需要访问的页面,则直接将缓存中的页面内容反馈给客户机;如果缓存中没有客户机需要访问的页面,则用代理服务器向Internet 发送访问请求。

由于客户机的Web 访问请求实际上时由代理服务器来代替完成的,从而可以隐藏用户的真是IP地址,起到一定的保护作用。另一方面,代理服务器承担这类似经纪人人的角色,所以有机会针对要访问的目标,客户机,访问的时间段等进行过滤控制。

  • 代理的基本类型
  1. 传统代理:也就是普通的代理服务,首先必须在客户机的浏览器,QQ聊天工具消灾软件过程中手动设置代理服务器地址和端口,然后才能使用代理武器来访问网络,
  2. 透明服代理:提供传统意义上的代理,区别在于客户机不需要指定代理服务器的地址和端口,而是通过默认路由,防火墙策咯将Web访问重定向,实际上仍然交给代理服务器,来处理。使用透明代理网页浏览器访问的网站的域名解析请求将有限交给DNS服务器
  • 安装及运行控制
mount.cifs //192.168.100.1/squid /abc/ #挂在共享目录
tar zxvf squid-3.4.6.tar.gz -C /opt/  #解压
cd /opt/squid-3.4.6
yum install gcc gcc-c++ make cmake -y //由于时手工编译安装所以需要安装一些需要的环境
./configure --prefix=/usr/local/squid \  #安装目录
--sysconfdir=/etc \  #单独将配置文件修改到其他目录
--enable-arp-acl \    #可在规则中设置为直接通过客户端MAC进行管理,放置客户端使用IP欺骗
--enable-linux-netfilter \ # 使用内核过滤
--enable-linux-tproxy \    # 支持透明模式
--enable-async-io=100 \    #异步I/O提升存储性能,相当于 --enable-pthreads --enable-storeio=ufs,aufs 
--enable-err-language="Simplify_Chinese" \ #错误信息的显示语言
--enable-underscore \   #允许URL中有下划线
--enable-poll \         #使用poll()模式提升性能
--enable-gnuregex       #使用GNU正则表表达式
manke && make install
创建链接文件 创建用户和组 制作启动脚本
ln -s /usr/local/squid/sbin/* /usr/local/sbin/  创建链接文件 创建用户和组
useradd -M -s /sbin/nologin squid
chown -R squid.squid /usr/local/squid/var/
vim /etc/squid.conf #修改配置文件
http_access allow all
http_access deny all
http_port 3128
cache_mem 64 MB                   #指定缓存功能所使用的内存空间大小,便于保持访问较频繁的WEB对象,容量最好为4的倍数,单位为MB,建议设为物理内存的1/4
reply_body_max_size 10 MB         #允许用户下载的最大文件大小,以字节为单位。默认设置0表示不进行限制
maximum_object_size 4096 KB       #允许保存到缓存空间的最大对象大小,以KB为单位,超过大小限制的文件将不被缓存,而是直接转发给用户
cache_effective_user squid        #添加   指定程序用户
cache_effective_group squid       #添加   指定账号基本组
coredump_dir /usr/local/squid/var/cache/squid

squid -k parse   //检查配置文件语法
squid -z   //初始化缓存目录
squid    //启动服务

cd /etc/init.d/
vim squid   制作启动脚本

#!/bin/bash
#chkconfig: 2345 90 25
PID="/usr/local/squid/var/run/squid.pid"
CONF="/etc/squid.conf"
CMD="/usr/local/squid/sbin/squid"

case "$1" in
   start)
     netstat -natp | grep squid &> /dev/null
     if [ $? -eq 0 ]
     then
       echo "squid is running"
       else
       echo "正在启动 squid..."
       $CMD
     fi
   ;;
   stop)
     $CMD -k kill &> /dev/null
     rm -rf $PID &> /dev/null
   ;;
   status)
     [ -f $PID ] &> /dev/null
        if [ $? -eq 0 ]
          then
            netstat -natp | grep squid
          else
            echo "squid is not running"
        fi
   ;;
   restart)
      $0 stop &> /dev/null
      echo "正在关闭 squid..."
         $0 start &> /dev/null
      echo "正在启动 squid..."
   ;;
   reload)
      $CMD -k reconfigure
   ;;
   check)
      $CMD -k parse
   ;;
   *)
      echo "用法:$0{start|stop|status|reload|check|restart}"
   ;;
esac
chmod +x squid  #提升执行权限
chkconfig --add squid  #加如到被系统所管理
chkconfig --level 35 squid on #实现开机自启动
iptables -F
setenforce 0
iptables -I INPUT -p tcp --dport 3218 -j ACCEPT
    整对于 INPUT链  指定 tcp 目标端口 3218 允许转发
service squid reload

透明代理
配置双网卡内网ens33  外网ens36
echo "1" > /proc/sys/net/ipv4/i[_forward  //开启路由转发功能
vim /etc/squid.conf

http_port 192.168.100.1:3128 transparent //只在其中一个IP地址上提供代理

service squid reload  

iptables -t nat -I PREROUTING -i ens33 -s 192.168.100.0/24 -p tcp --dport 80 -j REDIRECT --to 3128
 
iptables -t nat -I PREROUTING -i ens33 -s 192.168.100.0/24 -p tcp --dport 443 -j REDIRECT --to 3128

iptables -I INPUT -p tcp --dport 3218 -j ACCEPT

ACL访问控控制
  • squid 提供了强大的代理控制机制,通过合理设置ACL访问控制列表,并进行限制,可以针对源地址、目标地址、访问的URL路径,访问的是时间各种条件进行过滤。
  • 在配置文件squid.confACL访问控制通过以下两个步骤实现:其一,使用acl配置的定义需要控制的条件;其二通过http access 配置项对已定义的列表做“允许”或拒绝访问控制
  • squid预定义的列表类型有和多种,常用的包括源地址,目标地址,访问时间,访问端口。
列表类型 列表内容实列 含义\通途
src 192.168.1.168/192.168.1.0/24、192.168.1.0-192.168.3.0/24 源IP地址,网段、IP地址范围
dst 216.163.137.3、61.135.167.0/24、www.playboy.com 目标IP地址、网段、主机名
por 80 443 8080 20 21 目标端口
dstdomain .qq.com 目标域,匹配域的所在站点
time MTWHF 8:30-17:30 12:00-13:00 AS 使用代理服务器的时间段 字母表示一个星期隔天的英文所缩写
maxconn 20 每个客户机的并非连接数 最大连接数
url_regex url_regex-i^rtsp:// url_regex-i^emule:// 目标资源的URL地址,-i表示忽略大小写^以什么开头
urlpath_regex urlpath_regex -i sex adult urlpath_regex-i.mp3$ 目标资源的真个URL路径,-i表示忽略大小写
  • 在定义访问控制列表时。因该结合当前往网络环境真确的分析用户发文需求 当需要限制的同一类型比较多时,可以通过使用独立的文件来存放。在acl配置行的列表内容处指定对应的文件位置即可 没有设置任何规则时:squid服务将拒绝客户端的请求 有规则但是涨找不到想匹配的选项squid 将采取与最后一条规则相反的权限,即如果最后一条规则时allow,就拒绝客户端请求,否则允许该请求,建议采用,先拒绝后允许,或者先允许在拒绝,的方式最后一条规则设为默认策略,可以为http_access allow all 或者http_access deny all
  • 实验部署
名称 IP地址
squid服务器 192.168.100.7
wed1服务器 192.168.100.8
wed2服务器 192.168.100.9
客户端W7 192.168.100.10
  • 修改定义配置文件内
vim /etc/squid.conf
# Deny requests to certain unsafe ports 对于端口进行控制
# Only allow cachemgr access from localhost 对于列表进行控制
acl localhost src 192.168.100.10/32   #基于源地址
acl MYLAN src 192.100.0/24         #基于源网段
acl destionhost dst 192.168.100.10/32 #基于目标地址
acl MC20 maxconn 20                    #基于端口
acl BURL url_regex -i ^rtsp:// ^emule:// #目标资源的URL地址,-i表示忽略大小写(以什么什么开头)
acl PURL urlpath_regex -i \.mp3$ \.mp4$ \.rmvb$ #目标资源的整个URL路径,-i表示忽略大小写(以什么什么结尾)
acl work time MTWHF 08:30-17:30 #基于时间段禁止访问
mkdir /etc/squid     #启用对象列表管理
vim dest.list  #创建如都在统一网段或者定义大部分禁止访问的地址
192.168.100.10 #客户端W7
vim /etc/squid.conf  
acl destionhost dst "/etc/squid/dest.list"  
#写入前面创建的的文件路径到需要添加或者删除只需要在前面创建的文件里定义就可以不用在请主配置文件修改
http_access deny destionhost   #拒绝列表(注意置顶)
service squid restart  

日志分析
yum install -y gd gd-devel    #图像处理 httpd -y   

mkdir /usr/local/sarg

tar zxvf sarg-2.3.7.tar.gz -C /opt/

cd /opt/sarg-2.3.7

./configure --prefix=/usr/local/sarg \
--sysconfdir=/etc/sarg \
--enable-extraprotection            #额外安全防护

make && make install

cd /etc/sarg/

vim sarg.conf

access_log /usr/local/squid/var/logs/access.log    //指定访问日志文件

title "Squid User Access Reports"      //网页标题

output_dir /var/www/html/squid-reports    //报告输出目录

user_ip no          //使用用户名显示

exclude_hosts /usr/local/sarg/noreport   //不计入排序的站点列表文件

topuser_sort_field connect reverse   //top排序中有连接次数、访问字节、降序排列 升序是normal

user_sort_field reverse    //用户访问记录 连接次数、访问字节按降序排序

overwrite_report no   //同名日志是否覆盖

mail_utility mailq.postfix   //发送邮件报告命令

charset UTF-8   //使用字符集

weekdays 0-6   //top排行的星期周期

hours 0-23   //top排行的时间周期

www_document_root /var/www/html  //网页根目录


#添加不计入站点文件,添加的域名将不被显示在排序中
touch /usr/local/sarg/noreport

ln -s /usr/local/sarg/bin/sarg /usr/local/bin/


[root@localhost sarg]# sarg 
SARG: 纪录在文件: 242, reading: 100.00%
SARG: 成功的生成报告在 /var/www/html/squid-reports/2018Jul21-2018Jul21

yum install httpd -y

http://192.168.175.128/squid-reports

#周期性计划任务执行每天生成报告
sarg -l /usr/local/squid/var/logs/access.log -o /var/www/html/squid-reports/ -z -d $(date -d "1 day ago" +%d/%m/%Y)-$(date +%d/%m/%Y)

squid反向代理
vim /var/www/html/index.html  #wed1 添加首页内容 test01 
vim /var/www/html/index.html  #wed2 添加首页内容 test02
vim /etc/squid.conf
# Squid normally listens to port 3128 #下添加
http_port 192.168.100.7:80 accel vhost vport
(// 本地地址   accel:加速代理  虚拟主机  虚拟端口)
cache_peer 192.168.100.8 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web1
cache_peer 192.168.100.9 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web2
(//指定负向服务器  ICP端口不开启设为0   不进行查询  指向真实服务器  轮询   最大连接30   权重1   名字)
cache_peer_domain web1 web2 www.yun.com
(//指定web1,web2的域名为www.yun.com )