小知识:

正确的使用Squid服务程序部署代理缓存服务可以有效提升访问静态资源的效率,降低原服务器的负载。

不仅如此,还为读者们添加了对指定IP地址、网页关键词、网址与文件后缀的ACL访问限制功能的实验,真的很实用哦~

简单说就是客户端A向代理服务器提出访问Internet的请求,代理服务器接受请求之后先去缓存里看有没有它所需要的,有就给它,没有就代替客户端向Internet上的主机发送请求,同时将资源缓存到本地

还有以个更重要的优点是,可以控制客户端能够访问哪些网页,不能够访问那些网页。

首先我们在虚拟机上通过yum仓库下载安装squid服务

输入命令:yum  install squid  -y

做代理服务器最好是双网卡,所有我们在我们的虚拟机上再加一块网卡,右键虚拟机选项卡,

两块网卡都设置成桥接模式

回到我们虚拟机我们看一下,发现已经有了两块网卡

设置一下第二块网卡的ip,我们那这个网卡模拟公网的ip,记得重启一下网卡

现在我们可以看到我们虚拟机已经有了两块网卡(在我虚拟机中ens33为内部局域网网关,ens36网卡为外部公网网关)

接下来我们来到第二台虚拟机下载一下httpd服务,之后再重启一下这个服务

我们在这个主页写一点信息 首先进入/var/www/html下

输入命令:echo"wo shi longshisan">index.html

已经可以看到我们写好主页了

我们接下来把第二台虚拟机的ip改成公网ip(记得重启一下网卡)

我们那我们的第一台虚拟机ping一下我们刚才配的第二台虚拟机

打开刚才我们在另外一台计算机上的网页也是可以的(记得在服务器上将防火墙关闭)

我们这个时候打开第三台虚拟机,使第三台虚拟机的ip和我们第一台也就是作为代理服务器的虚拟机中的非公网网段的IP一致

之后我们打开cmd命令行下,ping一下200.200.200.200这个公网IP是否可以ping通(当然啦不在一个网段肯定是ping不通,我们最后要做的是通过服务器转发使他可以ping通)

接下来我们来修改一下squid服务的配置文件,对应位置添加这样一行,把下一行注释掉

输入命令: vi  /etc/squid/squid.conf

手动添加信息 (记得保存)

重启一下服务(可以设置开机启动)

接下来我们打开我们win2003虚拟机上的火狐浏览器(没有的话下载一个 ,没有必要必须是win2003虚拟机,win虚拟机都可以)

接下来打开火狐点击右上角,选择选项

进去之后选择高级,点击网络中的设置

我们使用代理模式,输入我们的代理ip(3128端口是我们在服务器上写的想改,可以把前面我们设置的改一下)

这个时候你在输入网址框输入http://200.200.200.200就可以访问我们在·第二台虚拟机上多建立的那个网页啦,即使不在一个网段、

在我们的服务器上我们可以看到谁访问了我们的使用了我们的代理

输入命令:cat /var/log/squid/access.log

透明传输

透明传输的意思就是你不需要在火狐浏览器里选择使用代理模式一样可以访问我们200的那个网页

在上面的基础上我们将火狐浏览器设置成不使用代理

每次实验前我们清空一下缓存,否则可能会影响实验效果

 透明正向代理

我们在win2008虚拟机上设置网关为我们的squid服务器

首先打开我们的配置文件(在服务器上)改成这样

输入命令:vi  /etc/squid/squid.conf

改完之后我们来重启一下服务

我们再重载一下服务

输入命令:service squid reload

接下来我们修改防火墙重定向策略,来自192.168.22.0的网络重定向到3128端口 一个是80端口的一个是443的

输入命令:iptables -t nat -I PREROUTING -i ens33 -s 192.168.22.0/24 -p tcp --dport 80 -j REDIRECT --to 3128

输入命令:iptables -t nat -I PREROUTING -i ens33 -s 192.168.22.0/24 -p tcp --dport 443 -j REDIRECT --to 3128

之后添加防火墙策略并应用允许3128端口通过 然后重启squid

输入命令:iptables -I INPUT -p tcp --dport 3218 -j ACCEPT

我们可以用检查错误的命令检查一下,检查我们的配置文件有没有错误(我的没有错误)

输入命令:squid -k parse

打开我们的火狐浏览器看看我们的网页吧 输入200.200.200.200

 透明反向代理

编辑Squid服务程序的配置文件(正向代理与反向代理不能同时使用,请还原您前面修改过的参数)

输入命令:vi  /etc/squid/squid.conf

//第59行,修改格式为:http_port Squid服务器地址:监听端口号 vhost

//第60行,添加格式为:cache_peer 原网站服务器地址 parent 服务器端口号 0 originserver

重启服务就可以了

访问网站 输入192.168.22.100

ACL是Access Control List(访问控制列表)

 

输入命令:vi  /etc/squid/squid.conf      打开配置文件,我们可以看到ACL访问控制列表

Saquid服务的ACL访问控制是非常有用的功能,可以根据特定条件来进行数据缓存或限制用户的访问,ACL元素的定义语法为:

acl aclname acltype string

acl aclname acltype "file"

src定义来源地址(即用户的客户机IP地址):

  acl aclname src ip-address/netmask

  acl aclname src addr1-addr2/netmask

dst定义目标地址(即用户请求的网站IP地址):

  acl aclname dst ip-address/netmask

port用于指定访问端口:

  acl aclname port 80 1024

  acl aclname port 0-1024

url_regex用于限制网址中的关键词:

  acl aclname url_regex [-i] pattern

proto用于定义要代理的协议:

  acl aclname proto HTTP FTP

method用于指定请求的方法:

  acl aclname method GET POST

