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方法的处理,不然可能会有数据无法正确更新问题,可是由于时间有限,不再细讲,欢迎大家一起讨论共同进步。

Gorun8电子商城是基于著名的开源项目OFBIZ的,并结合了中国人的使用习惯和审美观点而打造的一款适合中国人用的OFBIZ类电子商务系统。将gorun8打造成稳健、易用、高效电子商务平台。让广大企业用户能够利用gorun8以最低的成本,最快的速度开启电子商务营销之门

时间: 2024-10-13 01:46:44

OFBIZ分享:利用Nginx +Memcached架设高性能的服务的相关文章

利用Nginx+Mono+Fastcgi代替IIS对Asp.Net进行反向代理

Nginx的好处相信我不必多说了,它作为一个相当轻量级的开源Web 服务器以及反向代理服务器而深受欢迎.越来越多的公司已经对它产生兴趣,包括我们公司的许多部门,利用它进行负载均衡和资源管理,之前写过一篇关于利用Nginx进行负载均衡的文章(http://www.cnblogs.com/liping13599168/archive/2011/04/15/2017369.html). 本篇文章介绍怎样通过Nginx进行反向代理,并运行asp.net网站,测试环境我使用的是Win7系统. 首先,需要下

Nginx+Memcached+Tomcat集群配置

1.   Nginx Nginx是通过将多个Web Server绑定到同一个IP地址下,以实现多个WebServer间的负载均衡,降低单个Web Server的负荷,以提高整体的性能与稳定性. 安装和配置Nginx的简单方式如下: 1)      下载并解压Nginx到本地目录:http://nginx.org/en/download.html 2)      对Nginx的配置主要是对它的配置文件/conf/nginx.conf的修改.如下链接是nginx.conf配置文件各个属性的详细说明:

Nginx+Tomcat搭建高性能负载均衡集群(转)

一.       工具 nginx-1.8.0 apache-tomcat-6.0.33 二.    目标 实现高性能负载均衡的Tomcat集群: 三.    步骤 1.首先下载Nginx,要下载稳定版: 2.然后解压两个Tomcat,分别命名为apache-tomcat-6.0.33-1和apache-tomcat-6.0.33-2: 3.然后修改这两个Tomcat的启动端口,分别为18080和28080,下面以修改第一台Tomcat为例,打开Tomcat的conf目录下的server.xml

LVS+Keepalived+Squid+Nginx+MySQL主从 高性能集群架构配置

原文地址:LVS+Keepalived+Squid+Nginx+MySQL主从 高性能集群架构配置 作者:gron 原文链接:http://www.linuxidc.com/Linux/2012-07/65547.htm 架构图 先进行优化 vi /etc/sysctl.conf   # 编辑sysctl.conf文件添加以下内容 net.ipv4.tcp_rmem = 4096 87380 4194304 net.ipv4.tcp_wmem = 4096 65536 4194304 net.c

LVS+Keepalived+Squid+Nginx+MySQL主从高性能集群架构部署方案

方案一,在tomcat的workers.properties里面配置相关条件 worker.tomcat.lbfactor=50 worker.tomcat.cachesize=10 worker.tomcat.cache_timeout=600 worker.tomcat.socket_keepalive=1 worker.tomcat.socket_timeout=300 Linux内核优化: vi /etc/sysctl.conf   # 编辑sysctl.conf文件添加以下内容net.

利用Nginx构建负载均衡服务器

大家都知道,一个域名对应一个IP地址,而一个WebSite则对应一个IP地址上对应端口服务的应用程序(或位置).而大型网站的并发访问量非常大,这些网站是如何在一台Web服务器上实现负载均衡的呢? 相信很多人会有与我同样的疑惑,但实际上成熟的解决方案已经大规模投入使用.而常用的则是反向代理方法. 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理

【转载】Nginx+Tomcat搭建高性能负载均衡集群

最近对负载均衡比较感兴趣,研究了公司的负载均衡的配置,用的是阿里的SLB,相当于不用运维,只需要在后台进行简单的配置就能完成Tomcat的负载均衡,索性在网上找了几篇文章去尝试搭建一个集群,然而很多都是过时了或者不全,最后找到一个测试过能成功的文章. 一.       工具 nginx-1.8.0 apache-tomcat-6.0.33 二.    目标 实现高性能负载均衡的Tomcat集群: 三.    步骤 1.首先下载Nginx,要下载稳定版: 2.然后解压两个Tomcat,分别命名为a

Nginx+Tomcat搭建高性能负载均衡集群

一.       工具 nginx-1.8.0 apache-tomcat-6.0.33 二.    目标 实现高性能负载均衡的Tomcat集群: 三.    步骤 1.首先下载Nginx,要下载稳定版: 2.然后解压两个Tomcat,分别命名为apache-tomcat-6.0.33-1和apache-tomcat-6.0.33-2: 3.然后修改这两个Tomcat的启动端口,分别为18080和28080,下面以修改第一台Tomcat为例,打开Tomcat的conf目录下的server.xml

高性能Web服务之nginx应用详解

一.Nginx特性 * *模块化,目前只能将模块编译进Nginx,暂时不支持动态装卸模块.(httpd优势) * *可靠性,一个主进程(master)控制多个工作进程(worker),工作进程响应用户多个请求(httpd劣势) * *低内存消耗,(httpd劣势) * *支持热部署,(httpd相同) * *支持事件驱动I/O,AI/O,支持mmap(httpd2.4才算支持event,劣势) 二.Nginx基本架构 Nginx由一个master进程生成多个worker进程,每个worker进程