讲解使用squid+nginx负载均衡实现单机跑多个squid的配置
squid+nginx负载均衡实现单机跑多个squid.
如今,在大访问量的网站中,squid反向代理已经成为一种常用的缓存技术。但是,众所周知,squid本身不支持SMP,因此其原本是不支持在单台服务器同一端口(例如要反向代理web必须指定80端口)下开多个进程的。
而今多核多内存服务器已成趋势,如果单台服务器只运行一个squid反向代理跑web则显得太浪费,而根据官方意见要想运行多个squid实例,要么就指定不同的IP不同端口来实现。
而nginx是一个高性能的 HTTP 和反向代理服务器软件,运用nginx的负载均衡功能,我们就能很好的实现在同一台服务器中跑多个squid的目的,充分发挥多核大内存的作用。
具体步骤如下:
1、将N个squid安装到不同目录,并指定好多个用户以及不同的监听端口,这样便于监控时查看,例如:
squid1:/opt/squid1 监听在127.0.0.1:8081
squid2:/opt/squid2监听在127.0.0.1:8082
squid3:/opt/squid3 监听在127.0.0.1:80832、编译并安装,配置nginx
./configure
nginx配置文件nginx.conf
user www www;
worker_processes10;
worker_rlimit_nofile51200;
events{
useepoll;
worker_connections51200;
}
http{
includemime.types;
default_typeapplication/octet-stream;
log_formatmain'$remote_addr-$remote_user[$time_local]"$request"'
'$status$body_bytes_sent"$http_referer"'
'"$http_user_agent""$http_x_forwarded_for"';
#access_loglogs/access.logmain;
sendfileon;
tcp_nopushon;
tcp_nodelayon;
#keepalive_timeout0;
keepalive_timeout65;
upstreamjianglb{
server127.0.0.1:8081;
server127.0.0.1:8082;
server127.0.0.1:8083;
}
#gzipon;
server{
listen192.168.1.3:80;
server_namewww.jianglb.comjianglb.com;
access_loglogs/host.access.logmain;
location/{
proxy_passhttp://jianglb;
proxy_redirectoff;
proxy_set_headerHost$host:80;
proxy_set_headerX-Real-IP$remote_addr;
proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for;
}
}
}这里有几个配置的注意点:
- 如果需要同时代理加速多个域名,而这些域名是同时做负载均衡的话,不需要分开来指定,upstream只需要一个即可,proxy_pass那里的名称能对应起来即可;
- proxy_set_header Host $host:80;这里最好加上端口80,因为我一开始没加80,发现nginx转发的时候squid会收到www.jianglb.com:8081这样的头信息,这明显是不对的,一次加上80会比较好。