关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻公共列表

云服务器Squid Linux版配置反向代理,加速网站访问

发布时间:2022/11/10 13:11:38
香港云服务器

一、简介

代理服务器英文全称是Proxy Server,其功能就是代理网络用户去取得网络信息。

Squid是一个缓存Internet 数据的软件,其接收用户的下载申请,并自动处理所下载的数据。当一个用户想要下载一个主页时,可以向Squid 发出一个申请,要Squid 代替其进行下载,然后Squid 连接所申请网站并请求该主页,接着把该主页传给用户同时保留一个备份,当别的用户申请同样的页面时,Squid 把保存的备份立即传给用户,使用户觉得速度相当快。Squid 可以代理HTTP、FTP、GOPHER、SSL和WAIS等协议并且Squid 可以自动地进行处理,可以根据自己的需要设置Squid,使之过滤掉不想要的东西。

1.1 工作流程

当代理服务器中有客户端需要的数据时:

a. 客户端向代理服务器发送数据请求;

b. 代理服务器检查自己的数据缓存;

c. 代理服务器在缓存中找到了用户想要的数据,取出数据;

d. 代理服务器将从缓存中取得的数据返回给客户端。

当代理服务器中没有客户端需要的数据时:

1. 客户端向代理服务器发送数据请求;

2. 代理服务器检查自己的数据缓存;

3. 代理服务器在缓存中没有找到用户想要的数据;

4. 代理服务器向Internet 上的远端服务器发送数据请求;

5. 远端服务器响应,返回相应的数据;

6. 代理服务器取得远端服务器的数据,返回给客户端,并保留一份到自己的数据缓存中。

Squid代理服务器工作在TCP/IP的应用层。

1.2 Squid 分类

按照代理类型的不同,可以将Squid 代理分为正向代理和反向代理,正向代理中,根据实现方式的不同,又可以分为普通代理和透明代理。

普通代理:需要客户机在浏览器中指定代理服务器的地址、端口;

透明代理:适用于企业的网关主机(共享接入Internet)中,客户机不需要指定代理服务器地址、端口等信息,代理服务器需要设置防火墙策略将客户机的Web访问数据转交给代理服务程序处理;

反向代理:是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。

官方地址:http://www.squid-cache.org/

参考文档:http://www.squid-cache.org/Doc/config/

二、系统环境

操作系统:CentOS release 6.x或以上

Squid版本:squid-3.1.10-20.el6_5.3.x86_64或以上

SELINUX=disabled

HTTP Service: stoped

三、安装Squid服务

3.1 检查squid软件是否安装

# rpm -qa|grep squid

3.2 如果未安装,则使用yum 方式安装

# yum -y install squid

3.3 设置开机自启动

# chkconfig --level 35 squid on             //在3、5级别上自动运行squid服务

四、squid服务器的配置文件说明

squid 的主配置文件是 /etc/squid/squid.conf,所有squid的设定都是在这个文件里配置,下面我们来讲解一下该文件的配置选项。

http_port 3128      //设置监听的IP与端口号cache_mem 64 MB      //额外提供给squid使用的内存,squid的内存总占用为 X * 10+15+“cache_mem”,其中X为squid的cache占用的容量(以GB为单位),               //比如下面的cache大小是100M,即0.1GB,则内存总占用为0.1*10+15+64=80M,推荐大小为物理内存的1/3-1/2或更多。maximum_object_size 4 MB   //设置squid磁盘缓存最大文件,超过4M的文件不保存到硬盘minimum_object_size 0 KB   //设置squid磁盘缓存最小文件maximum_object_size_in_memory 4096 KB   //设置squid内存缓存最大文件,超过4M的文件不保存到内存cache_dir ufs /var/spool/squid 100 16 256   //定义squid的cache存放路径 、cache目录容量(单位M)、一级缓存目录数量、二级缓存目录数量logformat combined %&gt;a %ui %un [%tl] "%rm %ru HTTP/%rv" %Hs %h" "%{User-Agent}&gt;h" %Ss:%Sh        //log文件日志格式access_log /var/log/squid/access.log combined  //log文件存放路径和日志格式cache_log /var/log/squid/cache.log   //设置缓存日志logfile_rotate 60   //log轮循 60天cache_swap_high 95  //cache目录使用量大于95%时,开始清理旧的cachecache_swap_low 90   //cache目录清理到90%时停止。acl localnet src 192.168.1.0/24  //定义本地网段http_access allow localnet  //允许本地网段使用http_access deny all  //拒绝所有visible_hostname squid.david.dev  //主机名cache_mgr mchina_tang@qq.com  //管理员邮箱

关于ACL的知识,大家可以自行百度查阅,其他更多高级选项,请参考官方文档:http://www.squid-cache.org/Doc/config/。

注意:squid2.0 和squid3.0的差别还是很大的,如果配置完,启动squid不正确,请大家多多参考官方文档的相应版本说明。

五、反向代理服务

为Internet用户访问企业Web站点提供缓存加速。

具体配置如下:

5.1 关闭防火墙

# /etc/init.d/iptables stop

5.2 配置squid

http_port 80 vhost   //反向代理监控端口一般使用80,并启用虚拟主机支持vhosthttp_access allow all  //允许所有访问cache_dir ufs /var/spool/squid 40960 16 256   //配置缓存路径及缓存参数#下面两条用来配置反向代理主机cache_peer 192.168.2.101 parent 80 0 no-query originserver name=www   //配置父节点服务器,请将ip改为自己网站源服务器ip,端口修改为源站使用的端口,name后的名称可以自定义cache_peer_domain www  www.xxx.com // 配置父节点服务器支持访问的域名,注意域名前面的名称要和上条命令中name指定的一致,后面跟自己的域名。

5.3 重启squid服务

执行 /etc/init.d/squid restart 命令重启squid服务,如果报错,请检查具体报错,进行修改。

完成后可以访问刚才设置的域名,检查反向代理工作是不是正常,同时也可以进到缓存目录下查看是否已经生成了缓存目录,到此。反向代理配置完成。


补充说明:

tail -f /var/log/squid/access.log  通过这条命令可以查看squid实时访问日志
squidclient -h 127.0.0.1 -p 80 mgr:info  通过这条命令可以查看squid实时运行数据