Centos7 squid传统代理

灰太狼 2022-01-17 12:01 356阅读 0赞

Centos7 squid传统代理

操作环境:
squid代理服务器:192.168.80.100
web网站 :192.168.80.101
windows客户端 :192.168.80.30

1、安装编译环境
yum install gcc gcc-c++ make -y

2、安装插件
yum install perl-devel -y

3、安装wget下载工具
yum install wget -y

4、下载squid
wget http://www.squid-cache.org/Versions/v3/3.5/squid-3.5.21.tar.gz
Centos7 squid传统代理
5、安装与配置squid
tar xf squid-3.5.27.tar.gz -C /opt/ --解压软件包到/opt/下
cd /opt/squid-3.5.27/ --切换到解压目录

  1. 注:
  2. ./configure \ #配置
  3. --prefix=/usr/local/squid \ #指定安装路径
  4. --sysconfdir=/etc \ #配置文件存储目录
  5. --enable-arp-acl \ #可在ACL中设置通过MAC地址进行管理,防止IP欺骗
  6. --enable-linux-netfilter \ #使用内核过滤,目的是对透明模式提供支持
  7. --enable-linux-tproxy \ #允许使用透明模式
  8. --enable-async-io=100 \ #异步I/O,用来提升存储性能。
  9. --enable-err-language="Simplify_Chinese" \ #
  10. --enable-underscore \ #允许URL中有下划线
  11. --enable-poll \ #使用Poll()模式,提升性能
  12. --enable-gnuregex #使用GNU正则表达式

make && make install --编译并且安装
Centos7 squid传统代理
ln -s /usr/local/squid/sbin/* /usr/local/sbin --软连接启动程序
Centos7 squid传统代理
useradd -M -s /sbin/nologin squid --创建一个没有家目录,且不能登录系统的用户
chown -R squid:squid /usr/local/squid/var/ --修改文件的归属
Centos7 squid传统代理
vi /etc/squid.conf --squid配置文件

  1. http_access allow all
  2. http_port 3128 //在下面新增
  3. visible_hostname 192.168.80.181 #确定公共主机名
  4. cache_mem 64 MB
  5. cache_swap_low 80
  6. cache_swap_high 97
  7. cache_dir ufs /usr/local/squid/var/cache/squid 512 16 256 //配置硬盘缓存,打开#.缓存目录512M,其中一级目录16个,二级256个
  8. cache_effective_user squid #用来设置初始化、运行时缓存的账号,否则启动不成功
  9. cache_effective_group squid #//默认为指定账号的基本组

Centos7 squid传统代理

squid -k parse //检查配置文件

squid –k rec //重新加载配置文件

squid -zX //初始化缓存目录

-——————-制作squid系统服务脚本————-
为了使Squid服务的启动、停止、重载等操作更加方便,可以编写Squid服务脚本,并使用chkconfig和service工具来进行管理。

vi /etc/init.d/squid --创建一个启动脚本

  1. #!/bin/bash
  2. #chkconfig: 35 90 25
  3. #config: /etc/squid.conf
  4. #pidfile: /usr/local/squid/var/run/squid.pid
  5. #Description: Squid - Internet Object Cache
  6. PID="/usr/local/squid/var/run/squid.pid"
  7. CONF="/etc/squid.conf"
  8. CMD="/usr/local/squid/sbin/squid"
  9. case "$1" in
  10. start)
  11. netstat -utpln | grep squid &>/dev/null
  12. if [ $? -eq 0 ]
  13. then
  14. echo "Squid is running"
  15. else
  16. $CMD
  17. fi
  18. ;;
  19. stop)
  20. $CMD -k kill &>/dev/null
  21. rm -rf $PID &>/dev/null
  22. ;;
  23. status)
  24. [ -f $PID ] &>/dev/null
  25. if [ $? -eq 0 ]
  26. then
  27. netstat -utpln | grep squid
  28. else
  29. echo "Squid is not running"
  30. fi
  31. ;;
  32. restart)
  33. $0 stop &>/dev/null
  34. echo "正在关闭Squid..."
  35. $0 start &>/dev/null
  36. echo "正在启动Squid..."
  37. ;;
  38. reload)
  39. $CMD -k reconfigure
  40. ;;
  41. check)
  42. $CMD -k parse
  43. ;;
  44. *)
  45. echo "用法:{start | stop | restart | reload | check | status}"
  46. esac

chmod +x /etc/init.d/squid --给脚本执行权限
Centos7 squid传统代理
chkconfig --add squid --将脚本添加到系统服务中

chkconfig squid on --启动squid

service firewalld stop --关闭防火墙
setenforce 0 --关闭selinux

service squid start --启动squid

netstat -anpt | grep 3128
Centos7 squid传统代理
6、搭建web网站
web网站 :192.168.80.101
1、安装apache服务
yum install httpd -y
Centos7 squid传统代理
2、切换到YUM安装的网页根目录,并创建测试文件
cd /var/www/html

  1. dd if=/dev/zero of=test1.tgz bs=1M count=11
  2. dd if=/dev/zero of=test2.tgz bs=1M count=2

systemctl start httpd --启动apache服务

7、给squid设置参数
vi /etc/squid.conf

  1. reply_body_max_size 10 MB //禁止下载的超过10MB的文件
  2. maximum_object_size 4096 KB //超过4MB的文件不进行缓存
  3. http_access deny all //前面两行需要放在这行之上才生效

Centos7 squid传统代理

8、测试:windows系统
1、给浏览器设置代理服务器地址和端口
Centos7 squid传统代理
Centos7 squid传统代理
Centos7 squid传统代理
Centos7 squid传统代理

2、在浏览器输入ip地址/test1.tgz实验效果如下
Centos7 squid传统代理
Centos7 squid传统代理
3、查看squid日志
tail /usr/local/squid/var/logs/access.log
Centos7 squid传统代理
4、查看httpd的访问日志
提示:从日志来看我们的客户端没有访问apache的记录,都是客户端访问代理服务器,代理服务器去我们的apache拿数据
Centos7 squid传统代理
5、测试缓存效果
提示:我们的缓存服务器,设置的参数是大于10M的不需要下载,大于4M的不能缓存,所以我们用一个test2.tgz的测试文件来测试
1.我们要先下载test2.tgz
Centos7 squid传统代理

提示:当我们下载完以后我们的test2.tgz应该会缓存到我们的代理服务器,当我们再去apache拿test2文件的时候我们的代理服务器应该会直接把数据返回给我们而不是在去web服务器拿数据

转载于:https://blog.51cto.com/13701082/2345526

发表评论

表情:
评论列表 (有 0 条评论,356人围观)

还没有评论,来说两句吧...

相关阅读

    相关 squid反向代理

    一.反向代理的概念   什么是反向代理呢?其实,反向代理也就是通常所说的WEB服务器加速,它是一种通过在繁忙的WEB服务器和Internet之间增加一个高速的 WE