访问控制列表由多个规则条目组成的,根据指定的条件来允许或限制访问请求,匹配顺序会由上至下,一旦匹配则立即结束,通常会在控制列表的最下面写上“deny all”或者“allow all”来避免安全隐患。

例子:
仅允许192.168.10.20的主机使用本地Squid服务,拒绝其余主机:

acl client src 192.168.10.20

http_access allow client

http_access deny all

拒绝客户机使用代理服务器访问带有关键词“longshisan”的网站:

acl deny_keyword url_regex -i longshisan

http_access deny deny_keyword

拒绝客户机使用代理服务器访问百度网站:

acl deny_url url_regex http://www.baidu.com

http_access deny deny_url

禁止客户机使用代理服务器下载以mp3与rar为后缀的文件:

acl badfile urlpath_regex -i \.mp3$ \.rar$

http_access deny badfile

虚拟机中Linux环境下使用Squid部署代理缓存服务(及透明传输)的更多相关文章

  1. Linux基础学习-使用Squid部署代理缓存服务

    使用Squid部署代理缓存服务 Squid是Linux系统中最为流行的一款高性能代理服务软件,通常作为Web网站的前置缓存服务,能够代替用户向网站服务器请求页面数据并进行缓存.Squid服务配置简单. ...

  2. 《Linux就该这么学》培训笔记_ch16_使用Squid部署代理缓存服务

    <Linux就该这么学>培训笔记_ch16_使用Squid部署代理缓存服务 文章最后会post上书本的笔记照片. 文章主要内容: 代理缓存服务 配置Squid服务程序 正向代理 标准正向代 ...

  3. 第16章 使用Squid部署代理缓存服务

    章节概述: 本章节从代理缓存服务的工作原理开始讲起,让读者能够清晰理解正向代理(普通模式.透明模式)与反向代理的作用. 正确的使用Squid服务程序部署代理缓存服务可以有效提升访问静态资源的效率,降低 ...

  4. 使用Squid部署代理缓存服务(标准正向、透明正反向代理)

    正向代理让用户可以通过Squid服务程序获取网站页面等数据,具体工作形式又分为标准代理模式与透明代理模式.标准正向代理模式: 将网站的数据缓存在服务器本地,提高数据资源被再次访问时的效率,但用户必需在 ...

  5. 全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

    <ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入D ...

  6. 全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

    安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装 ...

  7. linux环境下的Oracle部署

    一.  环境及相关软件 虚拟机:VMwore Workstation Linux系统:CentOS ORACLE:ORACLE_112030_Linux-x86-64 Xmanger软件 二.  安装 ...

  8. 在Linux环境下使用Apache部署ASP.NET Core

    在前几篇文章中我们一起探讨了如何在Linux环境中安装ASP.NET Core运行时环境及将ASP.NET Core项目部署在Jexus中,这篇文章中我们将探讨如何将ASP.NET Core部署于Ap ...

  9. 在Linux环境下使用Jexus部署ASP.NET Core

    关于如何在Linux中添加ASP.NET Core运行时环境请参考我的上一篇文章,本文章将不再做赘述. 本文章运行环境如下:  (1) 安装独立版Jexus 本教程安装的是独立版的Jexus,独立版的 ...

随机推荐

  1. github上项目的目录结构说明

    build 构建脚本 dist 编译出来的发布版 docs 文档 examples 示例文件 src 源码 test 测试脚本 .babelrc Babel 交叉编译的配置 .eslintrc ESL ...

  2. OpenStack RPC框架解析

    1  消息队列Rabbitmq介绍 Rabbitmq的整体架构图 (1)Rabbitmq Server:中间那部分就是Rabbitmq Server,也叫broken server,主要是负责消息的传 ...

  3. setitimer()函数

    定时器时间函数 struct itimerval: struct itimerval *new_value,其定义如下: struct itimerval { struct timeval it_in ...

  4. php 每隔30s在页面显示字符串

    例子 // 30秒执行一次 ignore_user_abort(); //即使Client断开(如关掉浏览器),PHP脚本也可以继续执行. set_time_limit(); // 执行时间为无限制, ...

  5. JetBrains CLion 2019 for Mac(智能C和C++编辑器)中英文如何切换完整教程

    右键显示包内容,进入目录,contents/lib,删除resources_zh.jar,重启即可. 参考: https://blog.csdn.net/qq_45179462/article/det ...

  6. Spring Boot AOP 简易操作日志管理

    AOP (Aspect Oriented Programming) 面向切面编程. 业务有核心业务和边缘业务. 比如用户管理,菜单管理,权限管理,这些都属于核心业务. 比如日志管理,操作记录管理,这些 ...

  7. SelectKBest

    https://www.e-learn.cn/content/python/2198918from sklearn.feature_selection import SelectKBest,f_cla ...

  8. Java从指定URL下载文件并保存到指定目录

    1.基本流程 当我们想要下载网站上的某个资源时,我们会获取一个url,它是服务器定位资源的一个描述,下载的过程有如下几步: (1)客户端发起一个url请求,获取连接对象. (2)服务器解析url,并且 ...

  9. Java_jdbc 基础笔记之二 数据库连接

    /** * DriverManager 类是驱动程序管理器类 * 1)可以通过重载的getConnection()方法获取数据库的连接,较为方便 * 2)可以同时管理多个驱动程序:若注册了多个数据库连 ...

  10. 前端性能测试工具 : dynaTrace Ajax (还没写完)

    今天开始写这个工具, #什么是dynaTrace Ajax? 随着 jQuery.Dojo.YUI 等框架的兴起让构建 Web2.0 应用更加容易,但随之带来的定位等应用问题也越来越难,尤其是与性能相 ...