1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > squid常规代理实现内网的共享上网

squid常规代理实现内网的共享上网

时间:2019-02-12 07:39:01

相关推荐

squid常规代理实现内网的共享上网

一、Squid的简单介绍

通过squid代理服务器实现内网用户共享上网,配置squid的缓存和基本的访问控制加速和限制web服务的访问。

对于Web用户来说,Squid是一个高性能的代理缓存服务器,可以加快内部网浏览Internet的速度,提高客户机的访问命中率。Squid不仅支持HTTP协议,还支持ftp、gopher、SSL和WAIS等协议。和一般的代理缓存软件不同,Squid用一个单独的、非模块化的、I/O驱动的进程来处理所有的客户端请求。 Squid将数据元缓存在内存中,同时也缓存DNS查寻的结果,除此之外,它还支持非模块化的DNS查询,对失败的请求进行消极缓存。Squid支持SSL,支持访问控制。由于使用了ICP,Squid能够实现重叠的代理阵列,从而最大限度的节约带宽。 Squid由一个主要的服务程序Squid,一个DNS查询程序dnsserver,几个重写请求和执行认证的程序,以及几个管理工具组成。当Squid启动以后,它可以派生出指定数目的dnsserver进程,而每一个dnsserver进程都可以执行单独的DNS查询,这样一来就大大减少了服务器等待DNS查询的时间。 Squid的另一个优越性在于它使用访问控制清单(ACL)和访问权限清单(ARL)。访问控制清单和访问权限清单通过阻止特定的网络连接来减少潜在的Internet非法连接,可以使用这些清单来确保内部网的主机无法访问有威胁的或不适宜的站点。 Squid对硬件的要求是内存一定要大,不应小于128M,硬盘转速越快越好,最好使用服务器专用SCSI硬盘,处理器要求不高,400MH以上既可。

二、squid代理的实现原理

1、 客户端向代理服务器squid提出访问internet的请求

2、代理服务器接受请求后,首先与访问控制列表中的访问规则相对照,如果满足规则,那就在缓存中查找是否存在需要的信息,若缓存中有所需要的信息,则直接返还给客户端,如果不存在,代理服务器就会代替客户端向互联网发出访问请求。

3、互联网上的主机会将代理服务器请求的信息回馈给代理服务器,同时,代理服务器会将获得的数据存在自己的缓存中,然后再将互联网回应的信息传给客户端。

4、其他客户端向代理服务器squid提出访问internet的相同请求时,代理服务器首先与访问控制列表中的访问规则相对照,如果满足规则,则将缓存中的数据传给客户端

简单的用个逻辑图介绍一下

(1)如果缓存中有客户端请求的数据则走1234路线;

(2)如果缓存中没有请求的数据则走125634路线。

三、Squid的编译安装

[root@server softs]# tar xf squid-3.1.14.tar.gz -C /usr/src/

[root@server softs]# cd /usr/src/squid-3.1.14/

squid相关目录和文件

[root@server squid-3.1.14]# cp /usr/local/squid/etc/squid.conf.d

ocumented /usr/local/squid/etc/squid.conf

