设为首页 收藏本站
查看: 797|回复: 0

[经验分享] Squid 理解

[复制链接]

尚未签到

发表于 2018-12-26 08:07:38 | 显示全部楼层 |阅读模式
  因工作中需要用到squid,为此开始学习squid。这只能说明一点,学习是被逼出来的。费话不多说,开始了!
  Squid的代理模式有:
  1.代理服务器
  理解:web直接将80请求发给代理服务器3128端口)
  2.透明代理
  理解:web的80请求被防火墙直接重定向到3128,因此透时代理对用户而言是不可见的。
  3.反向代理
  
  
一、代理服务器  这是SQUID的最基本功能;通过在squid.conf文件里添加一系列访问及控制规则,用户在客户端设置服务器地址和端口,即可通过SQUID访问INTERNET,在下面的规则里,squid实现局域网用户代理和高速缓存功能。
  http_port 3128 #监听内外网端口
  cache_dir ufs /var/squid  
  #定义内容缓存的目录   
cache_mem 32MB

  #定义内存缓冲的大小  
cache_swap_low 90  
cache_swap_high 95

  cache_dir /var/squid 1000 16 32
  dns_nameservers 202.96.128.86
  #设置硬盘缓冲的大小               
cache_access_log /var/log/squid/access.log

  #设置访问日志               
cache_log /var/log/squid/cache.log

  #设置缓存日志               
acl all src 0.0.0.0/0.0.0.0

  #允许所有人可以上网
  acl head src 192.168.0.2/255.255.255.255 192.168.0.3/255.255.255.255
  #定义可上网的网段               
acl denysite dstdomain tw net

  #定义阻止的网站               
acl denyip dst 202.96.134.133/255.255.255.255

  #定义阻止的目标IP               
acl dnsport port 53

  #定义DNS传输端口               
http_access allow head                 
http_access deny denysite

  #执行定义的阻止访问站点               
http_
access deny denyip               
#执行定义的阻止的目标IP

  http_access deny dnsport
  执行阻止的DNS请求
  visible_hostname 192.168.0.1
  #配置代理服务器的主机名
  cache_mgr ×××@redhat.com
  #配置管理员的邮址
  客户端在IE设置里填写代理服务器IP地址及端口,即刻实现高速上网。
  
  二、透明代理
  所谓透明代理,是相对于代理服务器而言,客户端不需要做任何和代理服务器相关的设置和操作,对用户而言,更本感觉不到代理服务器的存在,所以称之为透明代理
  ▲用户A发送一个访问请求到防火墙,由防火墙将该用户的访问请求转发到SQUID,SQUID在先检查自身缓存中有无该用户请求的访问内容,如果没有,则请求远端目的服务器,获取该用户的访问内容,在返回给用户的同时,在自身缓存保留一份记录以备下次调用;当用户B发送一个和用户A相同的访问请求时,由防火墙将转发该用户请求到SQUID,SQUID检查自身缓存发现有同样内容后,直接将该内容返回给用户。
  ▲注:在实际使用中,通常将SQUID和防火墙放在同一台机器上,为了更清楚的象浏览者描述其工作流程,在以下的流程图中将防火墙和SQUID分开显示

  要实现透明代理,需要在代理服务器的配置文件基础上加一些东西。
  http_port 3128 #监听内外网端口
  cache_dir ufs /var/squid  
  #定义内容缓存的目录   
cache_mem 32MB

  #定义内存缓冲的大小  
cache_swap_low 90  
cache_swap_high 95

  cache_dir /var/squid 1000 16 32
  dns_nameservers 202.96.128.86
  #设置硬盘缓冲的大小               
cache_access_log /var/log/squid/access.log

  #设置访问日志               
cache_log /var/log/squid/cache.log

  #设置缓存日志               
acl all src 0.0.0.0/0.0.0.0

  #允许所有人可以上网
  acl head src 192.168.0.2/255.255.255.255 192.168.0.3/255.255.255.255
  #定义可上网的网段               
acl denysite dstdomain tw net

  #定义阻止的网站               
acl denyip dst 202.96.134.133/255.255.255.255

  #定义阻止的目标IP               
acl dnsport port 53

  #定义DNS传输端口               
http_access allow head                 
http_access deny denysite

  #执行定义的阻止访问站点               
http_
access deny denyip               
#执行定义的阻止的目标IP

  http_access deny dnsport
  执行阻止的DNS请求
  visible_hostname 192.168.0.1
  #配置代理服务器的主机名
  cache_mgr ×××@redhat.com
  #配置管理员的邮址
  ++++++++++++++++以下为实现透明代理不可缺少的主句
  httpd_accel_host virtual
  #虚拟主机模式
  httpd_accel_with_proxy on
  #此项设置为ON后,Squid即是WEB请求的加速器,又是缓存代理服务器。
  httpd_accel_users_host_header on
  #此项设置ON后,在透时代理模式下,代理服务器的缓存功能才能正常工作。
  
  +++++++++++
  开启Linux 路由功能:
  方法1:ech0 "1">/proc/sys/net/ipv4/ip_forward               
#打开Linux中的包转发功能               

  方法2:#改变此文件(sysctl.conf)让包转发功能在系统启动以后自动生效;               
vi /etc/sysctl.conf               
#找到下面语句:               
# Controls IP packet forwarding               
net.ipv4.ip_forward = 0               
#把0改为1,改后如下:               
# Controls IP packet forwarding               
net.ipv4.ip_forward = 1

  ++++++++++++
  开启iptables的NAT及端口重定向
  iptables -t nat -A POSTROUTING -o eth1 -j MASQUERADE
  #打开iptables的NAT功能(eth1是连接外网或者连接Internet的网卡);               

  iptables -t nat -A PREROUTING -i eth0 -p tcp -m tcp --dport 80 -j REDIRECT --to-ports 8080               
#端口重定向(eth0是内网的网卡);               

  service iptables save               
#保存iptables的规则;               

  service iptables restart               
#重启iptables

  ++++++++++++++++++++
  互联网的访问控制:
  acl 2 src 192.168.0.2               
http_access allow 2               
#允许192.168.0.2这个ip地址的请求全部通过代理服务器;               

  acl qq url_regex -i qq.com               
http_access deny qq               
acl tencent url_regex -i tencent.com               
http_access deny tencent               
#禁止用户上qq               

  acl jzxz urlpath_regex -i \.exe$ \.rar$ \.zip$ \.mp3$ \.mp4$ \.rm$ \.wma$ \.rmvb$ \.avi$               
http_access deny jzxz               
#禁止用户下载以'.exe、.rar、mp3、mp4、.rm'等结尾的文件(注意空格啊!没有空格便失效)               

  acl all src 192.168.0.1/255.255.255.0               
http_access allow all               
#设置访问控制列表,让代理服务器接受来自192.168.0这个网段的请求。

  
  博文若有问题,请大家拍砖!
  2010-4-1 深圳地王




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-655881-1-1.html 上篇帖子: 通过web修改squid用户上网密码 下篇帖子: squid流量限制
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表