●根据源地址、目标URL、文件类型等定义列表
acl 列表名称 列表类型 列表内容...
●针对已定义的ac列表进行限制
http_ access allow或deny 列表名称...
当一个用户访问代理服务器时,Squid会顺序匹配Squid中定义 的所有规则列表,一旦匹配成功,立即停止匹配。当所有规则都 不匹配时,Squid会使用与最后一条相反的规则
src→源地址 dst→目标地址 port→目标地址 dstdomain→目标域 time→访问时间 maxconn→最大并发连接 url_regex→目标URL地址 Urlpath_regex→整个目标URL路径
acl hostlocal src IP地址 #hostlocal表示是名称 http_access deny hostlocal #拒绝访问
[root@squid ~]# vim /etc/squid.conf ##修改配置文件 # should be allowed acl hostlocal src 192.168.10.10/32 ##控制hostlocal的主机 # Deny requests to certain unsafe ports http_access deny hostlocal ##拒绝访问 [root@squid ~]# service squid reload ##重启squid服务
acl work time WTHMFAS 8:00-12:00 #时间设置在工作日 8:30-17:00 http_access deny work #拒绝访问
#先创建一个目录,将拒绝的目标地址添加到一个文件中 mkdir /etc/squid vim dest.list #将拒绝的ip地址添加到文件中 192.168.10.111 192.168.10.123 192.168.10.136 #编辑配置文件 vim /etc/squid.conf #指定先前的地址文件路径为目标 acl destion dst "/etc/squid/dest.list" #拒绝目标访问 http_access deny destion
[root@squid ~]# mount.cifs //192.168.100.3/LNMP-C7 /mnt/ ##挂载 Password for root@//192.168.100.3/LNMP-C7: [root@squid ~]# cd /mnt/ [root@squid mnt]# tar zxvf sarg-2.3.7.tar.gz -C /opt/ ##解压 [root@squid mnt]# cd /opt/sarg-2.3.7/ [root@squid sarg-2.3.7]# yum install gd gd-devel -y ##安装gd库 [root@squid sarg-2.3.7]# ./configure --prefix=/usr/local/sarg \ ##安装路径 > --sysconfdir=/etc/sarg \ ##配置文件 > --enable-extraprotection ##开启安全防护 [root@squid sarg-2.3.7]# make && make install ##编译安装
[root@squid sarg-2.3.7]# vim /etc/sarg/sarg.conf ##修改sarg配置文件 ##将下面的模块修改开启 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 overwrite_report no ##同名日志是否覆盖 mail_utility mailq.postfix ##发送邮件报告命令 charset UTF-8 ##使用字符集 weekdays 0-6 ##top排行的时间周期 hours 0-23 ##top排行的时间周期 www_document_root /var/www/html ##网页根目录 [root@squid ~]# sarg ##生成报告 SARG: 纪录在文件: 91, reading: 100.00% SARG: 成功的生成报告在 /var/www/html/squid-reports/2019Dec11-2019Dec12 [root@squid sarg-2.3.7]# cd /var/www/html/squid-reports/ ##切换到html目录下 [root@squid squid-reports]# ls 2019Dec11-2019Dec12 images index.html [root@squid squid-reports]# yum install httpd -y ##安装httpd服务 [root@squid squid-reports]# systemctl start httpd.service ##开启服务 [root@squid squid-reports]# systemctl stop firewalld.service ##关闭防火墙 [root@squid squid-reports]# setenforce 0
##周期性计划任务执行每天生成报告crontab 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)
[root@web ~]# cd /var/www/html/ [root@web html]# vim index.html ##编辑网页内容 <h2>this is test web!</h2>
[root@web2 ~]# systemctl stop firewalld.service ##关闭防火墙 [root@web2 ~]# setenforce 0 [root@web2 ~]# yum install httpd -y ##安装httpd服务 [root@web2 ~]# cd /var/www/html/ ##创建网页内容 [root@web2 html]# vim index.html <h2>this is test2 web!</h2> [root@web2 html]# systemctl start httpd.service
[root@localhost squid]# vim /etc/squid.conf # Squid normally listens to port 3128 http_port 192.168.13.184:80 accel vhost vport ##监控本机80端口 cache_peer 192.168.13.151 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web1 ##节点服务器1最大访问30,权重1,别名web1 cache_peer 192.168.13.185 parent 80 0 no-query originserver round-robin max_conn=30 weight=1 name=web1 cache_peer_domain web1 web2 www.yun.com ##访问yun.com匹配web1,web2节点 [root@localhost squid]# service squid restart ##重启squid服务