Squid代理服务器应用
Squid代理服务器
Squid主要提供缓存加速、应用层过滤控制的功能。
代理的工作机制:
代理服务器的概念及其作用:
其主要作用有:
Squid代理的类型:
根据实现的方式不同,基本可以分为传统代理和透明代理两种方式:
传统代理:也就是普通的代理服务,需要我们客户端在浏览器、聊天工具等一些程序中设置代理服务器的地址和端口,然后才能使用代理来访问网络,这种方式相比较而言比较麻烦,因为客户机还需手动指定代理服务器,所以一般用于Internet环境。
透明代理:与传统代理实现的功能是一样的,区别在于客户机不需要手动指定代理服务器的地址和端口,而是通过默认路由、防火墙策略将web访问重定向,实际上仍然交给代理服务器来处理,重定向的过程完全是由squid服务器进行的,所以对于客户机来说,甚至不知道自己使用了squid代理服务,因此称之为透明模式。
透明代理多用于局域网环境,如在Linux网关中启用透明代理后,局域网主机无须进行额外设置就能享受更好的上网速度。
------------安装运行Squid服务------------
systemctl stop firewalld systemctl disable firewalld setenforce 0
1、编译安装Squid
#安装依赖环境 yum -y install gcc gcc-c++ make #上传软件包squid-3.5.27. tar到/opt目录下 cd /opt #解压 tar zxvf squid-3.5.27.tar.gz #配置相关模块 cd squid-3.5.27/ ./configure --prefix=/usr/local/squid \ --sysconfdir=/etc \ --enable-arp-acl \ --enable-linux-netfilter \ --enable-linux-tproxy \ --enable-async-io=100 \ --enable-err-language="Simplify_Chinese" \ --enable-underscore \ --enable-poll \ --enable-gnuregex #编译安装 make && 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/ #改变目录属主,此目录用来存放缓存文件
2、修改Squid的配置文件
vim /etc/squid.conf ...... -----56行--插入------ http_access allow all #放在http_access deny all 之前,允许任意客户机使用代理服务,控制规则自上而下匹配 http_access deny all http_port 3128 #用来指定代理服务监听的地址和端口(默认的端口号为3128) -----61行--插入------ cache_effective_user squid #添加,指定程序用户,用来设置初始化、运行时缓存的账号,否则启动不成功 cache_effective_group squid #添加,指定账号基本组 coredump_dir /usr/local/squid/var/cache/squid #指定缓存文件目录
3、Squid 的运行控制
#检查配置文件语法是否正确 squid -k parse #启动Squid, 第一次启动Squid服务时,会自动初始化缓存目录 squid -z #-z选项用来初始化缓存目录 squid #启动squid 服务 netstat -anpt | grep "squid"
4、创建 Squid 服务脚本
vim /etc/init.d/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
#2345是默认自启动级别,如是 - 代表任何级别都不自启动; 90是启动优先级,25是停止优先级, 优先级范围是0一100,数字越大,优先级越低。
chmod +x /etc/init.d/squid chkconfig --add squid chkconfig --level 35 squid on
------------搭建传统代理服务器------------
vim /etc/squid.conf ...... http_access allow all http_access deny all http_port 3128 cache_effective_user squid cache_effective_group squid ---63行,插入---- cache_mem 64 MB #指定缓存功能所使用的内存空间大小,便于保持访问较频繁的WEB对象,容量最好为4的倍数,单位为MB,建议设为物理内存的1/4 reply_body_max_size 10 MB #允许用户下载的最大文件大小,以字节为单位,当下载超过指定大小的Web对象时,浏览器的报错页面中会出现“请求或访问太大”的提示默认设置0表示不进行限制 maximum_object_size 4096 KB #允许保存到缓存空间的最大对象大小,以KB为单位,超过大小限制的文件将不被缓存,而是直接转发给用户 service squid restart 或 systemctl restart squid #生产环境中需要修改防火墙规则 iptables -F iptables -I INPUT -p tcp --dport 3128 -j ACCEPT iptables -nL INPUT #客户机的代理配置 打开浏览器,工具-->Internet选项-->连接 -->局域网设置-->开启代理服务器 (地址: Squid服务器IP地址,端口: 3128) #查看Squid访问日志的新增记录 tail -f /usr/local/squid/var/logs/access.log #查看Web访问日志的新增记录 tail -f /var/log/httpd/access_log 在浏览器输入Web服务器IP地址访问,查看Web服务器访问日志,显示的是由代理服务器替客户机在访问。
------------搭建透明代理服务器------------
squid服务器 :双网卡 ens33:192.168.73.10,ens36:12.0.0.1
web服务器:12.0.0.18(网关为squid代理服务器的ens36)
客户机:192.168.73.120(网关为squid代理服务器的ens33)
1、Squid服务器配置
cd /etc/sysconfig/network-scripts/ cp ifcfg-ens33 ifcfg-ens36 vim ifcfg-ens36 #修改IP地址,并注释或者删除DNS与网关 systemctl restart network
vim /etc/squid.conf http_access allow all http_access deny all --60行--修改添加提供内网服务的IP地址,和支持透明代理选项transparent http_port 192.168.73.10:3128 transparent systemctl restart squid #开启路由转发 echo 'net.ipv4.ip_forward = 1' >> /etc/sysctl.conf sysctl -p #修改防火墙规则 iptables -F iptables -t nat -F iptables -t nat -I PREROUTING -i ens33 -s 192.168.229.0/24 -p tcp --dport 80 -j REDIRECT --to 3128 #用于转发Http协议 iptables -t nat -I PREROUTING -i ens33 -s 192.168.229.0/24 -p tcp --dport 443 -j REDIRECT --to 3128 #用于转发https协议 iptables -I INPUT -p tcp --dport 3128 -j ACCEPT
2、Web服务器配置
修改IP地址为12.0.0.18,并设置网关为12.0.0.1
yum install -y http systemctl start httpd
客户机关闭代理服务器功能,并设网关为Squid服务器的ens33网卡
------------ACL访问控制------------
访问控制列表(Access Control Lists,ACL)是应用在路由器接口的指令列表。这些指令列表用来告诉路由器哪些数据包可以收、哪些数据包需要拒绝。至于数据包是被接收还是拒绝,可以由类似于源地址、目的地址、端口号等的特定指示条件来决定。
ACL访问控制方式
根据源地址、目标URL、文件类型等定义列表
针对已定义的acl列表进行限制
ACL规则优先级
一个用户访问代理服务器时, Squid会顺序匹配Squid中定义的所有规则列表,一旦匹配成功,立即停止匹配。
所有规则都不匹配时, Squid会使用与最后一条相反的规则
常用的ACL列表类型
src | 源地址 |
dst | 目标地址 |
port | 目标地址 |
dstdomain | 目标域 |
time | 访问时间 |
maxconn | 最大并发连接 |
url_regex | 目标URL地址 |
Urlpath_regex | 整个目标URL路径 |
设置ACL访问控制
在配置文件squid.conf中, ACL访问控制通过以下两个步骤来实现:
(1)使用acl配置项定义需要控制的条件
(2)通过http_access配置项对已定义的列表做“允许"或“拒绝"访问的控制。
##定义访问控制列表 vim /etc/squid.conf ...... acl localhost src 192.168.73.10/32 #源地址为192.168.73.10 acl MYLAN src 192.168.229.0/24 #客户机网段 acl destinationhost dst 192.168.73.20/32 #目标地址为192.168.73.20 acl MC20 maxconn 20 #最大并发连接20 acl PORT port 21 #目标端口21 acl DMBLOCK dstdomain .qq.com #目标域,匹配域内所有站点 acl BURL url_regex -i ^rtsp:// ^emule:// #以rtsp://.emule://开头的URL,-i表示忽略大小写 acl PURL urlpath_regex -i \.mp3$ \.mp4$ \.rmvb$ #以.mp3、.mp4、.rmvb结尾的URL路径 acl WORKTIME time MTWHF 08:30-17:30 #时间为周一--至周五8:30~17:30,"MTWHF"为每个星期的英文首字母
##启动对象列表管理 mkdir /etc/squid vim /etc/squid/dest.list 192.168.73.10 #Squid服务器IP 192.168.200.0/24 #任意需要的网段 vim /etc/ squid.conf ....... acl destinationhost dst "/etc/squid/dest.list" #调用指定文件中的列表内容 http access deny(或allow) destinationhost #注意,如果是拒绝列表,需要放在http_access allow all前面 systemctl restart squid
浏览器访问192.168.73.20查看web是否被拒绝
------------Squid日志分析------------
#安装图像处理软件包 yum install -y gd gd-devel pcre-devel 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 \ #配置文件目录,默认是/usr/local/etc --enable-extraprotection #额外安全防护 make && make install vim /etc/sarg/sarg.conf --7行--取消注释 access_log /usr/local/squid/var/logs/access.1og #指定访问日志文件 --25行--取消注释 title "Squid User Access Reports" #网页标题 -- 120行--取消注释,修改 output_dir /var/www/html/squid-reports #报告输出目录 --178行--取消注释 user_ip no #使用用户名显示 --184行--取消注释,修改 topuser_sort_field connect reverse #top排序中,指定连接次数采用降序排列,升序是normal -- 190行--取消注释,修改 user_sort_field connect reverse #对于用户访问记录,连接次数按降序排序 --206行--取消注释,修改 exclude_hosts /usr/local/sarg/noreport #指定不计入排序的站点列表的文件 --257行--取消注释 overwrite_report no #同名同日期的日志是否覆盖 --289行--取消注释,修改 mail_utility mailq.postfix #发送邮件报告命令 --434行--取消注释,修改 charset UTF-8 #指定字符集UTF-8 --518行--取消注释 weekdavs 0-6 #top排行的星期周期 --525行--取消注释 hours 0-23 #top排行的时间周期 --633行--取消注释 www_document_root /var/www/html #指定网页根目录 #添加不计入站点文件,添加的域名将不被显示在排序中 touch /usr/local/sarg/noreport ln -s /usr/local/sarg/bin/sarg /usr/local/bin/ sarg --help #验证 yum install httpd -y systemctl start httpd #运行 sarg #启动一次记录
Squid服务器使用浏览器访问http://192.168.73.10/sarg, 查看sarg报告网页
添加计划任务,执行每天生成报告
vim /usr/local/sarg/report.sh #/bin/bash #Get current date TODAY=$(date +%d/%m/%Y) #Get one week ago today YESTERDAY=$(date -d "1 day ago" +%d/%m/%Y) /usr/local/sarg/bin/sarg -l /usr/1ocal/squid/var/logs/access.log -o /var/www/html/sarg -z -d $YESTERDAY-$TODAY &> /dev/null exit 0 chmod +x /usr/local/sarg/report.sh crontab -e 0 0 * * * /usr/1ocal/sarg/report.sh
------------Squid反向代理------------
工作机制
缓存网页对象,减少重复请求
将互联网请求轮训或按权重分配到内网Web服务器
代理用户请求,避免用户直接访问Web服务器,提高安全
vim /etc/ squid.conf 60行--修改,插入------- http_port 192.168.73.10:80 accel vhost vport cache_peer 192.168.73.20 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web1 cache_peer 192.168.73.30 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web2 cache_peer_domain web1 web2 www.benet.com #表示对www.benet.com的请求,squid向192.168.73.20和192.168.73.30的80端口发出请求
http_port 80 accel vhost vport
#squid从一个缓存变成了一个Web服务器反向代理加速模式,这个时候squid在80端口监听请求,同时和webserver的请求端口(vhost vport)绑定,这个时候请求到了squid, squid是不用转发请求的,而是直接要么从缓存中拿数据要么向,绑定的端口直接请求数据。
accel:反向代理加速模式
vhost:支持域名或主机名来表示代理节点
vport:支持IP和端口来表示代理节点
parent:代表为父节点,上下关系,非平级关系
80:代理内部web服务器的80端口
0:没有使用icp,表示就一台squid服务器
no-query:不做查询操作,直接获取数据
originserver:指定是源服务器
round-robin:指定squid 通过轮询方式将请求分发到其中一-台父节点
max_conn:指定最大连接数
weight:指定权重
name:设置别名
#清空防火墙规则,并放空3128端口 iptables -F iptables -t nat -F iptables -I INPUT -p tcp --dport 3128 -j ACCEPT systemctl stop httpd #防止httpd服务使用的80端口号和squid反向代理配置的监听端口冲突 systemctl restart squid #后端节点服务器设置 yum install -y httpd systemctl start httpd #节点1(web1): echo "this is test01" >> /var/www/html/index.html #节点2(web2): echo "this is test02" >> /var/www/html/index.html
客户机的域名映射配置
修改C: \Windows\System32 \drivers\etc\hosts 文件
192.168.73.10 www.benet.com
客户机的代理配置
打开浏览器,工具-->Internet选项-->连接-->局域网设置-->开启代理服务器(地址: Squid服务器IP地址,端口:80)
浏览器访问http://www.benet.com