nginx反代加缓存傻瓜教程
由于目前使用军哥的lnmp一键包的人较多,所以,本教程基于lnmp0.9!
注意添加脚本后要重启nginx
/etc/init.d/nginx restart
一、最简单的反代脚本(无缓存):
server
{
listen 80;
server_name mjj.jybb.me; #你要绑定的域名
location / {
proxy_pass http://www.baidu.com/; #你要反代的域名
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
保存为.conf文件上传到/usr/local/nginx/conf/vhost并重启nginx即可!
二、最简单的反代+全缓存脚本:
#新建2个目录,放置缓存文件:
mkdir /home/cache/path
mkdir /home/cache/temp
修改/usr/local/nginx/conf/nginx.conf的http层,添加以下代码:
client_body_buffer_size 512k;
proxy_connect_timeout 5;
proxy_read_timeout 60;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 128k;
proxy_temp_path /home/cache/temp;
proxy_cache_path /home/cache/path levels=1:2 keys_zone=cache_one:500m inactive=7d max_size=30g;
#500m是内存占用,7d是7天无访问删除,30g是缓存占具硬盘空间
#limit_zone crawler $binary_remote_addr 10m; #这段是用于限制单ip连接数的,如果频繁出现后端负载过大可以尝试去掉#
然后新建一个虚拟主机,传到/usr/local/nginx/conf/vhost/下
server
{
listen 80;
server_name mjj.jybb.me; #主机名
location / {
proxy_cache cache_one;
proxy_cache_valid 200 304 3d; #正常状态缓存时间3天,按实际情况修改
proxy_cache_key $host$uri$is_args$args;
proxy_pass http://www.baidu.com/; #反代的网站
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
expires 10d; #默认10天缓存
access_log /home/wwwlogs/mjj.log access; #日志文件,不开启日志请改为access_log off;
#limit_conn one 20;
#limit_rate 200k;
#20为单ip连接数,200k为单ip连接速度,若要开启请去掉#
}
}
重启一下nginx,访问一下网站,随便点击一下。 然后
cd /home/cache/
df -sh
#若大小有变化,则说明缓存成功
rm -rf /home/cache/path #立即清空缓存
原文:http://jybb.me/nginx-proxy-pass-and-cache
========
Nginx反向代理教程
1、安装Nginx
yum -y install gcc g++ vim libncurses5-dev make libxml2-dev yum -y install subversion yum -y install libpcre3 libpcre3-dev libcurl4-openssl-dev yum -y install pcre* zlib* openssl* wget -c http://nginx.org/download/nginx-1.0.5.tar.gz tar -zxf nginx-1.0.5.tar.gz wget -c http://wiki.nginx.org/images/5/51/Nginx-accesskey-2.0.3.tar.gz tar -zxf Nginx-accesskey-2.0.3.tar.gz svn checkout http://substitutions4nginx.googlecode.com/svn/trunk/ substitutions4nginx-read-only curdir=$(pwd) cd nginx-1.0.5 ./configure --user=nobody --group=nobody --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --pid-path=/var/run/nginx.pid --conf-path=/etc/nginx/nginx.conf --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-ipv6 --with-pcre --with-http_sub_module --add-module=$curdir/substitutions4nginx-read-only --add-module=$curdir/nginx-accesskey-2.0.3 make make install
2、配置nginx.conf
编辑/etc/nginx/nginx.conf
server{ listen 80; server_name t.playvps.com; #绑定的域名 access_log off; #off 关闭日志 location / { subs_filter 'www.baidu.com' 't.playvps.com' gi; #substitutions4nginx替换 (使用方法参照官方) proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Referer http://www.baidu.com; #强制定义Referer,程序验证判断会用到 proxy_set_header Host www.baidu.com; #定义主机头,如果目标站点绑定的域名个server_name项的吻合则使用$host proxy_pass http://www.baidu.com; #指定目标,建议使用IP或者nginx自定义池 proxy_set_header Accept-Encoding ""; #清除编码 } }
3,重启Nginx
pkill nginx #关闭进程 nginx #启动Nginx
subs_filter 注:
g(默认): 替换所有匹配的字段串。
i: 执行区分大小写的匹配。
o: 仅替换首个匹配字符串。
r: 使用正则替换模式,默认是固定模式。
擼過看看= =
http://forums.internetfreedom.org/index.php?topic=17615.0
“专业版
http://dongtaiwang.com/loc/beta/fg734pb1.exe
http://dongtaiwang.com/loc/beta/fg734pb1.zip
专家版
http://dongtaiwang.com/loc/beta/fg734xb1.exe
http://dongtaiwang.com/loc/beta/fg734xb1.zip“