大型网站架构与自动化运维——Squid缓存服务器

                                                       Squid缓存服务器

一、网络架构图

二、Squid服务基础
1、缓存代理概述
(1)代理的工作机制
        当客户机通过代理来请求的时候,指定待服务器会先查询自己缓存,如果缓存有,则直接将缓存内容发送给客户机。否则由代理服务器向internet发送请求,并将返回信息缓存并发送给客户机
(2)代理的基本类型
        ①传统代理:需要在客户机程序中手动设置代理服务器地址和端口,才能使用代理服务器来访问网络
        ②透明代理:通过默认路由、防火墙策略将web访问重定向。
2、安装及运行控制
(1)编译安装
./configure --prefix=/usr/local/squid --sysconfdir=/etc --enable-arp-acl --enable-linux-netfilter --enable-linux-tproxy --enable-async-io=100 --enable-err-language="Simplify_Chinese" --enable-underscore --enable-poll --enable-gnuregex
        ①选项含义:
        --prefix:目录
        --sysconfdir:配置文件位置
        --enable-arp-acl:通过客户端MAC进行管理,放置IP欺诈
        --enable-linux-netfilter:使用内核过滤
        --enable-linux-tproxy:支持透明模式
        --enable-async-io:异步IO,提升存储性能
        --enable-err-language:错误信息语言
        --enable-underscore:允许URL中有下划线
        --enable-poll:使用poll()模式,提升性能
        --enable-gnuregex:使用GUN正则表达式
        ②创建连接文件、用户
        ln -s /user/local/squid/sbin/* /usr/Local/sbin/
        useradd -M -s /sbin/nologin squid
        chown -R squid:squid /usr/local/squid/var/
(2)配置文件:squid.conf
http_port 3128:监听端口
cache_effective_user squid:指定账号
cache_effective_group squid:指定组
(3)运行控制
        ①检查配置文件语法
        squid -k parse
        ②启动、停止
        squid -z 启动前需要先初始化
        squid 启动
        squid -k kill 停止
        rm -rf /usr/local/squid/var/run/squid.pid 删除PID文件
        ③问题
        centos7版本出现只监听IPV6时,修改3128为0.0.0.0:3128

三、构建代理服务器
1、传统代理
(1)squid服务器配置
        ①修改配置文件
        repliy_body_max_size 10MB:允许下载的最大文件大小
        http_access allow all:放在http_access deny all之前

2、透明代理
(1)配置squid支持透明代理
http_port 192.168.11.101:3128 transparent
(2)设置iptables策略
iptables -t nat -I PREROUTING -i eth1 -s 192.168.1.0/24 -p tcp --dport 80 -j REDIRECT --to 3128
iptables -t nat -I PREROUTING -i eth1 -s 192.168.1.0/24 -p tcp --dport 443 -j REDIRECT --to 3128
iptables -I INPUT -p tcp --dport 3128 -j ACCEPT

2、ACL访问控制
    在配置文件中,ACL访问控制通过两个步骤实现:其一,使用acl配置项定义需要控制的条件;其二,通过http_access配置项对已定义的列表做允许或拒绝控制
(1)定义访问控制列表:acl 列表名称 列表类型 列表内容

(2)设置访问权限
        ①httpd_access allow/deny 列表名
        ②取反可以在列表前加“!”
        ③没有设置任何规则时将拒绝客户端请求
        ④有规则时,没有匹配到,则执行最后一条规则
        ⑤deny MYLAN MEDIAFILE:禁止下载mp3、mp4等文件
                deny MYLAN IPBLOCK:禁止访问黑名单IP
                deny MYLAN DMBLCK:禁止访问黑名单网址
                deny MYLAN MC20:并发链接超过20则禁止
                deny allow MYLAN WORKTIME:允许工作时间上网
                deny all:禁止所有客户端使用代理


四、squid反向代理配置
1、修改配置文件
    http_port 192.168.11.10:80 vhost vport
    cache_peer  192.168.11.11 parent 80 0  www.abc.com
2、重启squid
 

五、varnish与nginx缓存服务器
1、varnish
(1)优点
具有更高的稳定性、更快的访问速度、更多的并发链接支持数,可以通过管理端口来管理缓存
(2)缺点
在高并发状态下,消耗更多的CPU/IP和内存资源
进程一旦挂起、崩溃或重启,缓存的数据会从内存中释放,此时所有的请求都会转发到后端服务器上

2、nginx
(1)缓存功能十分稳定、运行速度不逊于squid
(2)对多核CPU的利用率比其他开源软件要好
(3)支持高并发请求,能同时承受更多访问请求
六、varnish
1、varnish概述
(1)Varnish是一款高性能的开源HTTP加速器,其主要用来做为反向代理中的缓存服务器使用。
        Varnish 的作者Poul-Henning Kamp是FreeBSD的内核开发者之一,他认为现在的计算机比起1975年已经复杂许多。在1975年时,储存媒介只有两种:内存与硬盘。但现在计算机系统的内存除了主存外,还包括了cpu内的L1、L2,甚至有L3快取。硬盘上也有自己的快取装置,因此squid cache自行处理物件替换的架构不可能得知这些情况而做到最佳化,但操作系统可以得知这些情况,所以这部份的工作应该交给操作系统处理,这就是 Varnish cache设计架构。
varnish的设计架构就是利用操作系统的缓存机制处理访问
(2)Varnish主要运行两个进程:Management进程和Child进程(也叫Cache进程)
        ①Child进程包含多种类型的线程,常见的如:
        Acceptor线程:接收新的连接请求并响应;
        Worker线程:child进程会为每个会话启动一个worker线程,因此,在高并发的场景中可能会出现数百个worker线程甚至更多;
        Expiry线程:从缓存中清理过期内容;
(3)Varnish Configuration Language (VCL)是varnish配置缓存策略的工具
        使用VCL编写的缓存策略通常保存至.vcl文件中

2、部署
(1)安装支持软件
yum -y install libtool ncurses-devel pcre-devel libxslt groff pkgconfig libedit-devel libedit python-docutils python-imaging gcc gcc-c++ tar
(2)编译安装varnish
./configure --prefix=/usr/local/varnish --enable-debugging-symbols
make && make install
ln -s /usr/local/varnish/sbin/varnishd /usr/sbin/
ln -s /usr/local/varnish/bin/* /usr/local/bin/
(3)添加配置文件
cp /usr/local/varnish/share/doc/varnish/example.vcl /usr/local/varnish/default.vcl
(4)修改配置文件
vim /usr/local/varnish/default.vcl

backend web1 {
        .host = "192.168.11.101";
        .port = "80";
        .probe = {  #开启健康检查
                .url = "/";  #请求的URL路径
                .interval = 5s;  #查询间隔时间
                .timeout = 1s;  #超时时间
                .window = 5; #varnish保持的结果滑动窗口,该滑动窗口是一种流量控制方法,允许发送方在停止并等待确认前可以连续发送多个分组。由于发送方不必每发送一个分组就停下来等待确认,所有此协议可以加速数据传输
                .threshold = 3; #上次检查.window数量的多少,才代表后端是健康的
        }
}

backend web2 {
        .host = "192.168.11.102";
        .port = "80";
        .probe = {
                .url = "/";
                .interval = 5s;
                .timeout = 1s;
                .window = 5;
                .threshold = 3;
        }
}

sub vcl_init {
     new bar = directors.round_robin(); #定义调度算法:random/dns
     bar.add_backend(web1);
     bar.add_backend(web2);
}
sub vcl_recv {
    set req.backend_hint = bar.backend();  #把流量转发给directors
    return(pass);  #设置不进行缓存
}

(5)启动与停止
varnishd -f /usr/local/varnish/default.vcl -a 192.168.11.21:8080
pkill varnish

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编 者 的 话 5 第1篇 基础篇 6 第1章 数据库原理与访问 7 1.1 数据库基本原理 7 1.1.1 概述 7 1.1.2 桌面数据库 7 1.1.3 对象数据库 8 1.1.4 关系数据库服务器 9 1.1.5 选择适用的数据库 9 1.2 数据库访问技术 10 1.2.1 概述 10 1.2.2 ODBC API 10 1.2.3 ODBC的MFC类 11 1.2.4 DAO与RDO 11 1.2.5 OLE DB与ADO 12 1.3 数据库操纵语言SQL 13 1.3.1 SQL命令 13 1.3.2 SQL从句 13 1.3.3 SQL运算符 14 1.3.4 SQL合计函数 14 1.4 小 结 14 第2章 COM与数据库访问 15 2.1 COM的基本原理 15 2.1.1 COM历史 16 2.1.2 COM结构 16 2.1.3 COM优势 17 2.1.4 COM接口 18 2.1.5 COM与数据库访问 19 2.1.6 COM与Internet 19 2.2 ACTIVEX的数据库访问 19 2.2.1 ActiveX简介 19 2.2.2 ActiveX对数据库访问的支持 20 2.3 ATL的数据库访问 20 2.3.1 ATL目标 20 2.3.2 ATL内容简介 22 2.3.3 ATL对数据库访问的支持 22 2.4 小 结 23 第3章 数据库开发过程 23 3.1 阶段1:调查与分析 24 3.2 阶段2:数据建模 24 3.3 阶段3:功能设计 24 3.4 阶段4:选择数据库系统 25 3.5 阶段5:选择数据库访问技术 25 3.6 阶段6:代码设计 25 3.7 阶段7:测试与调试 26 3.8 阶段8:发行产品 26 第4章 VC++数据库开发基础 26 4.1 VC++ 6.0工程创建向导 26 4.2 VC++ 6.0数据库新建工具 27 4.3 VC++ 6.0的数据库工程 29 4.4 小 结 31 第2篇 实例篇 32 第5章 ODBC API编程 33 5.1 了解ODBC API 34 5.2 ODBC API编程步骤 34 5.2.1 步骤1:连接数据源 34 5.2.2 步骤2:分配语句句柄 36 5.2.3 步骤3:准备并执行SQL语句 36 5.2.4 步骤4:获取结果集 37 5.2.5 步骤5:提交事务 38 5.2.6 步骤6:断开数据源连接并释放环境句柄 39 5.3 ODBC API编程实例 39 5.3.1 实例概述 39 5.3.2 实例实现过程 40 5.3.3 编译并运行ODBCDemo1工程 97 5.3.4 ODBCDemo1实例小结 98 5.4 本 章 小 结 99 第6章 MFC ODBC编程 100 6.1 了解MFC ODBC 100 6.1.1 CDatabase类 100 6.1.2 CRecordSet类 100 6.2 MFC ODBC数据库访问技术 101 6.2.1 记录查询 101 6.2.2 记录添加 102 6.2.3 记录删除 102 6.2.4 记录修改 102 6.2.5 撤销数据库更新操作 103 6.2.6 直接执行SQL语句 103 6.2.7 MFC ODBC的数据库操作过程 103 6.3 MFC ODBC编程实例 104 6.3.1 实例概述 104 6.3.2 实例实现过程 105 6.3.3 编译并运行ODBCDemo2工程 132 6.3.4 ODBCDemo2实例小结 137 6.4 本 章 小 结 137 第7章 DAO数据库编程 138 7.1 DAO的数据访问 138 7.1.1 DAO对象 138 7.1.2 MFC对DAO的支持 139 7.1.3 DAO与ODBC的比较 139 7.1.4 MFC的DAO类简介 139 7.2 DAO编程实例 142 7.2.1 实例概述 142 7.2.2 实例实现过程 143 7.2.3 运行DAODemo工程 167 7.2.4 DAODemo实例小结 171 7.3 小 结 172 第8章 OLE DB客户数据库编程 172 8.1 OLE DB原理 172 8.1.1 OLE DB与ODBC 172 8.1.2 OLE DB的结构 173 8.1.3 OLE DB的优越性 173 8.1.4 OLE DB对象 174 8.1.5 OLE DB客户模板结构 177 8.1.6 OLE DB客户模
Squid 代理服务器是一款功能强大的 Web 缓存服务器,可以在内部网络和外部网络之间充当中间代理服务器,提高用户访问 Web 资源的速度和性能。以下是 Squid 代理服务器的配置与管理实验小结: 1. 安装 Squid 代理服务器:在 Linux 操作系统中,可以使用 yum 命令或 apt-get 命令安装 Squid 代理服务器。 2. 配置 Squid.conf 文件:Squid 的主要配置文件是 squid.conf,可以通过修改该文件来配置 Squid 代理服务器的各种参数,如监听端口、缓存大小、缓存存储路径、访问控制等。 3. 启动和停止 Squid 代理服务器:可以使用 systemctl 命令或 service 命令来启动和停止 Squid 代理服务器。 4. 监控和管理 Squid 代理服务器:可以使用 Squid 的日志文件来监控和管理 Squid 代理服务器的运行状态,如访问日志、错误日志、缓存日志等。 5. 配置 Squid 代理服务器的 ACL(访问控制列表):ACL 可以根据 IP 地址、域名、URL、时间等条件来限制用户的访问权限,从而提高网络安全性。 6. 配置 Squid 代理服务器缓存:可以通过设置缓存大小、缓存淘汰策略、缓存存储路径等参数来优化 Squid 代理服务器缓存效果。 总之,Squid 代理服务器是一款非常实用的网络工具,可以提高用户的访问速度和性能,同时还能提高网络安全性。熟练掌握 Squid 代理服务器的配置与管理技巧,对于网络管理人员来说将是非常有用的技能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值