OFBIZ分享:利用Nginx +Memcached架设高性能的服务
近年来利用Nginx和Memcached来提高站点的服务性能的作法,如一夜春风般的遍及大江南北,越来越多的门户站点和电子商务平台都採用它们来为自己的用户提供更好的服务体验。如:网易、淘宝、京东、凡客等无一不是如此。关于它们的优点,在此我不想再多言,假设您感兴趣,能够到网络上去搜索一下就可以轻松获得这方面的资料。我们今天的重点是和大家分享将Ofbiz与Nginx和Memcached配置在一起,在达到好的效果。
1) 所须要的软件
n Tengine:这是一个经过淘宝公司优化并开源的Nginxserver,它不仅保留了Nginx的全部长处,还增加了其他一些非常好的扩展。
n Memcached :请到官网上下载最新版本号。
n memc-nginx和srcache-nginx:这是淘宝公司的project师开发的,用于Nginx直接存取Memcached的两个扩展。请到网上下载它最新的版本号。在baidu中搜索memc-nginx和srcache-nginx就能够非常easy找到它们。
2) 软件安装
3) 原理
增加nginx和memcached后,当nginx收到用户的请求后,仅仅有动态的内容会被转发到ofbiz的tomcat进行处理,全部的静态内容都由nginx直接处理了,大大的减少了tomcatserver和后台数据库的压力。此外,由于memcached的存在,nginx会首先到memcached中提取数据,仅仅有数据不存在时才会到磁盘上读取文件或转给tomcat进行处理,并将取得的结果数据存入memcached中,这样,当下一次再请求同样的数据时,就直接从memcached中取了。不再受磁盘IO数的限制,大大的提高了效率。
由于直接由nginx对memcached进行存取,所以不须要对ofbiz的代码进行额外的改动,配置更加灵活。
4) 配置文件
以下我们来重点看一下nginx的配置文件。须要说明的是这个配置文件里,仅仅对经常使用的了部分组件进行了配置,假设没有包括您所须要的配置部分,你能够自己依照同样的思路去加入上就可以。
|
#user nobody; worker_processes 2; daemon on; #error_log logs/error.log; #error_log logs/error.log notice; error_log logs/error.log info; #error_log logs/error.log debug; #pid logs/nginx.pid; events { use epoll; worker_connections 1024; } http { include mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local]"$request" ' '$status $body_bytes_sent"$http_referer" ' '"$http_user_agent""$http_x_forwarded_for"'; upstream memcache{ server 127.0.0.1:12357; keepalive 512; } # upstream ofbiz_tomcat{ server 127.0.0.1:8080; } #ofbiz server server { listen 80; server_name _*; #charset koi8-r; access_log logs/ecshop.ofbiz.cn.log main; #处理memcached location /memc { internal;#仅仅同意本地訪问,提高了数据安全 memc_connect_timeout100ms; memc_send_timeout100ms; memc_read_timeout100ms; set$memc_key $query_string; memc_passmemcache; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,将动态的请求转请给tomcat location~* /(control|products)/ { set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $remote_addr; proxy_pass http://ofbiz_tomcat; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,将动态的请求转请给tomcat location ~* \.(jsp|jspx)$ { set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $remote_addr; proxy_pass http://ofbiz_tomcat; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location/ { set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; root <OFBIZ_HOME>/baseapps/ecommerce/webapp/ecshop; index index.html index.htm index.jsp default.jsp; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location /ordermgr/{ set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; root <OFBIZ_HOME>/baseapps/order/webapp; index index.html index.htm ; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location /partymgr/{ set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; root <OFBIZ_HOME>/baseapps/party/webapp; index index.html index.htm ; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location /catalog/ { root <OFBIZ_HOME>/baseapps/product/webapp; index index.html index.htm ; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location /images/ { set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; root <OFBIZ_HOME>/core/images/webapp; index index.html index.htm ; } #依据uri和參数,在memcached中查找,假设找到就返回给client,找不到就,到磁盘读取文件给client,并存处memcached location^~ /backend2013/ { set $key$uri$args; srcache_fetchGET /memc $key; srcache_storePUT /memc $key; root <OFBIZ_HOME>/themes/backend2013/webapp; index index.html index.htm ; } #redirect server error pages to the static page /50x.html # error_page 404 500 502 503504 /50x.html; location = /50x.html { root <OFBIZ_HOME>/core/images/webapp/errorpage; } #禁止nginx下载ftl,xml,groovy,sh等文件,由于这些文件在ofbiz中可能是我们的程序的组成部分 location ~* \.(ftl|xml|groovy|sh)$ { deny all; } #location ~* \.(gif|jpg|jpeg|png|bmp|swf)$ #{ # expires 30d; #} #location~* \.(js|css)$ #{ # expires 1h; #} }#end server } |
限制说明:
以上的配置,仅仅是一个初始的配置,还须要再进一步优化,比方,须要差别对待GET和POST方法的处理,不然可能会有数据无法正确更新问题,可是由于时间有限,不再细讲,欢迎大家一起讨论共同进步。
OFBIZ分享:利用Nginx +Memcached架设高性能的服务的更多相关文章
- Nginx+Tomcat+Session 高性能群集搭建
随着IT行业的发展,linux服务器在企业中应用广泛,人们对linux上的应用服务要求也越来越高,早先的apache服务器.apache有优点也 有不足,apache渐渐不能满足人们的要求,目前ngi ...
- 配置集群Nginx+Memcached+Tomcat集群配置
上班之余抽点时间出来写写博文,希望对新接触的朋友有帮助.今天在这里和大家一起学习一下配置集群 1. Nginx Nginx是通过将多个Web Server绑定到同一个IP地址下,以实现多个WebS ...
- 利用nginx实现负载均衡和动静分离
1.Nginx介绍 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器 . Nginx 是由 ...
- 利用Nginx+Mono+Fastcgi代替IIS对Asp.Net进行反向代理
Nginx的好处相信我不必多说了,它作为一个相当轻量级的开源Web 服务器以及反向代理服务器而深受欢迎.越来越多的公司已经对它产生兴趣,包括我们公司的许多部门,利用它进行负载均衡和资源管理,之前写过一 ...
- 【转】Nginx+Tomcat搭建高性能负载均衡集群
最近对负载均衡比较感兴趣,研究了公司的负载均衡的配置,用的是阿里的SLB,相当于不用运维,只需要在后台进行简单的配置就能完成Tomcat的负载均衡,索性在网上找了几篇文章去尝试搭建一个集群,然而很多都 ...
- Nginx+Tomcat搭建高性能负载均衡集群
一. 工具 nginx-1.8.0 apache-tomcat-6.0.33 二. 目标 实现高性能负载均衡的Tomcat集群: 三. 步骤 1.首先下载Nginx ...
- Nginx+Tomcat搭建高性能负载均衡集群(转)
转载自:http://blog.csdn.net/wang379275614/article/details/47778201 一. 工具 nginx-1.8.0 apache-tomca ...
- Nginx+Memcached+Tomcat集群配置
1. Nginx Nginx是通过将多个Web Server绑定到同一个IP地址下,以实现多个WebServer间的负载均衡,降低单个Web Server的负荷,以提高整体的性能与稳定性. 安装和 ...
- 利用 NGINX 最大化 Python 性能,第二部分:负载均衡和监控
[编者按]本文主要介绍 NGINX 的主要功能以及如何通过 Nginx 优化 Python 应用性能.本文系国内 ITOM 管理平台 OneAPM 编译呈现. 本文上一篇系: 利用 NGINX 最大化 ...
随机推荐
- json所需jar包 & js解析后台json数据
Json 所需jar包: var listxxx='<%=request.getAttribute("listxxx")%>'; // list数组 var mapx ...
- poj 1850/poj 1496
http://poj.org/problem?id=1850 -----------------http://poj.org/problem?id=1496 两题解法类似..本题为组合数学的题,要求所 ...
- MVCC 多版本并发控制
关于事务的介绍暂且不谈. InnoDB行级锁,虽然在很大程度上提高了事务的并发性,但是终究还是要耗费很大的.为了更进一步的提高并发性同时降低开销,存储引擎会同时实现MVCC. InnoDB实现MVCC ...
- MYSQL 好文章集锦
比较细致的讲解MySQL数据库的数据结构以及实现原理 MySQL索引背后的数据结构及算法原理 MySQL的InnoDB索引原理详解 MySQL索引原理及慢查询优化 持续更新,快乐学习.
- CMD获取当前目录的绝对路径
@echo offecho 当前盘符:%~d0echo 当前盘符和路径:%~dp0echo 当前批处理全路径:%~f0echo 当前盘符和路径的短文件名格式:%~sdp0echo 当前CMD默认目录: ...
- Qt见解:Post 与 Get 的区别(Get将参数直接与网址整合为一个整体,而Post则将其拆为两个部分)
第一次接触Qt的Http项目,今天看了一下Post和Get的基本使用方法,就开始尝试了.原先以为Post专门用于向服务器发送请求,然后接收服务器应答的: 而Get只是单纯从服务器获取资源,比如下载这个 ...
- 基于visual Studio2013解决C语言竞赛题之0202坐标转换
题目
- 基于visual Studio2013解决C语言竞赛题之0201温度转换
题目 解决代码及点评 #include <stdio.h> #include <stdlib.h> void main() { float f; float c; float ...
- Android 启动APP时黑屏白屏的三个解决方案(转载)
你会很奇怪,为什么有些app启动时,会出现一会儿的黑屏或者白屏才进入Activity的界面显示,但是有些app却不会如QQ手机端,的确这里要做处理一下.这里先了解一下为什么会出现这样的现象,其实很简单 ...
- iOS 请求数据 error
解决办法如下: 0x1 ->请求数据时加上缺少的类型 AFHTTPSessionManager *manager = [selfAFHTTPSessionManager];// manag ...