nginx反向代理、缓存及压缩配置实战
一、反向代理配置 (原文链接:http://www.studyshare.cn/blog/details/1155/0 )
准备:两个项目分别使用端口8080,8081,只有一个备案域名,配置如下
server {
listen 80; //端口配置
server_name www.study.cn; #配置域名
#charset koi8-r;
#access_log logs/host.access.log main;
location / { #location路由,当浏览器访问:http://www.study.cn或者http://www.study.cn/会被nginx匹配到该location下,匹配后将域名替换为localhost:8080
proxy_pass http://localhost:8080;
}
location /blog { #location路由,当浏览器访问:http://www.study.cn/blog时,会被nginx匹配到该location,并将域名替换问localhost:8081
proxy_pass http://localhost:8081;
proxy_set_header X-Real-IP $remote_addr; #设置获取浏览器访问的网络ip
}
}
java开发工具下载地址及安装教程大全,点这里。
更多技术文章,在这里。
二、缓存配置
1、配置http{}
http {
.....#略
#缓存配置
proxy_connect_timeout 10;
proxy_read_timeout 180;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 96k;
proxy_temp_file_write_size 96k;
proxy_temp_path /tmp/temp_dir;
proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache_one:100m inactive=1d max_size=10g;
#缓存配置
...#略
}
配置参数详解:
proxy_connect_timeout:服务器连接的超时时间
proxy_read_timeout:连接成功后,等候后端服务器响应时间
proxy_send_timeout:后端服务器数据回传时间
proxy_buffer_size:缓冲区的大小
proxy_buffers:每个连接设置缓冲区的数量和每块缓冲区的大小
proxy_busy_buffers_size:开启缓冲响应的功能以后,在没有读到全部响应的情况下,写缓冲到达一定大小时,nginx一定会向客户端发送响应,直到缓冲小于此值。proxy_temp_file_write_size:设置nginx每次写数据到临时文件的大小限制
proxy_temp_path:从后端服务器接收的临时文件的存放路径
proxy_cache_path:设置缓存的路径和其他参数。被缓存的数据如果在inactive参数(当前为1天)指定的时间内未被访问,就会被从缓存中移除
2、配置server{}
server{
location ~ /blog/.*\.(css|js|png|gif|jpg) {
proxy_pass http://localhost:8081;
proxy_redirect off;
proxy_set_header Host $host;
proxy_cache cache_one;
proxy_cache_valid 200 302 24h;
proxy_cache_valid 301 30d;
proxy_cache_valid any 5m;
expires 30d;
add_header daren "hi!cached!speed is fast.";
}
}
配置参数详解:
location ~ /blog/.*\.(css|js|png|gif|jpg) : 使用正则表达式匹配路由,此处/blog/是当前本地前端项目配置了/blog路由才能访问,所以静态资源文件也就在/blog/下,如果网站前端直接打开www.study.cn就能访问,则将/blog/去掉,直接配置:location ~ .*\.(css|js|png|gif|jpg) 即可
proxy_pass http://localhost:8081; nginx缓存里拿不到资源,就向该地址转发请求,并获取资源,然后进行缓存
proxy_redirect off; 设置后端服务器“Location”响应头和“Refresh”响应头的替换文本
proxy_set_header Host $host; 允许重新定义或者添加发往后端服务器的请求头
proxy_cache cache_one; 指定用于页面缓存的共享内存,对应http层设置的keys_zone
proxy_cache_valid 200 302 24h; 为不同的响应状态码设置不同的缓存时间
proxy_cache_valid 301 30d;
proxy_cache_valid any 5m;
expires 30d; 缓存在浏览中的时间,30d:30天,30m:30分钟
重启nginx生效后,看看效果:
(1)缓存配置生效前:

(2)缓存配置生效后:

三、压缩配置
在server{}中配置如下:
server{
location ~ /(.*)\.(html|js|css|jpg|jpeg|png|gif)$ {
gzip on; # 启用gzip压缩,默认是off,不启用
# 对js、css、jpg、png、gif格式的文件启用gzip压缩功能
gzip_types application/javascript text/css image/jpeg image/png image/gif;
gzip_min_length 1024; # 所压缩文件的最小值,小于这个的不会压缩
gzip_buffers 4 1k; # 设置压缩响应的缓冲块的大小和个数,默认是内存一个页的大小
gzip_comp_level 1; # 压缩水平,默认1。取值范围1-9,取值越大压缩比率越大,但越耗cpu时间
root html/gzip;
}
}
原创文章,转载请注明出处
java开发工具下载地址及安装教程大全,点这里。
更多技术文章,在这里。
nginx反向代理、缓存及压缩配置实战的更多相关文章
- nginx 反向代理实现负载均衡*配置实战
重要点: 1配置反向代理多虚拟主机节点服务器 2经过反向代理后的节点服务器记录用户IP 3与反向代理配置相关的更多参数说明 4根据URL目录地址转发 (1)根据URL中的目录地址实现代理转发(动静分离 ...
- nginx反向代理+缓存开启+url重写+负载均衡(带健康探测)的部署记录
在日常运维工作中,运维人员会时常使用到nginx的反向代理,负载均衡以及缓存等功能来优化web服务性能. 废话不多说,下面对测试环境下的nginx反向代理+缓存开启+url重写+负载均衡(带健康探测) ...
- nginx 反向代理及 https 证书配置
nginx 反向代理及 https 证书配置 author: yunqimg(ccxtcxx0) 1. 编译安装nginx 从官网下载 nginx源码, 并编译安装. ./configure --pr ...
- Nginx反向代理实现负载均衡配置图解
Nginx反向代理实现负载均衡配置图解 [导读] 负载均衡配置是超大型机器需要考虑的一些问题,同时也是数据安全的一种做法,下面我来介绍在nginx中反向代理 负载均衡配置图解,大家可参考本文章来操作. ...
- nginx反向代理缓存配置
关于nginx的反向代理缓存配置,用的最多的就是CDN公司,目前CDN公司用纯nginx做缓存的已经很少了,基本都用tnginx(阿里的).openresty:但是这两款软件都是基于nignx开发的, ...
- Nginx反向代理以及负载均衡配置
项目地址:http://git.oschina.net/miki-long/nginx 前提:最近在研究nginx的用法,在windows上小试了一下,由于windows下不支持nginx缓存配置,所 ...
- nginx反向代理缓存服务器的构建
一:代理服务可简单的分为正向代理和反向代理: 正向代理:用于代理内部网络对Internet的连接请求(如VPN/NAT),客户端指定代理服务器,并将本来要直接发送给目标Web服务器的HTTP请求先发送 ...
- nginx反向代理跨域基本配置与常见误区
最近公司前后端分离,前端独立提供页面和静态服务很自然的就想到了用nginx去做静态服务器.同时由于跨域了,就想利用nginx的反向代理去处理一下跨域,但是在解决问题的同时,发现网上有些方案的确是存在一 ...
- nginx反向代理负载均衡初次配置
反向代理,我个人理解是通过一台反向代理服务器,把客户端的把有请求按照一定的规则分发给后台的服务器.nginx作反向代理服务器的虚拟机配置如下: upstream itest { #正常情况下应该作如下 ...
随机推荐
- 经典算法(一) top k
问题:1亿数据中,找出最大的k个数,要求使用内存不超过1m (延伸问题:1亿数据中,找出重复出现次数最多的k个,要求使用内存不超过1m 等) 分析: 1亿数字(int)占内存:100000000 * ...
- CT窗宽位宽
先说一下CT值是什么 CT图像反映的是人体对X射线吸收的系数,但我们关心的是各组织结构的密度差异,即相对密度,如果某组织发生病变,其密度就会发生变化,但由于比较吸收系数非常繁琐,于是亨氏把组织器官对X ...
- Git Bash设置代理
从GitHub clone代码速度比较慢,设置代理,(假设端口是1080): git config --global https.proxy http://127.0.0.1:1080 git con ...
- Unity制作棋牌手游之斗地主
目录 大小7.2GB,MP4格式 扫码时备注或说明中留下邮箱 付款后如未回复请至https://shop135452397.taobao.com/ 联系店主
- 阿里巴巴Druid数据源组件
目前常用的数据源主要有c3p0.dbcp.proxool.druid,先来说说他们Spring 推荐使用dbcp:Hibernate 推荐使用c3p0和proxool1. DBCP:apacheDBC ...
- APISIX系列 | 使用 docker-apisix 安装APISIX服务
官方仓库:https://github.com/iresty/docker-apisix 官方仓库 拉取 git clone git@github.com:iresty/docker-apisix.g ...
- zookeeper生产最广泛使用java客户端curator介绍及其它客户端比较
关于zookeeper的原理解析,可以参见zookeeper核心原理详解,本文所述大多数实践基于对zookeeper原理的首先理解. Curator是Netflix公司开源的一个Zookeeper客户 ...
- 福昕PDF高级企业版编辑器9.5 Foxit PhantomPDF Business安装破解教程
title: "福昕PDF高级企业版编辑器9.5 Foxit PhantomPDF Business安装破解教程" categories: soft tags: soft auth ...
- NVM 安装注意
windows 系统下尽量使用安装版本,选择安装路径时,路径中不能带有空格,否则无法使用 nvm use xx.xx.xx
- IntelliJ IDEA Error:(24, 35) java: 常量字符串过长
在转换一个JSON转Java对象是 idea 编译不通过 提示:Error:(24, 35) java: 常量字符串过长 File -> Settings -> Build,Execut ...