squid代理服务器-------一之正向代理、反向代理配置

2024-01-22 11:48

本文主要是介绍squid代理服务器-------一之正向代理、反向代理配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

学习squid服务可以搭配CDN技术比较着一起学习,更容易理解并且接受。原文戳这里跳转

可以看两者之间的比较:
在这里插入图片描述

1、什么是squid?

  • Squid,一个高性能的代理缓存服务器,支持FTP、gopher、HTTP协议。

  • Squid,一个缓存Internet 数据的软件,其接收用户的下载申请(作为代理服务器),并自动处理所下载的数据,并返回给客户。

  • 当一个用户想要下载一个主页(如米扑科技:https://mimvp.com)时,可以向Squid 发出一个申请,让Squid 代替其进行下载,然后Squid 连接所申请网站并请求该主页,接着把该主页传给用户同时保留一个备份,当别的用户申请同样的页面时, squid可以简单的从磁盘中读到它,那样数据会立即传输到客户机,使用户觉得速度相当快。

  • Squid 可以代理HTTP、FTP、GOPHER、SSL和WAIS等协议并且Squid 可以自动地进行处理,可以根据自己的需要设置Squid,使之过滤掉不想要的东西。

2、squid的优点

  • Squid支持缓存多种不同的网络对象,包括那些通过HTTP和FTP访问的人。
  • 缓存频繁要求的网页、媒体文件和其它,加速回答时间并减少带宽堵塞的内容。
  • 通过缓存的方式为用户提供Web访问加速,对用户的Web访问进行过滤控制

3、squid工作流程(和varnish一样)

在这里插入图片描述

4、squid主要参数说明

在这里插入图片描述

5、squid各种代理配置方法

(1)正向代理(传统代理和透明代理)
在这里插入图片描述

环境配置:

squid服务端内部网卡:172.25.254.19,仅主机模式,静态IP。 外部网卡:通过桥接模式的dhcp自动分配ip
客户端172.25.254.129(不能上网),仅主机模式,静态IP

第一步:
将服务端虚拟机添加两个网卡,一个配置成仅主机模式,一个配置成桥接模式(联通外网)
在这里插入图片描述
内网:创建一个公司网络会话,自动生成一个ifcfg-company的文件,autoconnect no默认该网络不被激活,也就是自己要执行up company命令,指向ens33文件中的IP地址和网关,网卡ens33使用的是仅主机模式,可以自己设置静态IP,也可以利用刚才的DHCP池自动分配IP。这里我自己指定IP,因为IP变动会导致yum源不稳定。

[root@server1 ~]# nmcli connection add con-name  company ifname ens33 autoconnect no type ethernet ip4 172.25.254.19/24 gw4 172.25.254.250
Connection 'company' (484335ad-8198-478a-8257-2b6623727ec0) successfully added.

外网:创建一个家庭网络会话,自动生成一个ifcfg-house的文件,不指向任何IP,外部 的DHCP自动分配IP。该IP和主机在一个网段,保证能联通外网。

[root@server1 ~]# nmcli connection add con-name  house ifname ens37 type ethernet 
Connection 'house' (ba0ddead-ad51-4a89-baad-1834be66182b) successfully added.

查看两个网络会话状态:
在这里插入图片描述
将他们运行:

[root@server1 ~]# nmcli connection up company 
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/6)
[root@server1 ~]# nmcli connection up house 
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/7)

ens33网卡的配置文件写入内容如下:

[root@server1 network-scripts]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
TYPE=Ethernet
DEFROUTE=yes
IPADDR1=172.25.254.19
PREFIX1=24
NAME=ens33
ONBOOT=YES
DNS=114.114.114.114

网络编辑器的设置方法如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
看是否联通外网:
在这里插入图片描述
第二步:
进行服务的主配置文件参数设置:

[root@server1 ~]# yum install -y squid
[root@server1 ~]# rpm -qc squid

在这里插入图片描述

[root@server1 ~]# systemctl enable --now squid

在这里插入图片描述

[root@server1 ~]# netstat -antlp |grep squid

在这里插入图片描述
当我们不进行配置文件设置的时候:

客户端测试:
首先将网络配置成仅主机模式,然后写入静态与服务端代理器同网段的IP地址,本次实验的前提就是两台虚拟机之间可以相互通信:
在这里插入图片描述