cp: overwrite `/usr/local/squid/etc/squid.conf'? y

[root@server squid-3.1.14]# ln -s /usr/local/squid/sbin/squid /sbin/squid

[root@server squid-3.1.14]# ln -s /usr/local/squid/etc/squid.conf /etc/squid.conf

[root@server etc]# chmod -R o+w /usr/local/squid/var/logs/

[root@server etc]# chmod -R o+w /usr/local/squid/var/cache/

[root@server etc]# squid -z

/02/10 16:11:01| Creating Swap Directories

/02/10 16:11:01| /usr/local/squid/var/cache exists

/02/10 16:11:01| Making directories in /usr/local/squid/var/cache/00

/02/10 16:11:01| Making directories in /usr/local/squid/var/cache/01

/02/10 16:11:01| Making directories in /usr/local/squid/var/cache/02

/02/10 16:11:01| Making directories in /usr/local/squid/var/cache/03

/02/10 16:11:01| Making directories in /usr/local/squid/var/cache/04

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/05

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/06

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/07

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/08

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/09

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0A

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0B

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0C

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0D

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0E

/02/10 16:11:02| Making directories in /usr/local/squid/var/cache/0F

[root@server etc]#

[root@server etc]# squid -k parse

/02/10 16:12:05| Processing Configuration File: /usr/local/squid/etc/squid.conf (depth 0)

/02/10 16:12:05| Processing: acl mynet src 192.168.0.0/24

/02/10 16:12:05| Processing: http_access allow mynet

/02/10 16:12:05| Processing: http_port 3128

/02/10 16:12:05| Processing: cache_mem 256 MB

/02/10 16:12:05| Processing: acl manager proto cache_object

/02/10 16:12:05| Processing: acl localhost src 127.0.0.1/32 ::1

/02/10 16:12:05| Processing: acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1

/02/10 16:12:05| Processing: acl localnet src 10.0.0.0/8 # RFC1918 possible internal network

/02/10 16:12:05| Processing: acl localnet src 172.16.0.0/12 # RFC1918 possible internal network

/02/10 16:12:05| Processing: acl localnet src 192.168.0.0/16 # RFC1918 possible internal network

/02/10 16:12:05| Processing: acl localnet src fc00::/7 # RFC 4193 local private network range

/02/10 16:12:05| aclIpParseIpData: IPv6 has not been enabled.

/02/10 16:12:05| Processing: acl localnet src fe80::/10 # RFC 4291 link-local (directly plugged) machines

/02/10 16:12:05| aclIpParseIpData: IPv6 has not been enabled.

/02/10 16:12:05| Processing: acl SSL_ports port 443

/02/10 16:12:05| Processing: acl Safe_ports port 80# http

/02/10 16:12:05| Processing: acl Safe_ports port 21# ftp

/02/10 16:12:05| Processing: acl Safe_ports port 443 # https

/02/10 16:12:05| Processing: acl Safe_ports port 70# gopher

/02/10 16:12:05| Processing: acl Safe_ports port 210 # wais

/02/10 16:12:05| Processing: acl Safe_ports port 1025-65535 # unregistered ports

/02/10 16:12:05| Processing: acl Safe_ports port 280 # http-mgmt

/02/10 16:12:05| Processing: acl Safe_ports port 488 # gss-http

/02/10 16:12:05| Processing: acl Safe_ports port 591 # filemaker

/02/10 16:12:05| Processing: acl Safe_ports port 777 # multiling http

/02/10 16:12:05| Processing: acl CONNECT method CONNECT

/02/10 16:12:05| Processing: http_access allow manager localhost

/02/10 16:12:05| Processing: http_access deny manager

/02/10 16:12:05| Processing: http_access deny !Safe_ports

/02/10 16:12:05| Processing: http_access deny CONNECT !SSL_ports

/02/10 16:12:05| Processing: http_access allow localnet

/02/10 16:12:05| Processing: http_access allow localhost

/02/10 16:12:05| Processing: http_access deny all

/02/10 16:12:05| Processing: http_port 3128

/02/10 16:12:05| Processing: hierarchy_stoplist cgi-bin ?

/02/10 16:12:05| Processing: cache_dir ufs /usr/local/squid/var/cache 512 16 256

/02/10 16:12:05| Processing: minimum_object_size 0 KB

/02/10 16:12:05| Processing: maximum_object_size 4096 KB

/02/10 16:12:05| Processing: coredump_dir /usr/local/squid/var/cache

/02/10 16:12:05| Processing: refresh_pattern ^ftp:1440 20% 10080

/02/10 16:12:05| Processing: refresh_pattern ^gopher: 1440 0% 1440

/02/10 16:12:05| Processing: refresh_pattern -i (/cgi-bin/|\?) 0 0% 0

/02/10 16:12:05| Processing: refresh_pattern . 0 20% 4320

/02/10 16:12:05| Initializing https proxy context

[root@server etc]#

[root@server etc]# squid -s

[root@server etc]# netstat -ntlp | grep squid

tcp 0 0 0.0.0.0:3128 0.0.0.0:*LISTEN 17584/(squid)

[root@server etc]# squid -k shutdown

[root@server etc]# squid -k reconfigure

[root@server etc]# squid -s

[root@server etc]# netstat -tnlp | grep squid

tcp 0 0 192.168.1.110:31280.0.0.0:*LISTEN 17584/(squid)

客户端的设置

客户端需要配置内网的地址

客户端不需要配置dns和网关

可断浏览器需要配置代理服务器的网关和端口

浏览器访问baidu

查看一下日志

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。