本文共 2824 字,大约阅读时间需要 9 分钟。
安装编译环境
yum install gcc gcc-c++ make -y安装一个依赖件
yum install perl-devel解压squid包 没有自己下载
tar xf squid-3.5.27.tar.gz -C /opt/进入squid包并定制功能
cd /opt/squid-3.5.27/./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注:
./configure \ #配置--prefix=/usr/local/squid \ #指定安装路径--sysconfdir=/etc \ #配置文件存储目录--enable-arp-acl \ #可在ACL中设置通过MAC地址进行管理,防止IP欺骗--enable-linux-netfilter \ #使用内核过滤,目的是对透明模式提供支持--enable-linux-tproxy \ #允许使用透明模式--enable-async-io=100 \ #异步I/O,用来提升存储性能。--enable-err-language="Simplify_Chinese" \ #--enable-underscore \ #允许URL中有下划线--enable-poll \ #使用Poll()模式,提升性能--enable-gnuregex #使用GNU正则表达式编译
make && make install做一个软连接
ln -s /usr/local/squid/sbin/* /usr/local/sbin创建一个程序用户
useradd -M -s /sbin/nologin squid以递归的形似更改属组
chown -R squid:squid /usr/local/squid/var/进入配置文件
vi /etc/squid.confhttp_access allow all http_port 3128 //在下面新增visible_hostname 192.168.80.181 #确定公共主机名cache_mem 64 MBcache_swap_low 80cache_swap_high 97cache_dir ufs /usr/local/squid/var/cache/squid 512 16 256 //配置硬盘缓存,打开#.缓存目录512M,其中一级目录16个,二级256个cache_effective_user squid #用来设置初始化、运行时缓存的账号,否则启动不成功
cache_effective_group squid #//默认为指定账号的基本组squid -k parse //检查配置文件
squid –k rec //重新加载配置文件
squid -zX //初始化缓存目录
制作squid系统服务脚本为了使Squid服务的启动、停止、重载等操作更加方便,可以编写Squid服务脚本,并使用chkconfig和service工具来进行管理。
vi /etc/init.d/squid
#!/bin/bash
#chkconfig: 35 90 25#config: /etc/squid.conf#pidfile: /usr/local/squid/var/run/squid.pid#Description: Squid - Internet Object CachePID="/usr/local/squid/var/run/squid.pid"
CONF="/etc/squid.conf"CMD="/usr/local/squid/sbin/squid"case "$1" in
start)netstat -utpln | grep squid &>/dev/nullif [ $? -eq 0 ]thenecho "Squid is running"else$CMDfi;;stop)$CMD -k kill &>/dev/nullrm -rf $PID &>/dev/null;;status)[ -f $PID ] &>/dev/nullif [ $? -eq 0 ]thennetstat -utpln | grep squidelseecho "Squid is not running"fi;;restart)$0 stop &>/dev/nullecho "正在关闭Squid..."$0 start &>/dev/nullecho "正在启动Squid...";;reload)$CMD -k reconfigure;;check)$CMD -k parse;;*)echo "用法:{start | stop | restart | reload | check | status}"esacchmod +x /etc/init.d/squid 加权
chkconfig --add squid 添加到service里
service firewalld stop 或者自己设置防火钱的策略3128端口 还有
setenforce 0
service squid start 开启服务
netstat -anpt | grep 3128 查看端口有没有启动
在另一台安装一个web服务器
yum install httpd -ysystemctl restart httpd 启动httpd服务
进入网页根目录
cd /var/www/html执行一下命令
创建一个文件 dd if=/dev/zero of=test1.tgz bs=1M count=11dd if=/dev/zero of=test2.tgz bs=1M count=2在windows 下 打开网页 点击工具 再点击internet 选项
搜索 192.168.80.101/test1.tar如果80.100里有数据 那就成功了
tail /usr/local/squid/var/logs/access.log
转载于:https://blog.51cto.com/14150862/2345363