在这里插入图片描述

(1)未添加代理:
在这里插入图片描述
(2)添加代理:
在这里插入图片描述
在这里插入图片描述
依然访问不到外网。

现在进行服务端配置文件编辑:
在这里插入图片描述
我们可以查看配置文件的参数:
在这里插入图片描述

服务端重启服务
[root@server1 httpd]# systemctl restart squid

客户端:
在这里插入图片描述
我们也可以在命令行进行访问测试:

[root@server2 network-scripts]# curl -x172.25.254.19:3128 www.bai.com

在这里插入图片描述
可以成功看到百度的默认访问界面。
(2)反向代理

在这里插入图片描述
参数设置:

远程服务器172.25.254.18,提供http服务
squid代理服务器172.25.254.19 ,代理缓存转发
客户端172.24.254.129,请求数据

(1)远程服务端配置(IP=172.25.254.18):

因为使用的无图形界面版本,因此将代码写在这里吧。

yum install -y httpd    ###下载http
vim /var/www/html/index.html  
####
hello  westossystemctl restart httpd   ##重启服务
systemctl stop firewalld    ##关闭火墙

我们通过其他主机访问测试是否配置成功:
在这里插入图片描述

(2)代理服务器端配置(IP=172.25.254.19)

将端口号 “http_port 3128” 修改为 “http_port 80 accel vhost vport”,此时正向解析会被暂停,它不能与反向代理服务同时使用,然后再增加你要代理的后端真实服务器的信息。

[root@server1 squid]# vim /etc/sysconfig/squid
####
http_port 80  vhost vport60 cache_peer  172.25.254.18 parent 80 0 proxy-only   将远程主服务器的IP写入

在这里插入图片描述

[root@server1 squid]# systemctl restart squid

注意代理服务器端是没有HTTP也就是没有web内容的。
在这里插入图片描述
(3)客户端测试(IP=172.25.254.129)
在这里插入图片描述
我们也可以通过命令行测试:

在这里插入图片描述
登录成功。

总结:

正向代理:

对于用户来说:用于企业内网小型局域网中,让企业用户统一的通过squid服务访问外网资源,同时基于它的访问控制列表访问权限列表执行内容过滤与权限管理功能,达到限制用户上网内容和访问存在威胁的网站的目的。

关于访问控制列表和访问权限列表内容,我们放入下一个博客进行学习。

对于访问的服务器来说:由于公司内部所有的访问都通过squid服务器,因此也可以节省大量的上网带宽开销(有相同内容直接将缓存的转发给用户),减少网络拥塞,提高用户访问速度。

反向代理:

一般是大中型网站提供缓存服务的,他们将主服务器的一些静态资源数据存放在各代理节点处,当用户恰巧访问已经缓存的静态内容(视频、图片、文字),直接将资源转发给用户,减少主服务器的访问负载压力,提高用户的访问速度。

这篇关于squid代理服务器-------一之正向代理、反向代理配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/632859

相关文章

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

CentOS7更改默认SSH端口与配置指南

《CentOS7更改默认SSH端口与配置指南》SSH是Linux服务器远程管理的核心工具,其默认监听端口为22,由于端口22众所周知,这也使得服务器容易受到自动化扫描和暴力破解攻击,本文将系统性地介绍... 目录引言为什么要更改 SSH 默认端口?步骤详解:如何更改 Centos 7 的 SSH 默认端口1

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

SpringBoot多数据源配置完整指南

《SpringBoot多数据源配置完整指南》在复杂的企业应用中,经常需要连接多个数据库,SpringBoot提供了灵活的多数据源配置方式,以下是详细的实现方案,需要的朋友可以参考下... 目录一、基础多数据源配置1. 添加依赖2. 配置多个数据源3. 配置数据源Bean二、JPA多数据源配置1. 配置主数据

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

SpringBoot中配置Redis连接池的完整指南

《SpringBoot中配置Redis连接池的完整指南》这篇文章主要为大家详细介绍了SpringBoot中配置Redis连接池的完整指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以... 目录一、添加依赖二、配置 Redis 连接池三、测试 Redis 操作四、完整示例代码(一)pom.

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注