squid开多端口代理的心得

利用squid开二级代理很方便,就是在配置文件上做点文章, 它给的那个default的配置文件看起来就头大。一般都是重新写一个。

给A校区的兄弟们开了一个代理。用的是B校区的动态ip做的父代理。

但是动态实在是有够e。不能上国外不说,还经常抽筋。

由于手头有另一个专用代理A可以上国外,于是萌发了开两个二级代理的念头。

只有一台电脑,当然只能在一个自己上开两个端口(其实后来才想到可以用认证的方法,对一个端口进来的不同的用户采用不同的的父级代理,这样squid的配置文件会稍微麻烦一点),先开始不得要领,也没有现实的例子,看见有人这样开了,问一问才知道是windows下用wingate很简单就能做到了。

wingate能想到,我想squid也应该能做到,自己慢慢琢磨吧。

基本想法是:

服务端口3128-----squid-----动态ip连接----国内访问

服务端口6666-----squid-----代理A ----国外访问

先想到的是启动两次squid,第二次手动指定另外一个配置文件给它(-f),一尝试得到的信息是Squid is already running! Process ID **** 。想一想这种方法也有够野蛮,效率和稳定两不顾,于是弃之不用。

于是开始打配置文件的主意,在google上查到论坛上关于两个端口采用不同的认证的配置方法,OK,开两个端口就有路了,下来关键是对两个端口的接入进行分流。squid一般情况下是对不同的连接目标地址所在域进行分流的,比如把对.com的接连请求交给父代理X来做,对.edu.cn的请求代理交给父代理Y来做,

这种情况下用到了cache_peer_domain这个选择规则

cache_peer_domain Y .edu.cn

cache_peer_domain X !.edu.cn

既然有目标域的选择规则,那有没有针对其他情况的选择规则呢?

还是在squid.conf.default中查找到cache_peer_access这个功能强大的访问控制规则(其实这个又大又乱的squid.conf.default里所有的东西都教给我们了

,一开始就该好好阅读的)

比如通过访问控制列表进行选择:

对于来自192.168.1.0的请求我们使用local.proxy.com父代理服务

器,而对于其他请求由本地子代理服务器直接进行处理,

这时我们可以使用cache_peer_access选项来实现:

acl LocalNet src 192.168.1.0/

acl all src 0.0.0.0/0.0.0.0

cache_peer local.proxy.com parent 3128 3130

cache_peer_access local.proxy.com allow LocalNet

cache_peer_access local.proxy.com deny all

结合cache_peer_access的强大功能组合完成了下面的配置代码

http_port 3128

http_port 6666

#声明两个端口

acl X myport 3128

acl Y myport 6666

http_access allow X

http_access allow Y

#接受两个端口的http请求

acl all src 0.0.0.0/0.0.0.0

cache_peer 10.10.4.52 parent 6666 3130 login=***:*** default no-query

cache_peer 10.***.**.** parent 3128 3130

cache_peer_access 10.10.4.52 allow !Y

#让动态ip的父代理响应3128端口的接入,对6666端口的不响应

cache_peer_access 10.***.**.** allow Y

#让A代理响应6666端口的接入

这样便很好的对不同端口的访问进行了分流。使用起来效果也不错。

胡乱写一点希望对大家有用。